nvidia: update to 550.54.14.

This commit is contained in:
Andrew Benson 2024-02-23 17:12:08 -06:00 committed by Andrew Benson
parent 6d5a416aea
commit 353d0381ee
2 changed files with 13 additions and 75 deletions

View file

@ -1,62 +0,0 @@
linux-6.1.76, 6.6.15, and 6.7.3 have modified the non-ARCH-specific
pfn_valid() to use __rcu_read_lock/unlock[1] that is marked GPL and
cannot be used here[2][3][4] unless use the open source variant.
As a workaround, reuse the old implementation until NVIDIA makes
a fixed release (due to no longer be using pfn_valid[5], likely
with its own implementation similarly to this patch).
Safe to use with kernel >=5.15 or so but older ones had a different
pfn_valid implementation. However 5.15 and older branches are
"currently" not affected, so simply limit to >=6.1.76.
[1] https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/include/linux/mmzone.h?h=v6.7.3&id=3a01daace71b521563c38bbbf874e14c3e58adb7
[2] https://bugs.gentoo.org/923456
[3] https://forums.developer.nvidia.com/t/280908
[4] https://github.com/NVIDIA/open-gpu-kernel-modules/issues/594
[5] https://github.com/NVIDIA/open-gpu-kernel-modules/issues/594#issuecomment-1916197641
--- a/kernel/common/inc/nv-linux.h
+++ b/kernel/common/inc/nv-linux.h
@@ -1990,2 +1990,23 @@
+#if defined(CONFIG_HAVE_ARCH_PFN_VALID) || LINUX_VERSION_CODE < KERNEL_VERSION(6,1,76)
+# define nv_pfn_valid pfn_valid
+#else
+/* pre-6.1.76 kernel pfn_valid version without GPL rcu_read_lock/unlock() */
+static inline int nv_pfn_valid(unsigned long pfn)
+{
+ struct mem_section *ms;
+
+ if (PHYS_PFN(PFN_PHYS(pfn)) != pfn)
+ return 0;
+
+ if (pfn_to_section_nr(pfn) >= NR_MEM_SECTIONS)
+ return 0;
+
+ ms = __pfn_to_section(pfn);
+ if (!valid_section(ms))
+ return 0;
+
+ return early_section(ms) || pfn_section_valid(ms, pfn);
+}
+#endif
#endif /* _NV_LINUX_H_ */
--- a/kernel/nvidia/nv-mmap.c
+++ b/kernel/nvidia/nv-mmap.c
@@ -576,3 +576,3 @@
if (!IS_REG_OFFSET(nv, access_start, access_len) &&
- (pfn_valid(PFN_DOWN(mmap_start))))
+ (nv_pfn_valid(PFN_DOWN(mmap_start))))
{
--- a/kernel/nvidia/os-mlock.c
+++ b/kernel/nvidia/os-mlock.c
@@ -102,3 +102,3 @@
if ((nv_follow_pfn(vma, (start + (i * PAGE_SIZE)), &pfn) < 0) ||
- (!pfn_valid(pfn)))
+ (!nv_pfn_valid(pfn)))
{
@@ -176,3 +176,3 @@
- if (pfn_valid(pfn))
+ if (nv_pfn_valid(pfn))
{

View file

@ -3,8 +3,8 @@
_desc="NVIDIA drivers for linux"
pkgname=nvidia
version=535.154.05
revision=2
version=550.54.14
revision=1
maintainer="Andrew Benson <abenson+void@gmail.com>"
license="custom:NVIDIA Proprietary"
homepage="https://www.nvidia.com/en-us/drivers/unix/"
@ -19,7 +19,7 @@ conflicts="xserver-abi-video>25_1 nvidia470>=0 nvidia390>=0"
_pkg="NVIDIA-Linux-x86_64-${version}"
distfiles="http://uk.download.nvidia.com/XFree86/Linux-x86_64/${version}/${_pkg}.run"
checksum=7e95065caa6b82de926110f14827a61972eb12c200e863a29e9fb47866eaa898
checksum=8c497ff1cfc7c310fb875149bc30faa4fd26d2237b2cba6cd2e8b0780157cfe3
# subpackages need to be processed in this specific order
subpackages="nvidia-gtklibs nvidia-dkms nvidia-firmware nvidia-opencl nvidia-libs nvidia-libs-32bit"
depends="nvidia-libs-${version}_${revision}
@ -75,6 +75,8 @@ _install_libs() {
ln -sf libnvidia-fbc.so.${version} ${DESTDIR}/${libdir}/libnvidia-fbc.so
ln -sf libnvidia-fbc.so.${version} ${DESTDIR}/${libdir}/libnvidia-fbc.so.1
vinstall libnvidia-gpucomp.so.${version} 755 ${libdir}
# CUDA
vinstall libcuda.so.${version} 755 ${libdir}
ln -sf libcuda.so.${version} ${DESTDIR}/${libdir}/libcuda.so
@ -130,11 +132,11 @@ do_install() {
${DESTDIR}/usr/lib/nvidia/xorg/libglxserver_nvidia.so.1
# Wayland/GBM
vinstall libnvidia-egl-wayland.so.1.1.11 755 usr/lib
ln -sf libnvidia-egl-wayland.so.1.1.11 \
vinstall libnvidia-egl-wayland.so.1.1.13 755 usr/lib
ln -sf libnvidia-egl-wayland.so.1.1.13 \
${DESTDIR}/usr/lib/libnvidia-egl-wayland.so.1
vinstall libnvidia-egl-gbm.so.1.1.0 755 usr/lib
ln -sf libnvidia-egl-gbm.so.1.1.0 \
vinstall libnvidia-egl-gbm.so.1.1.1 755 usr/lib
ln -sf libnvidia-egl-gbm.so.1.1.1 \
${DESTDIR}/usr/lib/libnvidia-egl-gbm.so.1
vmkdir usr/share/glvnd/egl_vendor.d
@ -153,6 +155,8 @@ do_install() {
ln -sf libnvidia-cfg.so.${version} ${DESTDIR}/usr/lib/libnvidia-cfg.so
ln -sf libnvidia-cfg.so.${version} ${DESTDIR}/usr/lib/libnvidia-cfg.so.1
vinstall libnvidia-api.so.1 755 usr/lib
vbin nvidia-cuda-mps-control
vbin nvidia-cuda-mps-server
gzip -d nvidia-cuda-mps-control.1.gz
@ -220,12 +224,6 @@ do_install() {
# vulkan real-time ray tracing extensions
vinstall libnvidia-rtcore.so.${version} 755 usr/lib
vinstall libnvidia-vulkan-producer.so.${version} 755 usr/lib
ln -sf libnvidia-vulkan-producer.so.${version} \
${DESTDIR}/usr/lib/libnvidia-vulkan-producer.so
ln -sf libnvidia-vulkan-producer.so.${version} \
${DESTDIR}/usr/lib/libnvidia-vulkan-producer.so.1
# ngx
vbin nvidia-ngx-updater
vinstall libnvidia-ngx.so.${version} 755 usr/lib
@ -243,6 +241,8 @@ do_install() {
ln -sf libnvoptix.so.${version} ${DESTDIR}/usr/lib/libnvoptix.so
ln -sf libnvoptix.so.${version} ${DESTDIR}/usr/lib/libnvoptix.so.1
vinstall libnvidia-opticalflow.so.${version} 755 usr/lib
# dkms pkg
vmkdir usr/src/nvidia-${version}
vcopy "kernel/*" usr/src/nvidia-${version}