解决一例Fedora 31安装NVIDIA官方驱动程序无法使用DKMS注册的问题

  更新: If Not True Then False提供了一份Patch后的340.108版驱动,直接使用此版驱动安装包不会遇到DKMS报错,升级5.5内核时也没有问题,点击进入下载页面。


  手头一台Dell D630的本本,虽然已经10年以上寿命,拿来折腾升级续命一番后现在的配置为:Intel Core 2 Duo T9500/PM965/4G DDR2/NVIDIA Quadro NVS 135M/1280*800/Intel 545s 256GB SSD。
现在用来装个Linux玩玩,选择的发行版是Fedora Workstation。
  此为前提。

  试过RPM Fusion里的akmod-nvidia驱动两次总有问题,第一次是每次开机都有个报错,NVIDIA X Server Settings也无法启动;第二次直接连图形界面都无法启动了。所以试着安装NVIDIA官网提供的驱动。
  老黄那里,对NVS 135M这种上古时代G86核心的显卡提供的驱动是340.xx系列,此时最新版是340.108,比RPM Fusion里的107新一点。
解决一例Fedora 31安装NVIDIA官方驱动程序无法使用DKMS注册的问题_第1张图片解决一例Fedora 31安装NVIDIA官方驱动程序无法使用DKMS注册的问题_第2张图片按照If Not True Then False上面的教程一步步来,很简单,不过2.6.4移除Nouveau驱动那步我没有做,想着留作一个备份?
  然后重启切换到runlevel 3开始安装:

sudo ./NVIDIA-Linux-x86_64-340.108.run

  这里提醒一下要把驱动安装包放在一个没有中文路径的位置,不然重启后对着一堆方块目录名傻眼吧。
  其中有一步:

Would you like to register the kernel module souces with DKMS? This will allow DKMS to automatically build a new module, if you install a different kernel later?

  询问是否要使用DKMS注册内核模块,这样更新Linux内核后会自动生成新的模块,但是选Yes后会报错:

ERROR: Failed to run '/usr/sbin/dkms build -m nvidia -v 340.108 -k 5.4.7-200.fc31.x86_64:
Kernel preparation unnecessary for this kernel. Skipping…

Building module: cleaning build area… make -j2
KERNELRELEASE=5.4.8-200.fc31.x86_64 module
KERNEL_UNAME=5.4.8-200.fc31.x86_64; make -C uvm module
KERNEL_UNAME=5.4.8-200.fc31.x86_64
KBUILD_EXTMOD=/var/lib/dkms/nvidia/340.108/build/uvm…(bad
exit status: 2) Error! Bad return status for module build on kernel:
5.4.8-200.fc31.x86_64 (x86_64) Consult /var/lib/dkms/nvidia/340.108/build/make.log for more information.

  注册失败。当时图省事,重新运行安装程序时直接选了No,顺利安装成功,可以回到GUI正常使用了。
  但是Linux升级内核也是够勤的,半个月内升级了两次,每次升级完重启就进不了GUI了,又得折腾一通(我是干脆重装NVIDIA驱动,应该有直接的方法吧?),于是决心解决这个问题。

  首先手动运行dkms:

sudo dkms build -m nvidia -v 340.108 -k $(uname -r)

  报错后打开/var/lib/dkms/nvidia/340.108/build/make.log,文件结尾有这么几行错误信息:

/var/lib/dkms/nvidia/340.108/build/uvm/nvidia_uvm_lite.c: 在文件作用域:
/var/lib/dkms/nvidia/340.108/build/uvm/nvidia_uvm_lite.c:859:14: 错误:initialization of ‘vm_fault_t (*)(struct vm_fault )’ {或称 ‘unsigned int ()(struct vm_fault )’} from incompatible pointer type ‘int ()(struct vm_area_struct *, struct vm_fault )’ [-Werror=incompatible-pointer-types]
859 | .fault = _fault,
| ^~~~~~
/var/lib/dkms/nvidia/340.108/build/uvm/nvidia_uvm_lite.c:859:14: 附注:(在‘uvmlite_vma_ops.fault’的初始化附近)
/var/lib/dkms/nvidia/340.108/build/uvm/nvidia_uvm_lite.c:889:14: 错误:initialization of ‘vm_fault_t (
)(struct vm_fault )’ {或称 ‘unsigned int ()(struct vm_fault )’} from incompatible pointer type ‘int ()(struct vm_area_struct *, struct vm_fault *)’ [-Werror=incompatible-pointer-types]
889 | .fault = _sigbus_fault,
| ^~~~~~~~~~~~~
/var/lib/dkms/nvidia/340.108/build/uvm/nvidia_uvm_lite.c:889:14: 附注:(在‘counters_vma_ops.fault’的初始化附近)
cc1:有些警告被当作是错误
make[2]: *** [scripts/Makefile.build:266:/var/lib/dkms/nvidia/340.108/build/uvm/nvidia_uvm_lite.o] 错误 1
make[1]: *** [Makefile:1652:/var/lib/dkms/nvidia/340.108/build/uvm] 错误 2
make[1]: 离开目录“/usr/src/kernels/5.4.8-200.fc31.x86_64”
NVIDIA: left KBUILD.
nvidia-uvm.ko failed to build!
make: *** [Makefile:217:nvidia-uvm.ko] 错误 1
make: 离开目录“/var/lib/dkms/nvidia/340.108/build/uvm”

  不兼容指针类型。搜索了一下,这个问题可以通过关闭警告当作错误来解决,虽然没治本,但至少标能治好。

sudo gedit /lib/modules/$(uname -r)/build/Makefile

  查找“-Werror=incompatible-pointer-types”,改为“-Wno-error=incompatible-pointer-types”。
解决一例Fedora 31安装NVIDIA官方驱动程序无法使用DKMS注册的问题_第3张图片  感谢fedora21/beta 安装bcm43142无线网卡驱动和-Werror=incompatible-pointer-types
  重新运行dkms,这次的报错信息是:

DKMS make.log for nvidia-340.108 for kernel 5.4.8-200.fc31.x86_64
(x86_64) 2020年 01月 10日 星期五 19:32:07 CST NVIDIA: calling KBUILD…
make[1]: 进入目录“/usr/src/kernels/5.4.8-200.fc31.x86_64” Makefile:882:
*** 对函数“call”的未终止的调用:遗漏“)”。 停止。 make[1]: 离开目录“/usr/src/kernels/5.4.8-200.fc31.x86_64” NVIDIA: left KBUILD.
nvidia.ko failed to build! make: *** [Makefile:197:nvidia.ko] 错误 1
make: 进入目录“/var/lib/dkms/nvidia/340.108/build/uvm” cd ./…; make
module SYSSRC=/lib/modules/5.4.8-200.fc31.x86_64/source
SYSOUT=/lib/modules/5.4.8-200.fc31.x86_64/build KBUILD_EXTMOD=./…
make[1]: 进入目录“/var/lib/dkms/nvidia/340.108/build” NVIDIA: calling
KBUILD… make[2]: 进入目录“/usr/src/kernels/5.4.8-200.fc31.x86_64”
Makefile:882: *** 对函数“call”的未终止的调用:遗漏“)”。 停止。 make[2]:
离开目录“/usr/src/kernels/5.4.8-200.fc31.x86_64” NVIDIA: left KBUILD.
nvidia.ko failed to build! make[1]: *** [Makefile:197:nvidia.ko] 错误 1
make[1]: 离开目录“/var/lib/dkms/nvidia/340.108/build” make: ***
[Makefile:221:…/Module.symvers] 错误 2 make:
离开目录“/var/lib/dkms/nvidia/340.108/build/uvm”

  这个就有点滑稽了。

sudo gedit /usr/src/kernels/$(uname -r)/Makefile

  定位到882行下面,补全缺失的反括号。
解决一例Fedora 31安装NVIDIA官方驱动程序无法使用DKMS注册的问题_第4张图片  不知怎么会出现这个BUG,不过解决了就行。
  接下来运行dkms就OK了,返回success。
  输入

dkms status

  也可以看到

nvidia, 340.108, 5.4.8-200.fc31.x86_64, x86_64: installed

  重新安装一遍NVIDIA驱动,这次在DKMS那里选Yes也能正常完成,大功告成,以后升级内核时应该不用再操心显卡驱动的问题了。

你可能感兴趣的:(解决一例Fedora 31安装NVIDIA官方驱动程序无法使用DKMS注册的问题)