Disclaimer!
This a information regarding mainline kernel, copied from the ubuntu wiki:
By default, Ubuntu systems run with the Ubuntu kernels provided by the Ubuntu repositories. However it is handy to be able to test with unmodified upstream kernels to help locate problems in Ubuntu kernel patches, or to confirm that upstream has fixed a specific issue. To this end we now offer select upstream kernel builds. These kernels are made from unmodified kernel source but using the Ubuntu kernel configuration files. These are then packaged as Ubuntu .deb files for simple installation, saving you the time of compiling kernels, and debugging build issues.
These kernels are not supported and are not appropriate for production use.
Install kernel from PPA mainline
For detailed instruction follow this link: https://wiki.ubuntu.com/Kernel/MainlineBuilds
BUT, there is a semi-automated way to install the version of kernel of your choice:
For more information and installation procedure follow instruction on this site: https://github.com/pimlie/ubuntu-mainline-kernel.sh
Using ubuntu-mainline-kernel to install rc release
For testing the rc release of the kernel, do:
sudo ubuntu-mainline-kernel.sh --rc -i
MOK keys
If you are using ubuntu 20.04 and during installation
- Had “Secure Boot” enabled
- Choosed to install 3rd party drivers
There is a chance you were asked to enroll new key in MOK, which is automatically used to sign new kernel modules.
Those keys are available in location
$ ls /var/lib/shim-signed/mok/*
/var/lib/shim-signed/mok/MOK.der /var/lib/shim-signed/mok/MOK.priv
To use the to sign kernel as well we have to transform the MOK.der key to the PEM format and to do so type:
$ cd /var/lib/shim-signed/mok
$ sudo openssl x509 -in MOK.der -inform DER -outform PEM -out MOK.pem
Sign your kernel
-
Sign the vmlinuz kernel of your choice
sudo sbsign --key /var/lib/shim-signed/mok/MOK.priv --cert /var/lib/shim-signed/mok/MOK.pem /boot/vmlinuz-[KERNEL-VERSION]-generic --output /boot/vmlinuz-[KERNEL-VERSION]-generic.signed
-
Copy the initram to create a pair with signed vmlinuz image
$ sudo cp /boot/initrd.img-[KERNEL-VERSION]-generic{,.signed}
-
Update GRUB
$ sudo update-grub
Rebot and test
After reboot choose in grub entry of the signed kernel, and if system boots up properly and you want to keep the configuration, you can overwrite unsigned version of your kernel and call update-grub
again
sudo mv /boot/vmlinuz-[KERNEL-VERSION]-generic{.signed,}
sudo mv /boot/initrd.img-[KERNEL-VERSION]-generic{.signed,}
sudo update-grub