I am forever losing random blog posts that explain the mysterious inner workings of Advanced Linux Components: udev, kmod, UEFI kernel mod signing, etc.
Rather than continue to accrue bookmarks that rot over time, I’m going to start writing down what I’ve learned, so I can reference it on a domain that won’t disappear in 3 years…
Installing nVidia drivers + Optimus in Fedora UEFI secure boot
Optimus is nVidia’s tech for switching loads from the lame-o built-in Intel GPUiGPU, for integrated to the beefy, discrete nVidia GPUeGPU, for, uh, not-the-intel-one in your workstation-y, game-y laptops. They have A New Thing now they call PRIME Render Offload that does High-Level Magic to render things on the beefy eGPU then feed it to the iGPU for display in the same X session.
nVidia added Linux support for PRIME in early 2019 or so, judging from the dates on internet comment threads. Fedora 31 supports all the patches to the X11 upstream natively–one of many reasons that Fedora and Arch are the only Linux distributions worth installing. And, surprisingly, RPM Fusion has a functioning kmod package for the nVidia drivers that’s new enough to support PRIME. Convenient!
dnf install akmod-nvidia
pgrep kmod–wait for the module to finish compiling before doing anything else, sheesh.
- You already added your 509 DER sign-y keysWait, you do have 509 DER sign-y keys, right? No? Then, sheesh, do this: openssl req -new -x509 -newkey rsa:2048 -keyout MOK.priv -outform DER -out MOK.der -nodes -days 36500 -subj “/CN=Eric Lawler Gave Me This Script and I Ran It Without Changing Any Values/” to the UEFI MOK, right? If not:
mokutil --import your-public-key.der
- Give mokutil a nice password
- Reboot your machine
- Tell the lovely BIOS blue screen you want to add a new key. You should choose
View key #0to ensure that’s the one you added. Is it good through 2119? It probably should be. You don’t want your extra kernel modules to stop working next century, right?
- ADD THE KEY. You’ll have to enter your password from step ii (pronounced aiai).
- And that’s it. When you boot, you can sign things with that MOK key.
- Sign all the nVidia kernel modules with your DER key. You’ll have to do this every time you update the nVidia drivers or install a new kernel. Same as VirtualBox. I have a simple sh script:
echo 'Signing kernel modules for nvidia...' for i in /usr/lib/modules/$(uname -r)/extra/nvidia/*ko; do echo "...signing $i" sudo /usr/src/kernels/$(uname -r)/scripts/sign-file sha256 my-private-key.priv my-public-key.der "$i"; done echo 'Starting kernel modules' sudo modprobe -v nvidia
…except that, of course, the kernel modules can’t start while nouveau is loaded. So reboot one more time after the first install to be running with nVidia’s drivers.
How to use it?
To use your laptop’s beefy nVidia GPU, append this environment string to whatever you’re running:
__NV_PRIME_RENDER_OFFLOAD=1 __GLX_VENDOR_LIBRARY_NAME=nvidia [program]
Steam launchers can be modified like so:
__NV_PRIME_RENDER_OFFLOAD=1 __GLX_VENDOR_LIBRARY_NAME=nvidia %command%
Remapping caps lock to backspace, 2019 edition
This one’s a real mess, but I’m too lazy to type it out now. I’m trusting that this dangling appendage will
embarrass shame me into completing it, since the new Ask Fedora is absolutely, 100% useless and all the old Ask Fedora content (now rebranded as Askbot.fedora.org) will vanish soon, including Ahmad Samir’s ridiculously useful answer to my udev question from 2013.
tldr? Dig into the udev Readmes hiding on your system to learn all the udev utilities to run and monitor output while poking keys on your keyboard. Then you’ll suss out the manufacturer specific serial numbers/device IDs you can use to run rules or straight-up remap the hardware, as I do.
Here is my cookbook, for the next computer I purchase. Plop this in
/lib/udev/hwdb.d/90-custom-keyboard.hwdb, in Linux kernel 5.X+ and this will cause the kernel to translate all slaps of the caps lock key, useless invention that it is, as a backspace key to every single application on your system: In X and Wayland and Virtual Terminals alike.
# Dell XPS 15 evdev:input:b0011v0001p0001eAB41* KEYBOARD_KEY_3a=backspace KEYBOARD_KEY_70039=backspace # generic Logitech evdev:input:b0003v046DpC31* KEYBOARD_KEY_3a=backspace KEYBOARD_KEY_70039=backspace # Microsoft Sculpt Ergo Keyboard evdev:input:b0003v045Ep07A5* KEYBOARD_KEY_3a=backspace KEYBOARD_KEY_70039=backspace # Microsoft Natural Ergonomic Keyboard 4000 evdev:input:b0003v045Ep00DB* KEYBOARD_KEY_3a=backspace KEYBOARD_KEY_70039=backspace KEYBOARD_KEY_c022d=up KEYBOARD_KEY_c022e=down # das keyboard evdev:input:b0003v24F0* KEYBOARD_KEY_3a=backspace KEYBOARD_KEY_70039=backspace