Build An Accelerated KVM Guest Custom Kernel for WSL 2 - 2022 Edition
Updated, simpler guide for building a custom Linux kernel for WSL 2 optimized for running nested KVM guests.
data:image/s3,"s3://crabby-images/fa5c8/fa5c86885215650a096afc037e6f4a8f0ee0571d" alt="Build An Accelerated KVM Guest Custom Kernel for WSL 2 - 2022 Edition"
This guide walks you through the process of building a basic accelerated KVM custom kernel for WSL 2 that can be used with any WSL 2 distro you have installed.
This guide has been updated and simplified.
Requirements
Windows 11, build 22000+
WSL 2
OpenSUSE Tumbleweed
This guide works with Intel and AMD processors
data:image/s3,"s3://crabby-images/932e0/932e07207ef203580667f5c9c715c381ee3feb88" alt=""
data:image/s3,"s3://crabby-images/8132d/8132d4610e6434d884a3cc65d734c38c55c6fca2" alt=""
data:image/s3,"s3://crabby-images/9bcb2/9bcb234f5847a70abe146ab7d9779367348ddf3f" alt=""
Update openSUSE and install build dependencies
Run:
sudo zypper -n up
sudo bash -c "zypper in -y -t pattern devel_basis && zypper in -y bc openssl openssl-devel dwarves rpm-build libelf-devel aria2 jq"
data:image/s3,"s3://crabby-images/5b0d6/5b0d64c43cf3bc6f483a8c6d13015694edee9bab" alt=""
Get the Microsoft WSL 2 kernel sources
Run:
curl -s https://api.github.com/repos/microsoft/WSL2-Linux-Kernel/releases/latest | jq -r '.name' | sed 's/$/.tar.gz/' | sed 's#^#https://github.com/microsoft/WSL2-Linux-Kernel/archive/refs/tags/#' | aria2c -i -
tar -xf *.tar.gz
data:image/s3,"s3://crabby-images/63421/63421f76d65cce91fac0700d8715ccdbd43dfe80" alt=""
data:image/s3,"s3://crabby-images/5e554/5e554ff3f63d15ac0f18c889e30463eaca59d535" alt=""
Change to the kernel directory
Run:
cd "$(find -type d -name "WSL2-Linux-Kernel-linux-msft-wsl-*")"
data:image/s3,"s3://crabby-images/c53dc/c53dc383cb445f40efa01355682bc3cffe31011c" alt=""
Copy the default Microsoft kernel configuration
Run:
cp Microsoft/config-wsl .config
data:image/s3,"s3://crabby-images/55a50/55a5016621c37554130e8906205163c037b21c36" alt=""
Tweak the default Microsoft kernel configuration for KVM guests
The following tweaks are based on kernel version 5.14.
Run:
sed -i 's/# CONFIG_KVM_GUEST is not set/CONFIG_KVM_GUEST=y/g' .config
sed -i 's/# CONFIG_ARCH_CPUIDLE_HALTPOLL is not set/CONFIG_ARCH_CPUIDLE_HALTPOLL=y/g' .config
sed -i 's/# CONFIG_HYPERV_IOMMU is not set/CONFIG_HYPERV_IOMMU=y/g' .config
sed -i '/^# CONFIG_PARAVIRT_TIME_ACCOUNTING is not set/a CONFIG_PARAVIRT_CLOCK=y' .config
sed -i '/^# CONFIG_CPU_IDLE_GOV_TEO is not set/a CONFIG_CPU_IDLE_GOV_HALTPOLL=y' .config
sed -i '/^CONFIG_CPU_IDLE_GOV_HALTPOLL=y/a CONFIG_HALTPOLL_CPUIDLE=y' .config
sed -i 's/CONFIG_HAVE_ARCH_KCSAN=y/CONFIG_HAVE_ARCH_KCSAN=n/g' .config
sed -i '/^CONFIG_HAVE_ARCH_KCSAN=n/a CONFIG_KCSAN=n' .config
data:image/s3,"s3://crabby-images/5756e/5756e1aa8295266f7da3aee0dbc6ccff8b2dbb41" alt=""
Build the kernel
Run:
make -j 8
data:image/s3,"s3://crabby-images/11165/11165d684b57b5d86e2ea5d153246202f7477b80" alt=""
Copy the built kernel to your Windows user's home folder
From WSL:
powershell.exe /C 'Copy-Item .\arch\x86\boot\bzImage $env:USERPROFILE'
data:image/s3,"s3://crabby-images/d551a/d551ac1ca3ba6a767441151175c37af357c891d7" alt=""
Point to your custom kernel in .wslconfig
From WSL:
powershell.exe /C 'Write-Output [wsl2]`nkernel=$env:USERPROFILE\bzImage | % {$_.replace("\","\\")} | Out-File $env:USERPROFILE\.wslconfig -encoding ASCII'
data:image/s3,"s3://crabby-images/12b1c/12b1c0dd5e97e634bafb430e1cc991cd5f2d233c" alt=""
Restart WSL
Open a PowerShell terminal and run:
wsl.exe --shutdown
data:image/s3,"s3://crabby-images/41494/414943a34dc6f5c144d117a46be3678c1a8575b5" alt=""
Confirm you are booting your custom kernel
Confirm you are running your new kernel by checking the date, which should be very recent. Run:
wsl.exe uname -a
data:image/s3,"s3://crabby-images/e3073/e3073b4b7afa1ce8d5f344ce7cb0258c7f9df1cb" alt=""
Congrats, your WSL 2 kernel is now optimized for KVM guests.
Now...what are you going to run with that?