Dom0 Kernels for Xen

From Xen
Revision as of 02:28, 27 November 2011 by Kyl191 (talk | contribs) (Linux Distributions which have a Xen Dom0 kernel provided by a third party: Clean up Fedora info)

Xen Dom0 kernel: Quick Start

If you don't know what "dom0" or a "dom0 kernel" is, jump to the detailed explanation below.

This page contains information on Xen dom0 support, if you are looking for information on guest (domU) support see XenDomUSupport.

Linux Distributions which include a Xen Dom0 kernel

If possible we highly recommend choosing one of the following distributions which include a domain 0 kernel out of the box. They provide rpm or deb packages containing a dom0 kernel which can be installed using your favourite package manager. This provides the benefits such as ease of install, good integration with the distribution, support from the distribution, provision of security updates etc.

Distributions Versions
Debian 4.0 (Etch), 5.0 (Lenny), 6.0 (Squeeze)[1]
Fedora 16[1]
OpenSUSE 10.x, 11.x, 12.x
Oracle VM for x86 (OVM) All versions
Redhat Enterprise Linux (RHEL) 5.x
SUSE Linux Enterprise Server (SLES) 10.x, 11.x
Ubuntu 11.10[1][2]
Xen Cloud Project (XCP) All versions
XenServer All versions

[1] Please note that this kernel requires Xen >= 4.0.
[2] Planned or in beta as of October 2011.

Linux Distributions which have a Xen Dom0 kernel provided by a third party

If you are unable to use one of the above distributions then you may be able to use one of the following which have suitable dom0 kernels provided by third party packagers.


Now that dom0 kernel support has entered the upstream kernel, Fedora 16 (and later) supports Xen out of the box.

Obsolete information: This is relevant for Fedora 15 and lesser If you are running Fedora 15 or earlier you can find third party rpm packages built for you by M A Young (they require Xen >= 4.0).

Red Hat Enterprise Linux and CentOS

The last release of RHEL (and by extension CentOS and other derivatives) to include a Xen dom0 kernel was RHEL 5. We are currently working with the community to provide dom0 kernel packages for RHEL 6.


The last release of Ubuntu which includes a Xen dom0 kernel is 11.10 (Oneiric Ocelot). If you are running a older version of Ubuntu we recommend using the Debian Squeeze dom0 deb packages:

Dom0 support in BSDs and other Unix systems

This list is currently incomplete. We are in the process of verifying support for other Unixes.

Distributions Versions
NetBSD 5.1[1]

[1] See NetBSD Xen HowTo for more information
[2] See NetBSD Xen User Guide

Xen dom0 kernels: the detailed version

Xen hypervisor is not usable without Domain-0 ("dom0"). Privileged dom0 guest is the "host" operating system (or a "service console", if you prefer), it has drivers for hardware, it runs the Xen management toolstack, it is used to manage the whole system, and it provides Xen virtual disks and network access for other guests aka domUs (unprivileged domains) . Usually dom0 is running Linux kernel, but Xen dom0 implementations also exist for OpenSolaris and NetBSD.

If any of the info on this wiki page is out of date, you have something to add or change, please contact xen-devel mailing list.

How to choose a Xen dom0 kernel?

  • If your Linux distribution includes Xen and dom0 kernel it is recommended to use them. That allows you to easily get the security fixes as a part of the normal package upgrades provided by your distribution.
  • Xen PV domU kernel versions can be different from dom0 kernel versions. There's no need to upgrade domU kernel when you upgrade Xen hypervisor and/or dom0 kernel. Xen hypervisor is backwards compatible, ie. it supports older domU kernels. If your domU distribution includes a Xen domU kernel, it's usually best to use it and not compile your own domU kernel.

What Xen dom0 capable Linux kernel versions are available? Where to get them?

Please see XenKernelFeatures wiki page for more information about available features in different Xen enabled kernels.

There are two different types of Xen dom0 capable kernels available today:

  • pvops kernels, featuring new rewritten Xen support based on the upstream ( Linux pvops framework. This work has been included in upstream kernel since Linux 2.6.37.
  • xenlinux kernels based on the "old" patches originally for Linux 2.6.18. These Xenlinux patches won't be integrated to upstream Linux.

Xen 4.0 switched to using Linux pv_ops based dom0 kernel as a default. This is the kernel all users should be using and testing, and all the development should be made against the upstream pvops kernel.

pv_ops Xen dom0 kernel, based on upstream linux git tree

  • New default dom0 kernel in Xen >= 4.0, most features have been implemented or forward-ported (compared to the old default linux-2.6.18-xen).
  • pv_ops kernels require Xen >= 4.0.
  • pv_ops dom0 support has been merged into upstream Linux 2.6.37 kernel, so dom0 support is included out-of-the-box in Linux 2.6.37 and later versions.
  • Missing features: scsiback and scsifront for pvscsi, usbback and usbfront for pvusb (patches exist).
  • Long-term maintained pv_ops 2.6.32 dom0 kernel is available here, branch name "xen/stable-2.6.32.x": git://
  • See this wiki page for more information and for instructions how to get the pv_ops dom0 kernel:
  • Some help and tips for migrating from linux-2.6.18 to pvops dom0 kernel available from this wiki page: Migrate_from_Linux_2.6.18_to_2.6.31_and_higher

older Linux 2.6.18 "Xenlinux" based source trees and/or patchsets, and the various forward-ports of them

Xen dom0 kernels included in Linux distributions

  • Redhat Enterprise Linux 5 (RHEL5) and CentOS 5
    • Includes Xen dom0 kernel based on Linux 2.6.18, with a lot of patches and fixes by Redhat.
    • Redhat has also backported a lot of drivers and support for new hardware and features into their version of Linux 2.6.18.
    • Good choice as dom0 because RHEL5 has long lifecycle, and it's actively maintained and bugfixed.
    • Good choice because it's tested and certified to run on many vendors server hardware.
    • Good choice especially if you are trying out Xen virtualization for the first time, and want to use a distribution that has well working and tested Xen included.
  • Fedora
    • Fedora 8 is currently the latest release to include Xen dom0 kernel.
    • Fedora 9 - 14 do not contain Xen dom0 kernels (but they do contain Xen hypervisor and tools and Xen domU enabled kernels).
    • Fedora is planning to add support for Xen dom0 again when pv_ops dom0 is included in the upstream Linux kernels.
    • For more information:
    • M A Young is building unofficial pv_ops xendom0 kernel RPMs for Fedora. Download:
    • See fedora-xen and/or fedora-virt mailinglist archives for more information.
  • Debian
    • Debian 4.0 ("Etch") contains 2.6.18 Xen dom0 kernel.
    • Debian 5.0 ("Lenny") contains 2.6.26 Xen dom0 kernel based on early version of OpenSUSE forward-ported patches. Some users have experienced stability problems with this kernel, when used with newer Xen 3.3 and 3.4 hypervisors. Also, some users have reported live migrations being broken with this lenny's kernel.
    • Debian 6.0 ("Squeeze") contains a pv_ops Xen dom0 kernel
  • Ubuntu
    • Ubuntu 8.04 LTS (Hardy Heron) has Xen dom0 kernel (based on Linux 2.6.24) available in the universe repository (so it's not part of the official release - it's community supported). Unfortunately many users have reported various bugs with this kernel - both as dom0 and as domU.
    • Ubuntu 8.10 (Intrepid) and later ubuntu versions unfortunately don't include Xen dom0 kernels in the repositories. You have to compile/download your own dom0 kernel, or use Debian kernels.
  • Gentoo
    • Gentoo has multiple dom0 kernels available: 2.6.18 (latest is xen-sources-2.6.18-r12) and rebased kernels with OpenSUSE patches (latest is xen-sources-2.6.31-r11).
  • OpenSUSE
    • Novell is forward-porting the original Xenlinux 2.6.18 patches for new kernels in OpenSUSE (and SLES).
    • Currently (as of November 2011) patches and Xen dom0 kernel packages exist up to Linux 3.1.
    • OpenSUSE 11.2 ships with Linux 2.6.31 based Xen kernel using the forward-ported Xenlinux patches.
    • OpenSUSE 11.3 ships with Linux 2.6.34 based Xen kernel using the forward-ported Xenlinux patches.
    • OpenSUSE 11.4 ships with Linux 2.6.37 based Xen kernel using the forward-ported Xenlinux patches.
    • OpenSUSE 12.1 ships with Linux 3.1 based Xen kernel using the forward-ported Xenlinux patches.
  • SuSE Linux Enterprise (SLES)
    • SLES10 and SLES11 contain Xen dom0 kernels.
    • SLES10 is based on Linux 2.6.16.
    • SLES11 is based on Linux 2.6.27 with forward-ported original Xenlinux 2.6.18 patches.
    • SLES11 SP1 ships with a Linux 2.6.32 dom0 kernel based on the forward-ported Xenlinux patches.
    • Good choice as dom0 because SLES releases have long lifecycle and they are actively maintained and bugfixed.
    • Good choice because it's tested and certified to run on many vendors server hardware.

Please see XenKernelFeatures wiki page for information about features in different Xen enabled kernels!

Discussion about different Xen dom0 kernels on xen-devel mailinglist June/2009: