Ansible role to configure KVM nested virtualization for Intel and AMD CPUs
jm1.kvm_nested_virtualization
This role enables KVM nested virtualization for Intel and AMD CPUs.
It adds or removes options kvm_* nested=y
for kernel modules kvm_intel
and kvm_amd
in modprobe config file/etc/modprobe.d/kvm-nested-virtualization.conf
(defined with variable modprobe_conf_path
). When kernel module
options have been changed and reload_module
is true, then it will reload the current kvm kernel module with Ansible
module community.general.modprobe
.
WARNING:
This role will remove and (re)load the kvm_intel
and kvm_amd
modules from the Linux kernel to apply changes when
variable reload_module
is set to true. Before executing this role ensure that no virtual machines or other processes
depending on these modules are running.
With state: present
, this role runs tasks similar to the following shell commands:
# Reloading kernel modules and changing their options requires root rights
sudo -s
# Identify kvm support
if ! grep -E 'vmx|svm' -q /proc/cpuinfo; then
echo "No virtualization support has been detected"
else
if grep -E 'vmx' -q /proc/cpuinfo; then
# Detected Intel virtualization
kvm_kernel_module="kvm_intel"
else
# Detected AMD virtualization
kvm_kernel_module="kvm_amd"
fi
# Add module options to enable nested virtualization
cat << ____EOF > /etc/modprobe.d/kvm-nested-virtualization.conf
# 2020-2022 Jakob Meng, <jakobmeng@web.de>
# Enable KVM nested virtualization for Intel and AMD CPUs
# Ref.: https://galaxy.ansible.com/jm1/kvm_nested_virtualization
options kvm_intel nested=y
options kvm_amd nested=1
____EOF
# Ensure kernel module is available and loaded
modprobe "$kvm_kernel_module"
# Reload kernel module to apply changes
if grep -E '^N|0$' -q "/sys/module/${kvm_kernel_module}/parameters/nested"; then
rmmod "$kvm_kernel_module"
modprobe "$kvm_kernel_module"
fi
fi
With state: absent
, this role runs tasks similar to the following shell commands:
# Reloading kernel modules and changing their options requires root rights
sudo -s
# Identify kvm support
if ! grep -E 'vmx|svm' -q /proc/cpuinfo; then
echo "No virtualization support has been detected"
else
if grep -E 'vmx' -q /proc/cpuinfo; then
# Detected Intel virtualization
kvm_kernel_module="kvm_intel"
else
# Detected AMD virtualization
kvm_kernel_module="kvm_amd"
fi
# Remove module options to enable nested virtualization
rm /etc/modprobe.d/kvm-nested-virtualization.conf
# Ensure kernel module is available and loaded
modprobe "$kvm_kernel_module"
# Reload kernel module to apply changes
if grep -E '^Y|1$' -q "/sys/module/${kvm_kernel_module}/parameters/nested"; then
rmmod "$kvm_kernel_module"
modprobe "$kvm_kernel_module"
fi
fi
Tested OS images
Debian 10 (Buster)
[amd64
]Debian 11 (Bullseye)
[amd64
]Debian 12 (Bookworm)
[amd64
]CentOS 7 (Core)
[amd64
]CentOS 8 (Core)
[amd64
]CentOS 9 (Stream)
[amd64
]Ubuntu 18.04 LTS (Bionic Beaver)
[amd64
]Ubuntu 20.04 LTS (Focal Fossa)
[amd64
]Ubuntu 22.04 LTS (Jammy Jellyfish)
[amd64
]Available on Ansible Galaxy: jm1.kvm_nested_virtualization
This role is inspired by Lukas Bednar’slukas-bednar.nested_virtualization
role.
This role uses module(s) from collection community.general
. You can fetch this collection
from Ansible Galaxy using the provided requirements.yml
:
ansible-galaxy collection install --requirements-file requirements.yml
Name | Default value | Required | Description |
---|---|---|---|
modprobe_conf_path |
/etc/modprobe.d/kvm-nested-virtualization.conf |
no | Path to modprobe config file. If this file already exists, then it will be overwritten. If state is absent , then this file will be removed. |
reload_module |
yes |
no | Should the current kernel module be reloaded if configuration has changed. Beware, the module must not be in use, e.g. no VMs must be running |
state |
present |
no | Should KVM nested virtualization be present or absent |
None.
- hosts: all
roles:
- name: Enable KVM nested virtualization for Intel and AMD CPUs
role: jm1.kvm_nested_virtualization
# Optional: Pass variables to role
vars:
modprobe_conf_path: '/etc/modprobe.d/kvm-nested-virtualization.conf'
reload_module: yes
state: present
For instructions on how to run Ansible playbooks have look at Ansible’s
Getting Started Guide.
GNU General Public License v3.0 or later
See LICENSE.md to see the full text.