5395
Comment: Added note for 64-bit users of Fedora 11 and later.
|
14478
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
## page was renamed from Howto/nVidia | |
Line 3: | Line 4: |
This howto will help you install the correct nVidia driver for your graphics card as well as troubleshoot common driver problems. | This howto will help you install the correct NVIDIA driver on Fedora for your graphics card as well as troubleshoot common driver problems. The prerequisite is to have followed the [[Configuration]] page to have at least the RPM Fusion nonfree section available. |
Line 7: | Line 11: |
nVidia has several driver series, each of which has different hardware support. To determine which driver you need to install, you'll first need to find your graphics card model. | NVIDIA has several driver series, each of which has different hardware support. To determine which driver you need to install, you'll first need to find your graphics card model. |
Line 11: | Line 15: |
/sbin/lspci | grep VGA }}} == Fedora version notes == <<Anchor(fedora_version_notes)>> === Fedora 12 === Note: nVidia currently doesn't support cards older than Geforce6 on the xorg-x11-server used by Fedora 12. Please verify that the nouveau driver will fit your needs while upgrading. In order to keep [[#nouveau|compatibility with nouveau]], you either need to recreate the initrd manually after the driver has been installed, or add a command line option to the kernel. To recreate the initrd: {{{ su - mv /boot/initramfs-$(uname -r).img /boot/initramfs-$(uname -r)-nouveau.img dracut /boot/initramfs-$(uname -r).img $(uname -r) }}} To use the default initrd, but disable the nouveau driver, edit /etc/grub.conf and add the following to the end of the line(s) starting with 'kernel': {{{ rdblacklist=nouveau }}} Before using the driver, you need to lower your system protection so SElinux doesn't prevent the driver to load. {{{ setsebool -P allow_execstack on }}} === Fedora 11 === In order to keep [[#nouveau|compatibility with nouveau]], you need to recreate the initrd manually after the driver has been installed. {{{ su - mv /boot/initrd-$(uname -r).img /boot/initrd-$(uname -r)-nouveau.img mkinitrd /boot/initrd-$(uname -r).img $(uname -r) reboot }}} === Fedora 10 === Unfortunately, nVidia has not released a driver for card older than Geforce 2 that is compatible with Fedora 10 and beyond. |
/sbin/lspci | grep -e VGA }}} You can also check the [[https://download.nvidia.com/XFree86/Linux-x86_64/495.44/README/supportedchips.html|supported chips]] section and see which series is recommended for you card, then install the appropriate driver series. Please remember that you need additional steps for optimus. You are probably in the [[Howto/Optimus|Optimus]] case if your NVIDIA card is found with the next command: {{{ /sbin/lspci | grep -e 3D }}} |
Line 52: | Line 28: |
Please remember that once the driver is installed, it will configure your xorg.conf automatically and changes will take effect after a full reboot on the newest kernel. Using nvidia-xconfig or nvidia-settings before the reboot will garanty you problems. === GeForce 6 and newer === {{{ yum install kmod-nvidia-PAE (or kmod-nvidia if not using kernel-PAE) }}} === GeForce 5 (FX series) === {{{ yum install kmod-nvidia-173xx }}} === GeForce 2 through GeForce 4 === {{{ yum install kmod-nvidia-96xx }}} === Older === For Fedora 9 and older, you can do: {{{ yum install kmod-nvidia-legacy }}} |
Please remember that once the driver is installed, there is no need to configure xorg.conf by default unless you are using an Optimus device. Changes will take effect after a '''''full reboot''''' on the newest kernel. /!\ The '''''Secure Boot''''' will have to be disabled unless you managed to sign the nvidia kmod. You will have to enter the BIOS/EFI to disable it. === Current GeForce/Quadro/Tesla === Supported on current stable Xorg server release. This driver is suitable for any GPU found in 2014 and later. /!\ The 495 driver is available by default on Fedora 35+ and later and has dropped support for some older Kepler GPU. {{{ sudo dnf update -y # and reboot if you are not on the latest kernel sudo dnf install akmod-nvidia # rhel/centos users can use kmod-nvidia instead sudo dnf install xorg-x11-drv-nvidia-cuda #optional for cuda/nvdec/nvenc support }}} /!\ Please remember to wait after the RPM transaction ends, until the kmod get built. This can take up to 5 minutes on some systems. Once the module is built, "modinfo -F version nvidia" should outputs the version of the driver such as 440.64 and not modinfo: ERROR: Module nvidia not found. === Legacy GeForce 600/700 === Supported on current stable Xorg server release. /!\ This serie is the current default for fedora releases up to Fedora 34. Maintainer is awaited to maintain a 470xx dedicated series for Fedora 35 and later. This driver is suitable for any NVIDIA Kepler GPU found between 2012 and 2014 {{{ # Placeholder for 470xx serie }}} /!\ Please remember to wait after the RPM transaction ends, until the kmod get built. This can take up to 5 minutes on some systems. === Legacy GeForce 400/500 === Supported on current stable Xorg server release. This driver is suitable for any NVIDIA Fermi GPU found between 2010 and 2012 {{{ dnf update -y sudo dnf install xorg-x11-drv-nvidia-390xx akmod-nvidia-390xx sudo dnf install xorg-x11-drv-nvidia-390xx-cuda #optional for cuda up to 9.2 support }}} /!\ Please remember to wait after the RPM transaction ends, until the kmod get built. This can take up to 5 minutes on some systems. === Legacy GeForce 8/9/200/300 === Supported on current stable Xorg server release. EOL by NVIDIA at the end of 2019. Still available on "best effort basis" (newer kernel may break, will be discontinued at anytime if not actively maintained) {{{ sudo dnf update -y sudo dnf install xorg-x11-drv-nvidia-340xx akmod-nvidia-340xx sudo dnf install xorg-x11-drv-nvidia-340xx-cuda #optional for cuda up to 6.5 support }}} /!\ Please remember to wait until the kmod get built each time a new kernel rise up. This can take up to 5 minutes on some systems. /!\ Workaround for keeping 340xx driver on newer f31+. /!\ This driver doesn't support "pre-optimus" devices so if you have a mean to only use the NVIDIA device in bios, please turn it on (or rely on Intel/Nouveau if you want to keep both). {{{ sudo dnf copr enable kwizart/kernel-longterm-5.10 sudo dnf install akmods gcc kernel-longterm kernel-longterm-devel sudo dnf install xorg-x11-drv-nvidia-340xx akmod-nvidia-340xx }}} === Legacy GeForce 6/7 === Supported up to Fedora 27 - EOL, no more nvidia updates === Legacy GeForce 5 (FX series) === Supported up to Fedora 20 - EOL, no more nvidia updates === Legacy GeForce 2 through GeForce 4 === Supported up to Fedora 14 - EOL, no more nvidia updates |
Line 75: | Line 98: |
=== Optimus === With Fedora 25 and later, Optimus devices are supported automatically by default. Please see the dedicated [[Howto/Optimus|Optimus Howto]]. === Silverblue === Silverblue is supported with the NVIDIA driver using akmod-nvidia starting with f30. (only the current NVIDIA driver is tested). Please follow the [[Configuration|Configuration]] page first. {{{ sudo rpm-ostree install akmod-nvidia xorg-x11-drv-nvidia sudo rpm-ostree install akmod-nvidia xorg-x11-drv-nvidia-cuda #optional if using nvidia-smi or cuda sudo rpm-ostree kargs --append=rd.driver.blacklist=nouveau --append=modprobe.blacklist=nouveau --append=nvidia-drm.modeset=1 # this might not be needed at some point when silverblue will support the standard way to specify this. }}} === Switching between nouveau/nvidia === With recent drivers as packaged with RPM Fusion, it is possible to switch easily between nouveau and nvidia while keeping the nvidia driver installed. When you are about to select the kernel at the grub menu step. You can edit the kernel entry, find the linux boot command line and manually remove the following options "rd.driver.blacklist=nouveau modprobe.blacklist=nouveau nvidia-drm.modeset=1". This will allow you to boot using the nouveau driver instead of the nvidia binary driver. At this time, there is no way to make the switch at runtime. === CUDA === The driver support CUDA when installing the xorg-x11-drv-nvidia-cuda subpackage. Please have a look on the dedicated [[Howto/CUDA|CUDA Howto]] {{{ sudo dnf install xorg-x11-drv-nvidia-cuda }}} === KMS === KMS stands for "Kernel Mode Setting" which is the opposite of "Userland Mode Setting". This feature allows to set the screen resolution on the kernel side once (at boot), instead of after login from the display manager. This feature has early support in the main NVIDIA driver, but is not enabled by default yet as it may crash. To enable, use: {{{ sudo grubby --update-kernel=ALL --args='nvidia-drm.modeset=1' }}} Please have a look at the Wayland section if using it (specially for gnome users). === Graphic console === For long time, NVIDIA driver team have advertised "against" using a graphical console (vga parameters or else) over the default text console on non-EFI mode (bios). That's because some drivers bad interaction with the vesafb driver. This problem is now solved as it seems. (See also https://forums.developer.nvidia.com/t/unusable-linux-text-console-with-nvidia-drm-modeset-1-or-if-nvidia-persistenced-is-loaded). If using a legacy bios, you can improve the vesafb driver using this parameter: (along the appropriate vga=id, use vga=ask for the first time). {{{ sudo grubby --update-kernel=ALL --args='video=vesafb:mtrr:3' }}} === Suspend === NVIDIA has provided some experimental scripts to enable clean resume on suspend to RAM or suspend to disk (hibernate) that might be specially needed in some environment. Theses scripts will prevent artefacts on resume by moving the full content of the graphic memory into either host RAM (or disk). Packaging is currently (as of 2021-08-23) in in-between state and will be improved as discussed in https://bugzilla.rpmfusion.org/show_bug.cgi?id=6066 {{{ sudo dnf install xorg-x11-drv-nvidia-power sudo systemctl enable nvidia-{suspend,resume,hibernate} # Optional: tweak "nvidia options NVreg_TemporaryFilePath=/var/tmp" from /etc/modprobe.d/nvidia.conf as needed if you have issue with /tmp as tmpfs with nvidia suspend ) }}} === Vulkan === The main package support Vulkan, but you need to install the vulkan libraries if requested. {{{ sudo dnf install vulkan }}} === Wayland === Gnome with Wayland and NVIDIA doesn't work by default at this point. With Fedora 29, mutter has support for NVIDIA eglstream but it's disabled at runtime by a udev rules. You need to comment the "DRIVER==nvidia" line in /usr/lib/udev/rules.d/61-gdm.rules. You will also have to comment "WaylandEnable=false" in /etc/gdm/custom.conf === NVENC/NVDEC === RPM Fusion support ffmpeg compiled with NVENC/NVDEC with Fedora 25 and later. You need to have a recent NVIDIA card (see the [[https://developer.nvidia.com/ffmpeg|support matrix]]), and install the cuda sub-package. {{{ sudo dnf install xorg-x11-drv-nvidia-cuda-libs }}} Please have a look on the ffmpeg [[https://trac.ffmpeg.org/wiki/HWAccelIntro#NVENC|HWAccel introduction]] to the feature === Latest/Beta driver === You can install the latest drivers from Rawhide using the following command: {{{ sudo dnf install "kernel-devel-uname-r >= $(uname -r)" sudo dnf update -y sudo dnf copr enable kwizart/nvidia-driver-rawhide -y sudo dnf install rpmfusion-nonfree-release-rawhide -y sudo dnf --enablerepo=rpmfusion-nonfree-rawhide install akmod-nvidia xorg-x11-drv-nvidia xorg-x11-drv-nvidia-cuda --nogpgcheck }}} Or if you want to grab it from the latest fedora stable release: {{{ sudo dnf install "kernel-devel-uname-r == $(uname -r)" sudo dnf update -y sudo dnf --releasever=30 install akmod-nvidia xorg-x11-drv-nvidia --nogpgcheck }}} === nvidia-xconfig === This tool is only meant to be used as a sample to create a xorg.conf files. But don't use this directly as the generated xorg.conf is known to broke with many default Fedora/RHEL Xorg server options. Instead, you should probably start with : {{{ sudo cp /usr/share/X11/xorg.conf.d/nvidia.conf /etc/X11/xorg.conf.d/nvidia.conf }}} |
|
Line 76: | Line 200: |
If you wish to have 3D acceleration in 32bit packages such as Wine, be sure to install the xorg-x11-drv-nvidia-libs.i386 package for your driver variant. For example, if you installed kmod-nvidia then you will require xorg-x11-drv-nvidia-libs.i386, but if you install kmod-nvidia-'''96xx''', you will need xorg-x11-drv-nvidia-'''96xx'''-libs.i386. If using Fedora 11 you will need to use xorg-x11-drv-nvidia-libs.i586, with Fedora 12 use xorg-x11-drv-nvidia-libs.i686. | If you wish to have 3D acceleration in 32bit packages such as Wine, be sure to install the appropriate 32bit version of the xorg-x11-drv-nvidia-libs package for your driver variant. For example, if you installed kmod-nvidia then you will require xorg-x11-drv-nvidia-libs.i686. With Current Fedora (not EL), this is handled automatically by RPM (Boolean dependencies). |
Line 78: | Line 203: |
If you are on a 32bit (i686) system and have the PAE kernel installed to access more RAM, please append '''-PAE''' to all the "kmod" pacakges above. For example, '''kmod-nvidia-PAE''' or '''kmod-nvidia-96xx-PAE'''. This will install the kernel module for the PAE kernel instead of the regular 32bit kernel. Please note that this step is not required for any 64bit (x64_64) users. | If you are on a 32bit (i686) system and have the kernel-PAE installed to access more RAM, please install kernel-PAE-devel. Please note that this step is not required for any 64bit (x64_64) users. === VDPAU/VAAPI === In order to enable video acceleration support for your player and if your NVIDIA card is recent enough (Geforce 8 and later is needed). You can install theses packages: {{{ # sudo dnf install vdpauinfo libva-vdpau-driver libva-utils }}} With the native vdpau backend from a NVIDIA card, the output is similar to this: {{{ $ vdpauinfo display: :0.0 screen: 0 API version: 1 Information string: NVIDIA VDPAU Driver Shared Library 375.66 Mon May 1 14:32:38 PDT 2017 ... }}} Here is an example of an accurate output of vainfo, when the bridge to the VAAPI is correctly installed. {{{ $ vainfo libva info: VA-API version 0.40.0 libva info: va_getDriverName() returns 0 libva info: Trying to open /usr/lib64/dri/nvidia_drv_video.so libva info: Found init function __vaDriverInit_0_40 libva info: va_openDriver() returns 0 vainfo: VA-API version: 0.40 (libva ) vainfo: Driver version: Splitted-Desktop Systems VDPAU backend for VA-API - 0.7.4 vainfo: Supported profile and entrypoints ... }}} |
Line 81: | Line 235: |
An [[Packaging/KernelModules/Akmods|akmod]] is a type of package similar to dkms. As you start your computer, the akmod system will check if there are any missing kmods and if so, rebuild a new kmod for you. Akmods have more overhead than regular kmod packages as they require a few development tools such as gcc and automake in order to be able to build new kmods locally. If you think you'd like to try akmods, simply replace '''kmod''' with '''akmod''' in the instructions above and run them again. For example, kmod-nvidia-96xx becomes '''a'''kmod-nvidia-96xx. Akmods are fully compatible with regular kmods, so you can switch between the two or even use both at once without any problems. | An [[Packaging/KernelModules/Akmods|akmod]] is a type of package similar to dkms. As you start your computer, the akmod system will check if there are any missing kmods and if so, rebuild a new kmod for you. Akmods have more overhead than regular kmod packages as they require a few development tools such as gcc and automake in order to be able to build new kmods locally. |
Line 85: | Line 239: |
As nouveau is enabled by default starting with Fedora 11, you may experience problem which is caused by the nouveau kernel module being present in the initrd image. To avoid such problem, after you have installed the right series of the nvidia driver for your hardware and execute the [[#fedora_version_notes|commands specifics]] for a given Fedora version: After the reboot, this command should not output anything: |
As nouveau is enabled by default starting with Fedora 11, you may experience problem which is caused by the nouveau kernel module being present in the initrd image. Once the driver is installed and after the reboot, this command should not output anything: |
Line 92: | Line 245: |
== Troubleshooting == If you're experiencing problems with the drivers (in particular, lack of 3D after using nvidia-xconfig or nvidia-settings), try executing these commands: {{{ nvidia-config-display disable nvidia-config-display enable }}} This will re-configure xorg.conf for use with the RPM Fusion drivers. |
=== Secure Boot === Secure Boot currently blocks the kernel from loading the NVIDIA driver. It must be disabled before booting the OS. === Rawhide === Rawhide kernels are built with debug enabled GPL-only symbols which kernel is incompatible with the NVIDIA binary-only driver. You need to use the [[http://fedoraproject.org/wiki/RawhideKernelNodebug|Rawhide nodebug repository]]. {{{ sudo dnf config-manager --add-repo=http://dl.fedoraproject.org/pub/alt/rawhide-kernel-nodebug/fedora-rawhide-kernel-nodebug.repo sudo dnf update }}} Please remind that Xorg server version is also to take into consideration. In the case of incompatibilities with the xorg-server, you might need to downgrade to the previous fedora release: {{{ sudo dnf downgrade xorg-x11-server\* --releasever=29 --allowerasing sudo echo "exclude=xorg-x11*" >> /etc/dnf/dnf.conf }}} == Uninstall the NVIDIA driver == {{{ dnf remove xorg-x11-drv-nvidia\* }}} == Recover from NVIDIA installer == The NVIDIA binary driver installer overwrite some configuration and libraries. If you want to recover to a clean state, either to use nouveau or the packaged driver, use: {{{ rm -f /usr/lib{,64}/libGL.so.* /usr/lib{,64}/libEGL.so.* rm -f /usr/lib{,64}/xorg/modules/extensions/libglx.so dnf reinstall xorg-x11-server-Xorg mesa-libGL mesa-libEGL libglvnd\* mv /etc/X11/xorg.conf /etc/X11/xorg.conf.saved }}} |
Line 103: | Line 281: |
If you still cannot make the driver to work, you can either report a problem to nVidia or to rpmfusion packager team. Please read: [[http://www.nvnews.net/vbulletin/showthread.php?t=46678|How to report a problem about the nVidia proprietary driver]] |
If you still cannot make the driver to work, you can either report a problem to NVIDIA or to RPM Fusion packager team. Please read: [[https://devtalk.nvidia.com/default/topic/522835/linux/if-you-have-a-problem-please-read-this-first/|If you have a problem, PLEASE read this first]] Basically, you need to generate an archive and attach it to bugzilla or any paste service. {{{ sudo nvidia-bug-report.sh zcat nvidia-bug-report.log.gz | fpaste }}} |
Contents
About this Howto
This howto will help you install the correct NVIDIA driver on Fedora for your graphics card as well as troubleshoot common driver problems.
The prerequisite is to have followed the Configuration page to have at least the RPM Fusion nonfree section available.
Determining your card model
NVIDIA has several driver series, each of which has different hardware support. To determine which driver you need to install, you'll first need to find your graphics card model.
If you don't know it, open a Terminal (Applications > System Tools > Terminal) and type:
/sbin/lspci | grep -e VGA
You can also check the supported chips section and see which series is recommended for you card, then install the appropriate driver series. Please remember that you need additional steps for optimus.
You are probably in the Optimus case if your NVIDIA card is found with the next command:
/sbin/lspci | grep -e 3D
Installing the drivers
Please remember that once the driver is installed, there is no need to configure xorg.conf by default unless you are using an Optimus device. Changes will take effect after a full reboot on the newest kernel.
The Secure Boot will have to be disabled unless you managed to sign the nvidia kmod. You will have to enter the BIOS/EFI to disable it.
Current GeForce/Quadro/Tesla
Supported on current stable Xorg server release.
This driver is suitable for any GPU found in 2014 and later. The 495 driver is available by default on Fedora 35+ and later and has dropped support for some older Kepler GPU.
sudo dnf update -y # and reboot if you are not on the latest kernel sudo dnf install akmod-nvidia # rhel/centos users can use kmod-nvidia instead sudo dnf install xorg-x11-drv-nvidia-cuda #optional for cuda/nvdec/nvenc support
Please remember to wait after the RPM transaction ends, until the kmod get built. This can take up to 5 minutes on some systems.
Once the module is built, "modinfo -F version nvidia" should outputs the version of the driver such as 440.64 and not modinfo: ERROR: Module nvidia not found.
Legacy GeForce 600/700
Supported on current stable Xorg server release. This serie is the current default for fedora releases up to Fedora 34. Maintainer is awaited to maintain a 470xx dedicated series for Fedora 35 and later.
This driver is suitable for any NVIDIA Kepler GPU found between 2012 and 2014
# Placeholder for 470xx serie
Please remember to wait after the RPM transaction ends, until the kmod get built. This can take up to 5 minutes on some systems.
Legacy GeForce 400/500
Supported on current stable Xorg server release.
This driver is suitable for any NVIDIA Fermi GPU found between 2010 and 2012
dnf update -y sudo dnf install xorg-x11-drv-nvidia-390xx akmod-nvidia-390xx sudo dnf install xorg-x11-drv-nvidia-390xx-cuda #optional for cuda up to 9.2 support
Please remember to wait after the RPM transaction ends, until the kmod get built. This can take up to 5 minutes on some systems.
Legacy GeForce 8/9/200/300
Supported on current stable Xorg server release. EOL by NVIDIA at the end of 2019. Still available on "best effort basis" (newer kernel may break, will be discontinued at anytime if not actively maintained)
sudo dnf update -y sudo dnf install xorg-x11-drv-nvidia-340xx akmod-nvidia-340xx sudo dnf install xorg-x11-drv-nvidia-340xx-cuda #optional for cuda up to 6.5 support
Please remember to wait until the kmod get built each time a new kernel rise up. This can take up to 5 minutes on some systems.
Workaround for keeping 340xx driver on newer f31+.
This driver doesn't support "pre-optimus" devices so if you have a mean to only use the NVIDIA device in bios, please turn it on (or rely on Intel/Nouveau if you want to keep both).
sudo dnf copr enable kwizart/kernel-longterm-5.10 sudo dnf install akmods gcc kernel-longterm kernel-longterm-devel sudo dnf install xorg-x11-drv-nvidia-340xx akmod-nvidia-340xx
Legacy GeForce 6/7
Supported up to Fedora 27 - EOL, no more nvidia updates
Legacy GeForce 5 (FX series)
Supported up to Fedora 20 - EOL, no more nvidia updates
Legacy GeForce 2 through GeForce 4
Supported up to Fedora 14 - EOL, no more nvidia updates
Special notes
Optimus
With Fedora 25 and later, Optimus devices are supported automatically by default. Please see the dedicated Optimus Howto.
Silverblue
Silverblue is supported with the NVIDIA driver using akmod-nvidia starting with f30. (only the current NVIDIA driver is tested). Please follow the Configuration page first.
sudo rpm-ostree install akmod-nvidia xorg-x11-drv-nvidia sudo rpm-ostree install akmod-nvidia xorg-x11-drv-nvidia-cuda #optional if using nvidia-smi or cuda sudo rpm-ostree kargs --append=rd.driver.blacklist=nouveau --append=modprobe.blacklist=nouveau --append=nvidia-drm.modeset=1 # this might not be needed at some point when silverblue will support the standard way to specify this.
Switching between nouveau/nvidia
With recent drivers as packaged with RPM Fusion, it is possible to switch easily between nouveau and nvidia while keeping the nvidia driver installed. When you are about to select the kernel at the grub menu step. You can edit the kernel entry, find the linux boot command line and manually remove the following options "rd.driver.blacklist=nouveau modprobe.blacklist=nouveau nvidia-drm.modeset=1". This will allow you to boot using the nouveau driver instead of the nvidia binary driver. At this time, there is no way to make the switch at runtime.
CUDA
The driver support CUDA when installing the xorg-x11-drv-nvidia-cuda subpackage. Please have a look on the dedicated CUDA Howto
sudo dnf install xorg-x11-drv-nvidia-cuda
KMS
KMS stands for "Kernel Mode Setting" which is the opposite of "Userland Mode Setting". This feature allows to set the screen resolution on the kernel side once (at boot), instead of after login from the display manager. This feature has early support in the main NVIDIA driver, but is not enabled by default yet as it may crash. To enable, use:
sudo grubby --update-kernel=ALL --args='nvidia-drm.modeset=1'
Please have a look at the Wayland section if using it (specially for gnome users).
Graphic console
For long time, NVIDIA driver team have advertised "against" using a graphical console (vga parameters or else) over the default text console on non-EFI mode (bios). That's because some drivers bad interaction with the vesafb driver. This problem is now solved as it seems. (See also https://forums.developer.nvidia.com/t/unusable-linux-text-console-with-nvidia-drm-modeset-1-or-if-nvidia-persistenced-is-loaded).
If using a legacy bios, you can improve the vesafb driver using this parameter: (along the appropriate vga=id, use vga=ask for the first time).
sudo grubby --update-kernel=ALL --args='video=vesafb:mtrr:3'
Suspend
NVIDIA has provided some experimental scripts to enable clean resume on suspend to RAM or suspend to disk (hibernate) that might be specially needed in some environment. Theses scripts will prevent artefacts on resume by moving the full content of the graphic memory into either host RAM (or disk). Packaging is currently (as of 2021-08-23) in in-between state and will be improved as discussed in https://bugzilla.rpmfusion.org/show_bug.cgi?id=6066
sudo dnf install xorg-x11-drv-nvidia-power sudo systemctl enable nvidia-{suspend,resume,hibernate} # Optional: tweak "nvidia options NVreg_TemporaryFilePath=/var/tmp" from /etc/modprobe.d/nvidia.conf as needed if you have issue with /tmp as tmpfs with nvidia suspend )
Vulkan
The main package support Vulkan, but you need to install the vulkan libraries if requested.
sudo dnf install vulkan
Wayland
Gnome with Wayland and NVIDIA doesn't work by default at this point.
With Fedora 29, mutter has support for NVIDIA eglstream but it's disabled at runtime by a udev rules. You need to comment the "DRIVER==nvidia" line in /usr/lib/udev/rules.d/61-gdm.rules. You will also have to comment "WaylandEnable=false" in /etc/gdm/custom.conf
NVENC/NVDEC
RPM Fusion support ffmpeg compiled with NVENC/NVDEC with Fedora 25 and later. You need to have a recent NVIDIA card (see the support matrix), and install the cuda sub-package.
sudo dnf install xorg-x11-drv-nvidia-cuda-libs
Please have a look on the ffmpeg HWAccel introduction to the feature
Latest/Beta driver
You can install the latest drivers from Rawhide using the following command:
sudo dnf install "kernel-devel-uname-r >= $(uname -r)" sudo dnf update -y sudo dnf copr enable kwizart/nvidia-driver-rawhide -y sudo dnf install rpmfusion-nonfree-release-rawhide -y sudo dnf --enablerepo=rpmfusion-nonfree-rawhide install akmod-nvidia xorg-x11-drv-nvidia xorg-x11-drv-nvidia-cuda --nogpgcheck
Or if you want to grab it from the latest fedora stable release:
sudo dnf install "kernel-devel-uname-r == $(uname -r)" sudo dnf update -y sudo dnf --releasever=30 install akmod-nvidia xorg-x11-drv-nvidia --nogpgcheck
nvidia-xconfig
This tool is only meant to be used as a sample to create a xorg.conf files. But don't use this directly as the generated xorg.conf is known to broke with many default Fedora/RHEL Xorg server options. Instead, you should probably start with :
sudo cp /usr/share/X11/xorg.conf.d/nvidia.conf /etc/X11/xorg.conf.d/nvidia.conf
x86_64 (64bit) users
If you wish to have 3D acceleration in 32bit packages such as Wine, be sure to install the appropriate 32bit version of the xorg-x11-drv-nvidia-libs package for your driver variant. For example, if you installed kmod-nvidia then you will require xorg-x11-drv-nvidia-libs.i686. With Current Fedora (not EL), this is handled automatically by RPM (Boolean dependencies).
PAE (Physical Address Extension) kernel users
If you are on a 32bit (i686) system and have the kernel-PAE installed to access more RAM, please install kernel-PAE-devel. Please note that this step is not required for any 64bit (x64_64) users.
VDPAU/VAAPI
In order to enable video acceleration support for your player and if your NVIDIA card is recent enough (Geforce 8 and later is needed). You can install theses packages:
# sudo dnf install vdpauinfo libva-vdpau-driver libva-utils
With the native vdpau backend from a NVIDIA card, the output is similar to this:
$ vdpauinfo display: :0.0 screen: 0 API version: 1 Information string: NVIDIA VDPAU Driver Shared Library 375.66 Mon May 1 14:32:38 PDT 2017 ...
Here is an example of an accurate output of vainfo, when the bridge to the VAAPI is correctly installed.
$ vainfo libva info: VA-API version 0.40.0 libva info: va_getDriverName() returns 0 libva info: Trying to open /usr/lib64/dri/nvidia_drv_video.so libva info: Found init function __vaDriverInit_0_40 libva info: va_openDriver() returns 0 vainfo: VA-API version: 0.40 (libva ) vainfo: Driver version: Splitted-Desktop Systems VDPAU backend for VA-API - 0.7.4 vainfo: Supported profile and entrypoints ...
Akmods
An akmod is a type of package similar to dkms. As you start your computer, the akmod system will check if there are any missing kmods and if so, rebuild a new kmod for you. Akmods have more overhead than regular kmod packages as they require a few development tools such as gcc and automake in order to be able to build new kmods locally.
Nouveau compatibility
As nouveau is enabled by default starting with Fedora 11, you may experience problem which is caused by the nouveau kernel module being present in the initrd image. Once the driver is installed and after the reboot, this command should not output anything:
lsmod |grep nouveau
Secure Boot
Secure Boot currently blocks the kernel from loading the NVIDIA driver. It must be disabled before booting the OS.
Rawhide
Rawhide kernels are built with debug enabled GPL-only symbols which kernel is incompatible with the NVIDIA binary-only driver. You need to use the Rawhide nodebug repository.
sudo dnf config-manager --add-repo=http://dl.fedoraproject.org/pub/alt/rawhide-kernel-nodebug/fedora-rawhide-kernel-nodebug.repo sudo dnf update
Please remind that Xorg server version is also to take into consideration. In the case of incompatibilities with the xorg-server, you might need to downgrade to the previous fedora release:
sudo dnf downgrade xorg-x11-server\* --releasever=29 --allowerasing sudo echo "exclude=xorg-x11*" >> /etc/dnf/dnf.conf
Uninstall the NVIDIA driver
dnf remove xorg-x11-drv-nvidia\*
Recover from NVIDIA installer
The NVIDIA binary driver installer overwrite some configuration and libraries. If you want to recover to a clean state, either to use nouveau or the packaged driver, use:
rm -f /usr/lib{,64}/libGL.so.* /usr/lib{,64}/libEGL.so.* rm -f /usr/lib{,64}/xorg/modules/extensions/libglx.so dnf reinstall xorg-x11-server-Xorg mesa-libGL mesa-libEGL libglvnd\* mv /etc/X11/xorg.conf /etc/X11/xorg.conf.saved
Bug Report
If you still cannot make the driver to work, you can either report a problem to NVIDIA or to RPM Fusion packager team. Please read: If you have a problem, PLEASE read this first
Basically, you need to generate an archive and attach it to bugzilla or any paste service.
sudo nvidia-bug-report.sh zcat nvidia-bug-report.log.gz | fpaste