DEV Community

Cover image for Debian 12: NVIDIA Drivers Installation
Anna
Anna

Posted on • Edited on

1

Debian 12: NVIDIA Drivers Installation

NVIDIA, with the rise in popularity of Large Language Models (LLMs), has managed to ride this wave of hype—since LLMs are deeply tied to GPU computations—NVIDIA has firmly secured its position as the leader in the GPU market, leaving AMD GPUs far behind. However, for Linux users, installing and configuring NVIDIA GPU's drivers still gives many goosebumps. In this article, I’ll cover key concepts about NVIDIA drivers and will show an easy way to install them on Debian OS.


Here’s the roadmap of this article:

➀ Understanding what are the drivers on Debian OS and how they are related to Linux kernel.

➁ NVIDIA documentation & NVIDIA official installation guide

➂ NVIDIA drivers installation: "Debian" way:

  • ➂.➀ Adding non-free and contrib components to the apt sources.list
  • ➂.➁ Checking the state of Secure Boot on your PC
  • ➂.➂ Checking if your Debian uses dracut
  • ➂.➃ Installing nvidia-driver package

➃ How and when to update NVIDIA drivers


➀ Linux kernel & Drivers

When you first install an OS using a graphical installer, you might notice the graphics of Installer look a bit rough or stretched, kind of like this:

Image description

After installation is finished and you boot for the first time, everything usually looks fine in terms of resolution. That’s because, during the installation of Debian or any other OS, the Linux Kernel with necessary drivers are installed.

Here’s how it works: you install your OS → the OS also installs the Linux kernel (as it can't operate without it) → the Kernel doesn’t come alone—it has kernel modules, which are essentially the Linux drivers for your PC's hardware pieces.

During installation, the installer doesn’t connect to the Linux kernel source repository to fetch the kernel for your system; instead, it connects to its own repository, where the Linux kernel is packed, optimized, and tuned to work harmoniously with the system. In case of Debian:

The kernels in Debian are distributed in binary form, built from the Debian kernel source. It is important to recognize that Debian kernel source may be (and in most cases is) different from the upstream (or "pristine") kernel source, distributed from www.kernel.org and its mirrors. Due to licensing restrictions, unclear license information, or failure to comply with the Debian Free Software Guidelines (DFSG), parts of the kernel are removed in order to distribute the source in the main section of the Debian archive. (Source)

This piece of information actually puts a light on that age-old question, or dilemma, or whatever you want to call it:

"WHY DID HARDWARE X WORK ON WINDOWS BUT NOT ON DEBIAN?" Well, because Windows uses its own kernel. Second question: "WHY DID HARDWARE X WORK ON UBUNTU BUT NOT ON DEBIAN?" The answer is that Ubuntu prioritizes usability and universality over security, so their developers policies about adding some stuff to their default package repos is definitely less strict than Debian's ones.

Let’s put pieces of information together. Linux kernel has kernel modules and they are providing your system with possibility to use various hardware components of your PC, because drivers per se are kernel modules.

You can explore the drivers available on your system by running ls /lib/modules/$(uname -r)/kernel/drivers/ ($(uname -r) part retrieves the exact version of the kernel currently in use by your system; there might be multiple kernel versions installed, especially if you regularly update your system packages, as the kernel version updates whenever a new kernel release becomes available).

Image description

When I run lspci -k | grep -A 3 NVIDIA, I can see that for my NVIDIA video card, the kernel driver in use is Nouveau. By default, Debian provides Nouveau drivers for NVIDIA graphics cards because they are open-source and non-proprietary, unlike NVIDIA’s official drivers.

I mentioned that Debian "provides" these drivers, and I’d like to elaborate on this. On Debian, the Linux kernel is not just a standalone "file/object" pulled during installation - it is a package. This package is called linux-image-*, where the asterisk represents a specific target build of the kernel package, such as cloud, amd64, rt, and the version of this package. This kernel package linux-image-*includes built-in modules, like the Nouveau driver, to ensure hardware compatibility out of the box. You can actually check which package provides a specific kernel module with dpkg-query command. In case of nouveau driver for NVIDIA video card the command will be:
dpkg-query -S /lib/modules/$(uname -r)/kernel/drivers/gpu/drm/nouveau/nouveau.ko

Image description

Even though there’s nothing wrong with Nouveau drivers for NVIDIA GPUs— you can use them and enjoy very good performance (many Linux users even prefer them over NVIDIA’s proprietary drivers)—if you plan to use your NVIDIA GPU for AI, machine learning, or LLMs, you will absolutely need NVIDIA’s proprietary drivers. There’s no way to access CUDA without these drivers. Plus, it’s always nice to fully utilize the potential of such high-cost hardware like GPUs, and this level of optimization is often only achievable with the manufacturer’s proprietary drivers


➁ NVIDIA documentation & NVIDIA official installation guide

The NVIDIA website can feel like a dark forest. If you go to the official NVIDIA site on the Download The Official NVIDIA Drivers | NVIDIA page, you’ll need to manually enter your NVIDIA device model. Here’s what’s suggested for my NVIDIA GeForce video card:

Image description

The second screenshot shows only 2 items from a long list of 10+ "recommended certified versions." The issue is that they aren’t ordered by version—550.x.x.x is followed by 535.x.x.x, and then it jumps back to 550.x.x.x. The confusion starts right here.

Image description

Let’s say I just pick the first one in the list, which has a nice description:

What is an NVIDIA Recommended Driver?
This driver meets the quality levels applied to Windows drivers that pass testing in Windows Hardware Quality Labs (WHQL), therefore providing the same attention to driver reliability, robustness, and performance for non-Windows operating systems (e.g., Linux).

Well that's nice that it was tested in some Windows Hardware Quality Labs, but I am searching for Linux drivers...well...whatever. If I click on the View button, I’m redirected to the Download page. There, you’ll see three tabs—click on Additional Information, and that’s where the installation instructions are hiding!

Image description

Installation instructions: Once you have downloaded the driver, change to the directory containing the driver package and install the driver by running, as root, sh ./NVIDIA-Linux-x86_64-550.127.05.run

Seems very easy-peasy-lemon-squisy. But what is that .run stuff? Executing something unknown with root privileges...boh. You can check this article to understand why it is not a very good idea.

On Linux systems, a .run file is typically either a single binary executable or a shell script that includes a binary blob that can be installed (source). Essentially, any .run file acts as an installer script that will make system-wide changes, since it specifies that it should be executed with root permissions. As I mentioned earlier, drivers are kernel modules, so this installer will build an additional kernel module for your OS. But what exactly will be inside this new kernel module? Download page of NVIDIA drivers does not mention any compatibility matrix with the kernel, so will this “magic” .run file simply build version 550.x.x.x of the driver for my kernel? Or will it update my kernel to fit its needs? Well, I definitely don’t want my kernel updated!

If you don’t have a clear answer to questions above, that's reason enough NOT to run anything with sh some-cool-installer.run on your Debian system! This isn’t just about the security risks with NVIDIA drivers or the possibility of some embedded nasty stuff—it’s about your Debian stability.

NVIDIA drivers are very close-source and even their license states clearly:

You may not reverse engineer, decompile, or disassemble the SOFTWARE provided in binary form, nor attempt in any other manner to obtain source code of such SOFTWARE

A link to the README instructions is available under the Additional Information tab on the download page.

Image description

Chapter 4 of this README is dedicated to installation of NVIDIA driver with this .run executable.

The .run file is a self-extracting archive. When executed, it extracts the contents of the archive and runs the contained nvidia-installer utility, which provides an interactive interface to walk you through the installation.

And here is about how Nvidia driver installation will communicate with your kernel:

When the installer is run, it will check your system for the required kernel sources and compile the kernel interface. You must have the source code for your kernel installed for compilation to work. On most systems, this means that you will need to locate and install the correct kernel-source, kernel-headers, or kernel-devel package; on some distributions, no additional packages are required.

In a default Debian setup (the set of packages you get pre-installed), you’ll only have the package linux-image-* (which contains kernel itself and default kernel modules-drivers, as it was mentioned above)—without the kernel headers or developer libraries preinstalled. Why is that? First, you need to understand what Linux headers are and why exactly NVIDIA drivers need them.

If you're using your Debian system in the "Debian way," you’re probably installing packages mostly from Debian repositories. Since these packages (including the kernel) come from Debian’s repos, they’re built and tested to work together. The open-source Nouveau drivers, for instance, are part of the linux-image-* Debian package, together with the Linux kernel itself. However, for external, especially third-party software that has to communicate with kernel, your kernel is a "black box." These programs can’t communicate with it directly. That’s where Linux headers come in. Linux headers can be roughly explained as "the programming interface needed to interact with the Linux kernel" - if a software needs to communicate with the kernel, Linux headers are needed to install/build it.

So, naturally, the installation process for NVIDIA drivers requires having Linux headers. However, Linux headers aren’t the only requirement for installation. And the README file contains all the additional instructions.

The important section to pay attention to—which can cause a very unpleasant experience for your PC management—is if this .run script does not find DKMS (Dynamic Kernel Module Support) installed on your system:

The installer will check for the presence of DKMS on your system. If DKMS is found, you will be given the option of registering the kernel module with DKMS. (README)

If this .run script doesn’t find it—will it prompt you to install it, give a warning, fail, or install it for you? I really have no idea. DKMS is your bro when it comes to Linux drivers (kernel modules).

DKMS is a framework which allows kernel modules to be dynamically built for each kernel on your system in a simplified and organized fashion. (Source)

It is exactly DKMS that takes care of automatically rebuilding registered kernel modules (read drivers) whenever you install a different Linux kernel. So, if the NVIDIA proprietary .run installer doesn’t find DKMS installed on your system (dpkg -l| grep dkms), it will probably compile just standalone kernel modules for each component of their drivers—meaning you’ll have to rebuild them manually at every major kernel update. And if you have Secure Boot enabled on your system, you’ll also need to sign them all manually.

Summarizing: If you don’t fully understand these instructions and the steps involved, then installing NVIDIA drivers this way might not be for you. You can, of course, experiment (snapshotting tools are great for these kinds of experiments).

I won’t provide a guide on how to do it, nor I will install NVIDIA drivers in this NVIDIA Recommended way on my Debian. I prefer to manage my system "the Debian way," and installing drivers like this is not a Debian way at all. System's drivers are not just about getting them set up—it’s about maintaining them afterward. Installation might be straightforward, but maintenance is the real challenge, especially when it comes to system software and kernel updates & upgrades.

Besides, for my needs, I don’t need any bleeding-edge NVIDIA features that come with the latest versions of NVIDIA drivers.

Luckily, there is Debian way of installing these drivers, and in this article I will be following it.


➂ NVIDIA drivers installation: "Debian" way

The procedure for installing NVIDIA drivers is covered in detail in NvidiaGraphicsDrivers - Debian Wiki. I mentioned the "Debian way" of drivers installation, and actually it is a broad term related not only to drivers installation, and if you’re using a Debian distro, I recommend familiarizing yourself with this term. You can find many details here.

In the documentation, the section you need is "Debian 12 Bookworm" (I’m assuming you’re using this version of Debian, the latest one). The version of the NVIDIA drivers installed by following that guide will be 535.183.01. Yes, this version is slightly older than the "official" driver available on NVIDIA’s website, which I mentioned earlier. However, this is a trade-off: you sacrifice a bit in terms of the driver’s newness, but you gain system stability and ease of installation.

The "Debian way" of installing NVIDIA drivers is about installing them as a single package in a default way - using apt. However, as I mentioned, NVIDIA’s software is proprietary and very close-source, so Debian keeps this type of third-party software in a separate component of its package repositories.

If you’re unfamiliar with how Debian packages its software, apt for you is a sort of "black box", and the sources.list file seems completely incomprehensible, I highly recommend checking out these articles before proceeding: about Debian releases, about Debian software installation - repositories and repository components.

The package containing the NVIDIA drivers is located in the "non-free" component of Debian’s package repositories. The term "non-free" doesn’t mean you need to pay to use the packages found there; rather, it refers to the nature of the software, as it includes closed-source code that isn’t publicly accessible. By default, "non-free" component is excluded from the list of sources that apt uses to fetch and install packages onto your system.

STEP ➂.➀: Add the "non-free" component to the list of sources for apt:

$ sudo vim /etc/apt/sources.list
#add contrib and non-free components:
deb http://deb.debian.org/debian/ bookworm main contrib non-free non-free-firmware
#this step is important: you have to make apt aware of changes made to this file:
$ sudo apt update
Enter fullscreen mode Exit fullscreen mode

NB! If you have your kernel package linux-image-* installed not from Debian bookworm repo but from Debian backports repo, you will need to install NVIDIA drivers also from there! This is due to the various dependencies linked to kernel and its version of NVIDIA drivers package!

STEP ➂.➁: Check if your OS is booted with Secure Boot.

Rule of the thumb - if you use a Dual Boot with Windows 11, 99% is that Secure Boot is enabled!. To be sure, run sudo mokutil --sb-state. If you see this:

$ sudo mokutil --sb-state
SecureBoot enabled
Enter fullscreen mode Exit fullscreen mode

If you do not understand what the Secure Boot is about, you will need to study it. I wrote the detailed article about Secure Boot and Debian, specifically from the perspective of how it impacts kernel modules and NVIDIA drivers. As an alternative, you always can find all answers in Debian Documentation - SecureBoot - Debian Wiki.

NB! If you have Secure Boot enabled and proceed with the following steps, your installed NVIDIA drivers will never load until you have them signed. The NVIDIA drivers signing is out of the scope for this article!

If you don’t know how to sign kernel modules for UEFI, I strongly recommend reading the Debian documentation or the article I mentioned. Once you’ve learned how to handle Secure Boot and signed your modules, you can return here to continue with the installation steps. FYI, in this article, I am installing drivers on systems that has Secure Boot enabled.

STEP ➂.➂ You need to check if your system uses dracut.

Dracut is the low-level tool that is used to create an initial image used by the kernel for preloading the block device modules (such as IDE, SCSI or RAID) which are needed to access the root filesystem, mounting the root filesystem and booting into the real system (Source). This "job" can be done not only by dracut, but also by initramfs-tools. You can find out "who" does this job for your system with dpkg -l | grep -E 'dracut|initramfs-tools'. If you see in the output dracut, you have to:

  • Make a dracut configuration file /etc/dracut.conf.d/10-nvidia.conf (you can actually name it anything you like, as long as it ends in .conf) with the following contents:
install_items+=" /etc/modprobe.d/nvidia-blacklists-nouveau.conf /etc/modprobe.d/nvidia.conf /etc/modprobe.d/nvidia-options.conf "
Enter fullscreen mode Exit fullscreen mode
  • Note the spaces between quotes and characters.
  • The modprobe.d files referenced here will be added by the nvidia-driver package.

STEP ➂.➃ Install nvidia-driver package that will bring to your system NVIDIA drivers

$ sudo apt update
$ sudo apt install nvidia-driver firmware-misc-nonfree
# NB!!!If your linux-image-* package is from bookworm backports, you must install nvidia-driver package from this repo to avoid broken dependencies error!
# $ sudo apt install -t bookworm-backports nvidia-driver
Enter fullscreen mode Exit fullscreen mode

If you did not blacklist nouveau drivers before installation, at certain point during installation you will see a warning message in the terminal (likely on the blue background):

Conflicting nouveau kernel module loaded
The free nouveau kernel module is currently loaded and conflicts with the non-free nvidia kernel module
The easiest way to fix this is to reboot the machine once the installation has finished

So, you just need to press Enter to proceed, the solution is the reboot - once installation has finished, reboot your system (sudo reboot).

When you are booted again, run nvidia-smi command.
This is my output:

Image description

If you see something similar (and no errors), congratulations! You have successfully installed the NVIDIA drivers. For additional confirmation, you can list your PCI devices and the kernel modules in use (loaded drivers) by running lspci -k | grep -A 3 NVIDIA.


➃ How and when to update NVIDIA drivers

This section is not about NVIDIA driver VERSION updates, because even other Debian releases (Unstable, Testing) offer the SAME major NVIDIA driver version—535.x—just like Bookworm repo. So if you’re not planning to downgrade (which is another story entirely), I don’t really see any "debian source" for VERSION update.

However, I do want to discuss a different kind of NVIDIA driver update—not about the version, but about the kernel module update itself.

If this question still did not pop up in your mind, I will anticipate it: "Since NVIDIA drivers are kernel modules, what happens to them then when Debian kernel version updates?"

It can be quite common that when you start using Debian, one of the first things you do is install NVIDIA drivers. But eventually, if you’re using Debian Stable release, you might encounter the need for a more major kernel version—for example, in my case, it was for Wi-Fi USB adapter drivers. So you learn a bit about backports and update the kernel from there - not just small regular updates from Debian Stable repositories (like from 6.1.10 to 6.1.11), but literally jumping from kernel v6.1.x to v6.9.x or even v6.12.x. That’s a major jump, and there’s a good chance your NVIDIA driver won’t work properly. Why? Because of Linux headers.

As I mentioned, headers are really important for NVIDIA drivers to work on your system. They serve as an API or interface that the NVIDIA driver uses to communicate with the kernel. When you update the kernel with sudo apt install -t bookworm-backports linux-image-amd64 (to install the newest kernel version from backports), it will only install the kernel and not the headers! You have to install the headers manually, and they must match your kernel version exactly. So if you install linux-image-amd64 from backports, you also have to install the headers in the same way (linux-headers-amd64). If you use a more detailed command pointing to the exact version of linux-image* package (e.g. sudo apt install -t bookworm-backports linux-image-6.9.7+bpo-amd64), the headers should match it (e.g. sudo apt install -t bookworm-backports linux-headers-6.9.7+bpo-amd64)—they’re always paired.

Here’s the trick with NVIDIA driver updates: if you installed them the Debian way, they were built with DKMS. This nice tool will rebuild (read "update") your NVIDIA drivers, and the trigger for that is installing the linux headers. During the final steps of their installation, you’ll see in log that DKMS is rebuilding stuff (and not just NVIDIA drivers, but also other kernel modules-drivers you installed in a way that they were built with DKMS).

So, this is yet another reason why it’s better to install NVIDIA drivers in the Debian way, or at least make sure that whatever you install manually is built with DKMS and not just scrapped together with some script.

However, keep in mind, that a VERY major kernel update (for example, when kernel gets updated from version 6.x to 7.x) may require installing a newer NVIDIA driver, as changes to the kernel APIs may not be compatible with the existing driver version.

Heroku

This site is built on Heroku

Join the ranks of developers at Salesforce, Airbase, DEV, and more who deploy their mission critical applications on Heroku. Sign up today and launch your first app!

Get Started

Top comments (4)

Collapse
 
anilfd profile image
Anil

Thanks very much for this post and the one about Secure Boot. I have managed to install and load the Nvidia driver. I am on a fresh Debian 12 install on a laptop with integrated and Nvidia card. I

However, apparently I am now stuck in an X session instead of the
Wayland session I had before.

I have followed the additional instruction here
wiki.debian.org/NvidiaGraphicsDriv...
and have run the command:
echo "options nvidia-drm modeset=1" >> /etc/modprobe.d/nvidia-
options.conf

and now, cat /sys/module/nvidia_drm/parameters/modeset, outputs: Y

My laptop has both and integrated card and the Nvidia card. I have read
the instructions here:
wiki.debian.org/NVIDIA%20Optimus#P...

I don't really understand the second paragraph there, where it says
that it should just work out of the box but also recommends some
additional steps. Should I uninstall the xserver-xorg-video-intel
package as suggested there?

I have also tried the instructions regarding wayland in the Debian page. wiki.debian.org/NvidiaGraphicsDriv...
With no avail

Should I be getting an option to select Wayland instead of Xorg at
login? I'm not sure I had that option before.

I am only using my laptop's screen right now,

thank you very much,

Collapse
 
dev-charodeyka profile image
Anna • Edited

Hello!

Unfortunately, I do not use Wayland, however, I have some ideas about what can be the issue…

First, what are you using as DE? You use one of defaults ones like GNOME, KDE ecc or you use just window manager?

Next question, what is your Display Manager? If you use on of classics DE, it is shipped with a DE.. so actually Display Manager is the one that starts a graphical session for you, maybe you can check configs of it

I can confirm though, that nvidia-driver pulls also minimal x server - xserver-xorg-core package (at least in my case it spawned after installation of Nvidia drivers, which is fine by me, as I use it)

Are you comfortable with using console only? You can try to forse your system to enter on the run level without graphics session and start it manually… you will have to start wayland session, not X session…

“You may change the runlevel also at runtime. Use only levels 1-5. Use either init [runlevel] or teli bit [runlevel]. Latter is preferred.” Debian Wiki run levels

So, once on the run level in console, you can try starting wayland, but I do not know which compositor you use, it depends on DE

For example for kde plasma is startplasma-wayland (not sure, something like this)

So, if it all starts and working, than the issue is in display manager that starts xsession for some reason

If you want to purge x server, then you need to purge xserver-xorg-core, the purging of intel drivers with xserver-xorg-video-intel will not remove server.

NB! Before purging something, I recommend to install a snapshotting tool like time shift, and take a snapshot of your system to recover: dev.to/dev-charodeyka/using-timesh...

Here is the detailed article about how Xserver works and starts, it’s not relevant for your needs, but maybe you will just get some idea what to remove/purge/modify :

dev.to/dev-charodeyka/debian-12-is...

Collapse
 
anilfd profile image
Anil

Hello Anna,

thanks very much for your response, it does help me understand the relevant parts to this issue.
I managed to get a default Wayland session and the options in the GDM login manager by deactivating rules at /usr/lib/udev/rules.d/61-gdm.rules

As I mentioned here. lists.debian.org/debian-user/2025/...
I still have some doubts, but my system is working here nicely.

Thanks again,

Thread Thread
 
dev-charodeyka profile image
Anna

Happy to hear it! As soon as I find time, I will write about how to setup Wayland with NVIDIA drivers (I will focus on Hyprland). Thank you for sharing the link!

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

👋 Kindness is contagious

Engage with a sea of insights in this enlightening article, highly esteemed within the encouraging DEV Community. Programmers of every skill level are invited to participate and enrich our shared knowledge.

A simple "thank you" can uplift someone's spirits. Express your appreciation in the comments section!

On DEV, sharing knowledge smooths our journey and strengthens our community bonds. Found this useful? A brief thank you to the author can mean a lot.

Okay