14 KiB
layout | title | permalink | redirect_from | |
---|---|---|---|---|
doc | Managing VM kernel | /doc/managing-vm-kernel/ |
|
VM kernel managed by dom0
By default, VMs kernels are provided by dom0. This means that:
- You can select the kernel version in VM settings;
- You can modify kernel options in VM settings;
- You can not modify any of the above from inside a VM;
- Installing additional kernel modules is cumbersome.
Note In the examples below, although the specific version numbers might be old, the commands have been verified on R3.2 with debian-9 and fedora-26 templates. At the time of writing, there is a blocking issue for R4.0 3563.
To select which kernel a given VM will use, you can either use Qubes Manager (VM settings, advanced tab), or the qvm-prefs
tool:
[user@dom0 ~]$ qvm-prefs -s my-appvm kernel
Missing kernel version argument!
Possible values:
1) default
2) none (kernels subdir in VM)
3) <kernel version>, one of:
- 3.18.16-3
- 3.18.17-4
- 3.19.fc20
- 3.18.10-2
[user@dom0 ~]$ qvm-prefs -s my-appvm kernel 3.18.17-4
[user@dom0 ~]$ qvm-prefs -s my-appvm kernel default
To check/change the default kernel you can either go to "Global settings" in Qubes Manager, or use the qubes-prefs
tool:
[user@dom0 ~]$ qubes-prefs
clockvm : sys-net
default-fw-netvm : sys-net
default-kernel : 3.18.17-4
default-netvm : sys-firewall
default-template : fedora-21
updatevm : sys-firewall
[user@dom0 ~]$ qubes-prefs -s default-kernel 3.19.fc20
Installing different kernel using Qubes kernel package
VM kernels are packages by Qubes team in kernel-qubes-vm
packages.
Generally, the system will keep the three newest available versions.
You can list them with the rpm
command:
[user@dom0 ~]$ rpm -qa 'kernel-qubes-vm*'
kernel-qubes-vm-3.18.10-2.pvops.qubes.x86_64
kernel-qubes-vm-3.18.16-3.pvops.qubes.x86_64
kernel-qubes-vm-3.18.17-4.pvops.qubes.x86_64
If you want a more recent version, you can check the qubes-dom0-unstable
repository.
There is also the kernel-latest-qubes-vm
package which should provide a more recent (non-LTS) kernel, but has received much less testing.
As the names suggest, keep in mind that those packages may be less stable than the default ones.
To check available versions in the qubes-dom0-unstable
repository:
[user@dom0 ~]$ sudo qubes-dom0-update --enablerepo=qubes-dom0-unstable --action=list kernel-qubes-vm
Using sys-firewall as UpdateVM to download updates for Dom0; this may take some time...
Running command on VM: 'sys-firewall'...
Loaded plugins: langpacks, post-transaction-actions, yum-qubes-hooks
Installed Packages
kernel-qubes-vm.x86_64 1000:3.18.10-2.pvops.qubes installed
kernel-qubes-vm.x86_64 1000:3.18.16-3.pvops.qubes installed
kernel-qubes-vm.x86_64 1000:3.18.17-4.pvops.qubes installed
Available Packages
kernel-qubes-vm.x86_64 1000:4.1.12-6.pvops.qubes qubes-dom0-unstable
No packages downloaded
Installed Packages
kernel-qubes-vm.x86_64 1000:3.18.10-2.pvops.qubes @anaconda/R3.0
kernel-qubes-vm.x86_64 1000:3.18.16-3.pvops.qubes @/kernel-qubes-vm-3.18.16-3.pvops.qubes.x86_64
kernel-qubes-vm.x86_64 1000:3.18.17-4.pvops.qubes @qubes-dom0-cached
Installing a new version from qubes-dom0-unstable
repository:
[user@dom0 ~]$ sudo qubes-dom0-update --enablerepo=qubes-dom0-unstable kernel-qubes-vm
Using sys-firewall as UpdateVM to download updates for Dom0; this may take some time...
Running command on VM: 'sys-firewall'...
Loaded plugins: langpacks, post-transaction-actions, yum-qubes-hooks
Resolving Dependencies
(...)
===========================================================================================
Package Arch Version Repository Size
===========================================================================================
Installing:
kernel-qubes-vm x86_64 1000:4.1.12-6.pvops.qubes qubes-dom0-cached 40 M
Removing:
kernel-qubes-vm x86_64 1000:3.18.10-2.pvops.qubes @anaconda/R3.0 134 M
Transaction Summary
===========================================================================================
Install 1 Package
Remove 1 Package
Total download size: 40 M
Is this ok [y/d/N]: y
Downloading packages:
Running transaction check
Running transaction test
Transaction test succeeded
Running transaction (shutdown inhibited)
Installing : 1000:kernel-qubes-vm-4.1.12-6.pvops.qubes.x86_64 1/2
mke2fs 1.42.12 (29-Aug-2014)
This kernel version is used by at least one VM, cannot remove
error: %preun(kernel-qubes-vm-1000:3.18.10-2.pvops.qubes.x86_64) scriptlet failed, exit status 1
Error in PREUN scriptlet in rpm package 1000:kernel-qubes-vm-3.18.10-2.pvops.qubes.x86_64
Verifying : 1000:kernel-qubes-vm-4.1.12-6.pvops.qubes.x86_64 1/2
Verifying : 1000:kernel-qubes-vm-3.18.10-2.pvops.qubes.x86_64 2/2
Installed:
kernel-qubes-vm.x86_64 1000:4.1.12-6.pvops.qubes
Failed:
kernel-qubes-vm.x86_64 1000:3.18.10-2.pvops.qubes
Complete!
[user@dom0 ~]$
In the above example, it tries to remove the 3.18.10-2.pvops.qubes kernel (to keep only three installed), but since some VM uses it, it fails. Installation of the new package is unaffected by this event.
The newly installed package is set as the default VM kernel.
Installing different VM kernel based on dom0 kernel
It is possible to package a kernel installed in dom0 as a VM kernel. This makes it possible to use a VM kernel which is not packaged by Qubes team. This includes:
- using a Fedora kernel package
- using a manually compiled kernel
To prepare such a VM kernel, you need to install the qubes-kernel-vm-support
package in dom0 and also have matching kernel headers installed (kernel-devel
package in the case of a Fedora kernel package).
You can install requirements using qubes-dom0-update
:
[user@dom0 ~]$ sudo qubes-dom0-update qubes-kernel-vm-support kernel-devel
Using sys-firewall as UpdateVM to download updates for Dom0; this may take some time...
Running command on VM: 'sys-firewall'...
Loaded plugins: langpacks, post-transaction-actions, yum-qubes-hooks
Package 1000:kernel-devel-4.1.9-6.pvops.qubes.x86_64 already installed and latest version
Resolving Dependencies
(...)
================================================================================
Package Arch Version Repository Size
================================================================================
Installing:
qubes-kernel-vm-support x86_64 3.1.2-1.fc20 qubes-dom0-cached 9.2 k
Transaction Summary
================================================================================
Install 1 Package
Total download size: 9.2 k
Installed size: 13 k
Is this ok [y/d/N]: y
Downloading packages:
Running transaction check
Running transaction test
Transaction test succeeded
Running transaction (shutdown inhibited)
Installing : qubes-kernel-vm-support-3.1.2-1.fc20.x86_64 1/1
Creating symlink /var/lib/dkms/u2mfn/3.1.2/source ->
/usr/src/u2mfn-3.1.2
DKMS: add completed.
Verifying : qubes-kernel-vm-support-3.1.2-1.fc20.x86_64 1/1
Installed:
qubes-kernel-vm-support.x86_64 0:3.1.2-1.fc20
Complete!
Then you can call the qubes-prepare-vm-kernel
tool to actually package the kernel.
The first parameter is kernel version (exactly as seen by the kernel), the second one (optional) is short name.
This is visible in Qubes Manager and the qvm-prefs
tool.
[user@dom0 ~]$ sudo qubes-prepare-vm-kernel 4.1.9-6.pvops.qubes.x86_64 4.1.qubes
--> Building files for 4.1.9-6.pvops.qubes.x86_64 in /var/lib/qubes/vm-kernels/4.1.qubes
---> Recompiling kernel module (u2mfn)
---> Generating modules.img
mke2fs 1.42.12 (29-Aug-2014)
---> Generating initramfs
--> Done.
Using kernel installed in the VM
This option is available only in Qubes R3.1 or newer
It is possible to use a kernel installed in the VM (in most cases - TemplateVM). This is possible thanks to PV GRUB2 - GRUB2 running in the VM. To make it happen, at a high level you need to:
- Install PV GRUB2 (
grub2-xen
) in dom0. - Install kernel in the VM (see below for Fedora and Debian steps). As with all VM software installation - this needs to be done in a TemplateVM (or StandaloneVM if you are using one).
- Set VM kernel to
pvgrub2
value. You can usepvgrub2
in selected VMs, but it's not necessary in all of them, even if its template has a kernel installed. You can still use a dom0-provided kernel for selected VMs.
WARNING: When using a kernel from within a VM, the kernelopts
parameter is ignored.
Installing PV GRUB2
Simply execute:
sudo qubes-dom0-update grub2-xen
Installing kernel in Fedora VM
In a Fedora based VM, you need to install the qubes-kernel-vm-support
package.
This package includes the additional kernel module and initramfs addition required to start a Qubes VM (for details see template implementation).
Additionally, you need some GRUB tools to create its configuration.
Note: You don't need an actual grub bootloader as it is provided by dom0, but having one shouldn't hurt.
sudo dnf install qubes-kernel-vm-support grub2-tools
Then install whatever kernel you want.
You need to also ensure you have the kernel-devel
package for the same kernel version installed.
If you are using a distribution kernel package (kernel
package), the initramfs and kernel modules may be handled automatically.
If you are using a manually built kernel, you need to handle this on your own.
Take a look at the dkms
documentation, especially the dkms autoinstall
command may be useful.
If you did not see the kernel
install rebuild your initramfs, or are using a manually built kernel, you will need to rebuild it yourself with the following:
sudo dracut -H -f /boot/initramfs-$(uname -r).img $(uname -r)
Once the kernel is installed, you need to create a GRUB configuration.
You may want to adjust some settings in /etc/default/grub
; for example, lower GRUB_TIMEOUT
to speed up VM startup.
Then, you need to generate the actual configuration:
In Fedora it can be done using the grub2-mkconfig
tool:
sudo grub2-mkconfig -o /boot/grub2/grub.cfg
You can safely ignore this error message:
grub2-probe: error: cannot find a GRUB drive for /dev/mapper/dmroot. Check your device.map
Then shutdown the VM.
Now you can set pvgrub2
as the VM kernel and it will start the kernel configured within your VM.
Note: On first boot the VM will automatically allocate swap space.
This can take a while to complete- longer than your qrexec_timeout
setting, which will make the VM appear to have hung on boot.
To confirm this is the case, see Troubleshooting below or just wait for five minutes and shutdown the VM.
It should respond normally on future boots.
Installing kernel in Debian VM
In a Debian based VM, you need to install the qubes-kernel-vm-support
package.
This package includes the additional kernel module and initramfs addition required to start a Qubes VM (for details see template implementation).
Additionally, you need some GRUB tools to create its configuration.
Note: You don't need an actual grub bootloader as it is provided by dom0, but having one shouldn't hurt.
sudo apt update
sudo apt install qubes-kernel-vm-support grub2-common
If prompted for a GRUB install device, choose /dev/mapper/dmroot
.
You will receive an error about GRUB failed to install to it, but just continue anyways.
Ignore warnings about version '...' has bad syntax
.
Then install whatever kernel you want.
If you are using a distribution kernel package (linux-image-amd64
package), the initramfs and kernel modules should be handled automatically.
If not, or you are building the kernel manually, do this using dkms
and initramfs-tools
:
sudo dkms autoinstall -k <kernel-version> # replace this <kernel-version> with actual kernel version
sudo update-initramfs -u
The output should look like this:
$ sudo dkms autoinstall -k 3.16.0-4-amd64
u2mfn:
Running module version sanity check.
- Original module
- No original module exists within this kernel
- Installation
- Installing to /lib/modules/3.16.0-4-amd64/updates/dkms/
depmod....
DKMS: install completed.
$ sudo update-initramfs -u
update-initramfs: Generating /boot/initrd.img-3.16.0-4-amd64
When the kernel is installed, you need to create a GRUB configuration.
You may want to adjust some settings in /etc/default/grub
; for example, lower GRUB_TIMEOUT
to speed up VM startup.
Then, you need to generate the actual configuration with the update-grub2
tool:
sudo mkdir /boot/grub
sudo update-grub2
You can safely ignore this error message:
grub2-probe: error: cannot find a GRUB drive for /dev/mapper/dmroot. Check your device.map
Then shutdown the VM.
Now you can set pvgrub2
as the VM kernel and it will start the kernel configured within your VM.
When starting the VM you can safely ignore any warnings about a missing module 'dummy-hcd'.
Note: on first boot the VM will automatically allocate swap space.
This can take a while to complete- longer than your qrexec_timeout
setting, which will make the VM appear to have hung on boot.
To confirm this is the case, see Troubleshooting below or just wait for five minutes and shutdown the VM.
It should respond normally on future boots.
Troubleshooting
In case of problems, you can access the VM console using sudo xl console VMNAME
in dom0, then access the GRUB menu.
You need to call it just after starting the VM (until GRUB_TIMEOUT
expires); for example, in a separate dom0 terminal window.
In any case you can later access the VM's logs (especially the VM console log guest-VMNAME.log
).
You can always set the kernel back to some dom0-provided value to fix a VM kernel installation.