.. _nvidia: NVIDIA\* Drivers ################ NVIDIA manufactures graphics processing units (GPU), also known as graphics cards. NVIDIA devices on Linux\* have two popular device driver options: the opensource drivers from the `nouveau project`_ or the proprietary drivers published by NVIDIA. The nouveau drivers are built into the |CL-ATTR| kernel and are loaded automatically at system boot if a compatible card is detected. These instructions show how to use the proprietary NVIDIA drivers, which require a manual installation. .. warning:: Software installed outside of :ref:`swupd ` is not updated with |CL| updates and must be updated and maintained manually. For example, the file :file:`/usr/lib/libGL.so` conflicts with the file provided by the mesa package in |CL| and the file NVIDIA provides. If a |CL| update overwrites these files, a reinstallation of the NVIDIA driver might be required. .. contents:: :local: :depth: 1 Prerequisites ************* * A |CL| system with a desktop installed * An NVIDIA device installed .. note:: NVIDIA Optimus Some systems come with a hybrid graphics configuration for a balanced power and performance profile. This configuration is commonly found on laptops. `NVIDIA Optimus* technology `_, is designed to allow switching seamlessly between a NVIDIA device and another graphics devices sharing the same display. Getting NVIDIA Optimus* on Linux working well with both graphics devices adds an additional level of complexity with platform specific steps and may require additional software. Installation for systems with NVIDIA Optimus* with both graphics devices operating is not covered by the scope of this documentation. As a simple workaround, some systems can disable one of the graphics devices or NVIDIA Optimus* in the system firmware. Installation ************ Install DKMS ============ The :ref:`Dynamic Kernel Module System (DKMS) ` allows the NVIDIA kernel modules to be automatically integrated when kernel updates occur in |CL|. Install the appropriate DKMS bundle using the instructions below: .. note:: The Long Term Support (LTS) kernel variant is more likely to remain compatible between updates with NVIDIA drivers. .. include:: /guides/kernel/kernel-modules-dkms.rst :start-after: kernel-modules-dkms-install-begin: :end-before: kernel-modules-dkms-install-end: Download the NVIDIA drivers =========================== #. Identify the NVIDIA GPU model that is installed. .. code-block:: bash sudo lshw -C display #. Go to the `NVIDIA Driver Downloads website`_ . Search for and download the appropriate driver based on the NVIDIA GPU model you have with *Linux 64-bit* selected as the Operating System. .. code-block:: bash wget https://download.nvidia.com/XFree86/Linux-x86_64//NVIDIA-Linux-x86_64-.run If you already know the appropriate driver version for your device, you can also obtain a download link directly from one of the links below: - https://www.nvidia.com/en-us/drivers/unix/ - https://download.nvidia.com/XFree86/Linux-x86_64/ Disable the nouveau driver ========================== The proprietary NVIDIA driver is incompatible with the nouveau driver and must be disabled before installation can continue. #. Disable the nouveau driver by creating a blacklist file under :file:`/etc/modprobe.d` and reboot. .. code-block:: bash sudo mkdir /etc/modprobe.d printf "blacklist nouveau \noptions nouveau modeset=0 \n" | sudo tee --append /etc/modprobe.d/disable-nouveau.conf #. Reboot the system and log back in. It is normal for the graphical environment not to start without the NVIDIA driver loaded. Configure alternative software paths ==================================== The NVIDIA installer is directed to install files under :file:`/opt/nvidia` as much as possible to keep its contents isolated from the rest of the |CL| system files under :file:`/usr`. The dynamic linker and X server must be configured to use the content under :file:`/opt/nvidia`. #. Configure the dynamic linker to look for and to cache shared libraries under :file:`/opt/nvidia/lib` and :file:`/opt/nvidia/lib32` in addition to the default paths. .. code-block:: bash echo "include /etc/ld.so.conf.d/*.conf" | sudo tee --append /etc/ld.so.conf sudo mkdir /etc/ld.so.conf.d printf "/opt/nvidia/lib \n/opt/nvidia/lib32 \n" | sudo tee --append /etc/ld.so.conf.d/nvidia.conf #. Reload the dynamic linker run-time bindings and library cache. .. code-block:: bash sudo ldconfig #. Create a Xorg configuration file to search for modules under :file:`/opt/nvidia` in addition to the default path. .. code-block:: bash sudo mkdir -p /etc/X11/xorg.conf.d/ sudo tee /etc/X11/xorg.conf.d/nvidia-files-opt.conf > /dev/null <<'EOF' Section "Files" ModulePath "/usr/lib64/xorg/modules" ModulePath "/opt/nvidia/lib64/xorg/modules" EndSection EOF Install the NVIDIA drivers ========================== #. A terminal not running on */dev/tty1* is useful to view uninterrupted installation progress. Switch to a secondary virtual terminal by pushing :command:`CTRL + ALT + F2` or remotely login over SSH. #. Navigate to the directory where the NVIDIA installer was downloaded. In this example, it was saved in the :file:`Downloads` folder. .. code-block:: bash cd ~/Downloads/ #. Make the :file:`NVIDIA-Linux-x86_64-.run` file executable. .. code-block:: bash chmod +x NVIDIA-Linux-x86_64-.run #. Run the installer with the advanced options below. .. code-block:: bash sudo ./NVIDIA-Linux-x86_64-.run \ --utility-prefix=/opt/nvidia \ --opengl-prefix=/opt/nvidia \ --compat32-prefix=/opt/nvidia \ --compat32-libdir=lib32 \ --x-prefix=/opt/nvidia \ --x-module-path=/opt/nvidia/lib64/xorg/modules \ --x-library-path=/opt/nvidia/lib64 \ --x-sysconfig-path=/etc/X11/xorg.conf.d \ --documentation-prefix=/opt/nvidia \ --application-profile-path=/etc/nvidia \ --no-precompiled-interface \ --no-nvidia-modprobe \ --no-distro-scripts \ --force-libglx-indirect \ --glvnd-egl-config-path=/etc/glvnd/egl_vendor.d \ --egl-external-platform-config-path=/etc/egl/egl_external_platform.d \ --dkms \ --silent #. The graphical interface may automatically start after the NVIDIA driver is loaded. Return to the working terminal and log back in if necessary. #. Confirm that the NVIDIA kernel modules are loaded. .. code-block:: bash lsmod | grep ^nvidia #. Run a |CL| system verification to restore files that the NVIDIA installer likely deleted. .. code-block:: bash sudo swupd repair --quick --bundles=lib-opengl .. warning:: Although a limited version of :command:`swupd repair` is run above, other uses of the :command:`swupd repair` command should be avoided with the proprietary NVIDIA drivers installed. The NVIDIA software places some files under the :file:`/usr` subdirectory that are not managed by |CL| and conflict with the |CL| stateless design. #. Optional: Create a link for the nvidia-settings desktop entry to :file:`~/.local/share` so that it appears in the launcher for easy access. .. code-block:: bash ln -sv /opt/nvidia/share/applications/nvidia-settings.desktop $HOME/.local/share Updating ******** The proprietary NVIDIA drivers are installed manually outside of :ref:`swupd ` and must be updated manually when needed. Updating the NVIDIA drivers follows the same steps as initial installation, however the desktop environment must first be stopped so that the drivers are not in use. #. Follow the steps in the `Download the NVIDIA drivers`_ section to get the latest NVIDIA drivers. #. Temporarily set the default boot target to the *multi-user*, which is a non-graphical runtime. .. code-block:: bash sudo systemctl set-default multi-user.target #. Reboot the system and log back in. It is normal for the graphical environment not to start. #. Follow the steps in the `Install the NVIDIA Drivers`_ section to update the NVIDIA drivers. This installation will overwrite the previous NVIDIA drivers and files. #. Set the default boot target back to the *graphical* target. .. code-block:: bash sudo systemctl set-default graphical.target #. Reboot the system and log back in. #. Trigger a flatpak update that will download the runtime corresponding with the new NVIDIA drivers for the flatpak apps that require it. .. code-block:: bash flatpak update Uninstallation ************** The NVIDIA drivers and associated software can be uninstalled and nouveau driver restored with the instructions in this section. #. Remove the :file:`modprobe.d` file that prevents nouveau from loading. .. code-block:: bash sudo rm /etc/modprobe.d/disable-nouveau.conf #. Remove the :file:`xorg.conf.d` file that adds a search path for X modules. .. code:: bash sudo rm /etc/X11/xorg.conf.d/nvidia-files-opt.conf #. Remove the nvidia-settings desktop entry file if it was linked to :file:`~/.local/share`. .. code:: bash unlink -v $HOME/.local/share/nvidia-settings.desktop #. Run the :command:`nvidia-uninstall` command. .. code:: bash sudo /opt/nvidia/bin/nvidia-uninstall #. Follow the prompts on the screen and reboot the system. Troubleshooting *************** * The NVIDIA driver places installer and uninstaller logs under :file:`/var/log/nvidia-install` and :file:`/var/log/nvidia-uninstall`. * :file:`NVIDIA-Linux-x86_64-.run --advanced-options` shows many parameters to control installation behavior. * :file:`NVIDIA-Linux-x86_64-.run --extract-only` extracts installation files into a directory named :file:`NVIDIA-Linux-x86_64-`. Brightness control ================== If you can't control the screen brightness with the NVIDIA driver installed, try one of the solutions below: - Add a kernel parameter *acpi_osi=* which disables the ACPI Operating System Identification function. Some system firmware may manipulate brightness control keys based on the reported operating system. Disabling the identification mechanism can cause the system firmware to expose brightness controls that are recognizable in Linux. .. code:: bash sudo mkdir -p /etc/kernel/cmdline.d echo "acpi_osi=" | sudo tee /etc/kernel/cmdline.d/acpi-backlight.conf sudo clr-boot-manager update - Add a kernel parameter for the nvidia driver: *NVreg_EnableBacklightHandler=1*. This handler overrides the ACPI-based one provided by the video.ko kernel module. This option is available with NVIDIA driver version 387.22 and above. .. code:: bash sudo mkdir -p /etc/kernel/cmdline.d echo "nvidia.NVreg_EnableBacklightHandler=1" | sudo tee /etc/kernel/cmdline.d/nvidia-backlight.conf sudo clr-boot-manager update - Add the *EnableBrightnessControl=1* options to the *Device* section of your xorg config. Below is an example: .. code:: bash sudo mkdir -p /etc/X11/xorg.conf.d/ sudo tee /etc/X11/xorg.conf.d/nvidia-brightness.conf > /dev/null <<'EOF' Section "Device" Identifier "Device0" Driver "nvidia" Option "RegistryDwords" "EnableBrightnessControl=1" EndSection EOF Additional resources ==================== * `Why aren't the NVIDIA Linux drivers open source? `_ * `Where can I get support for NVIDIA Linux drivers? `_ * `NVIDIA Accelerated Linux Graphics Driver Installation Guides `_ .. _`nouveau project`: https://nouveau.freedesktop.org/wiki/ .. _`NVIDIA Driver Downloads website`: https://www.nvidia.com/download/index.aspx