aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--system/nvidia-driver/README4
-rw-r--r--system/nvidia-driver/changelog.txt1
-rw-r--r--system/nvidia-driver/nvidia-driver.SlackBuild331
-rw-r--r--system/nvidia-driver/nvidia-driver.info50
-rw-r--r--system/nvidia-driver/nvidia-switch111
-rw-r--r--system/nvidia-driver/skip_conflict-GPU_detect.patch28
6 files changed, 245 insertions, 280 deletions
diff --git a/system/nvidia-driver/README b/system/nvidia-driver/README
index 5dccc1074f356..066a174ec34b7 100644
--- a/system/nvidia-driver/README
+++ b/system/nvidia-driver/README
@@ -55,5 +55,5 @@ not working. Here are the affected files:
/usr/lib[64]/xorg/modules/libwfb.so
/usr/lib[64]/xorg/modules/extensions/libglx.so
-Simply remove the dead nvidia symlinks and rename the saved '-xorg'
-appended files.
+Simply remove the dead nvidia symlinks and and reinstall the mesa and
+xorg-server packages. See 'nvidia-switch --help'.
diff --git a/system/nvidia-driver/changelog.txt b/system/nvidia-driver/changelog.txt
index d621da47f95b6..9160e1fed8916 100644
--- a/system/nvidia-driver/changelog.txt
+++ b/system/nvidia-driver/changelog.txt
@@ -29,3 +29,4 @@
4.7 31-APR-2016 version update LLB, added nvidia-installer, updated libs/symlinks
5.0 20-FEB-2017 version update LLB, security fixes, updated libs/symlinks, nvidia-switch
5.1 01-APR-2017 fix nvidia-switch lib names to prevent bad ldconfig symlinks on reboot
+5.2 02-JUN-2017 version update LLB, refactor/debug scripts, use nvidia-installer
diff --git a/system/nvidia-driver/nvidia-driver.SlackBuild b/system/nvidia-driver/nvidia-driver.SlackBuild
index bb3688f8a84e3..65d5bc90de4af 100644
--- a/system/nvidia-driver/nvidia-driver.SlackBuild
+++ b/system/nvidia-driver/nvidia-driver.SlackBuild
@@ -26,18 +26,18 @@
# see changelog.txt
PRGNAM=nvidia-driver
-VERSION=${VERSION:-375.39}
-BUILD=${BUILD:-2}
+VERSION=${VERSION:-375.66}
+BUILD=${BUILD:-1}
TAG=${TAG:-_SBo}
-CPROXY=${CPROXY:-yes}
+
GLVND=${GLVND:-yes}
-# Note: libglvnd may land in X.org Mesa and Nvidia recommended
+# libglnvd may land in mesa and is Nvidia recomended
set -e
if [ -z "$ARCH" ]; then
case "$( uname -m )" in
- i?86) ARCH=i486 ;;
+ i?86) ARCH=i586 ;;
arm*) ARCH=arm ;;
*) ARCH=$( uname -m ) ;;
esac
@@ -48,14 +48,16 @@ TMP=${TMP:-/tmp/SBo}
PKG=$TMP/package-$PRGNAM
OUTPUT=${OUTPUT:-/tmp}
-if [ "$ARCH" = "i486" ]; then
- SLKCFLAGS="-O2 -march=i486 -mtune=i686"
+if [ "$ARCH" = "i586" ]; then
+ SLKCFLAGS="-O2 -march=i586 -mtune=i686"
TARGET="x86"
LIBDIRSUFFIX=""
+ COMPAT32=no
elif [ "$ARCH" = "i686" ]; then
SLKCFLAGS="-O2 -march=i686 -mtune=i686"
TARGET="x86"
LIBDIRSUFFIX=""
+ COMPAT32=no
elif [ "$ARCH" = "x86_64" ]; then
SLKCFLAGS="-O2 -fPIC"
TARGET="x86_64"
@@ -63,21 +65,28 @@ elif [ "$ARCH" = "x86_64" ]; then
# Set 32-bit compatibility flag default
COMPAT32=${COMPAT32:-no}
else
- COMPAT32=${COMPAT32:-no}
SLKCFLAGS="-O2"
LIBDIRSUFFIX=""
+ COMPAT32=no
fi
SRCNAM=NVIDIA-Linux-$TARGET-${VERSION}
-# Flag package as multilib, if needed
-MULTI=""
-if [ "$ARCH" = "x86_64" -a "${COMPAT32}" = "yes" ]; then
- MULTI="_multi"
+# make a clean package directory tree
+rm -rf $PKG
+rm -rf $TMP/$SRCNAM
+mkdir -p $TMP $PKG $OUTPUT $PKG/install
+mkdir -p $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/{drivers,extensions} \
+ $PKG/etc/OpenCL/vendors/ $PKG/usr/{bin,doc,man/man1,sbin} \
+ $PKG/usr/share/{applications,nvidia,pixmaps} \
+ $PKG/usr/include/GL $PKG/etc/vulkan/icd.d $PKG/etc/X11/xorg.conf.d \
+ $PKG/etc/X11/glvnd/egl_vendor.d $PKG/var/log/nvidia/{32,64}
+
+if [ "$COMPAT32" = "yes" ]; then
+ mkdir -p $PKG/usr/lib
fi
-rm -rf $PKG
-mkdir -p $TMP $PKG $OUTPUT
+# Extract all the sources
cd $TMP
rm -rf nvidia-installer-$VERSION
tar xvf $CWD/nvidia-installer-$VERSION.tar.bz2
@@ -89,7 +98,6 @@ rm -rf nvidia-modprobe-$VERSION.tar.bz2
tar xvf $CWD/nvidia-modprobe-$VERSION.tar.bz2
rm -rf nvidia-persistenced-$VERSION.tar.bz2
tar xvf $CWD/nvidia-persistenced-$VERSION.tar.bz2
-rm -rf $SRCNAM
sh $CWD/$SRCNAM.run --extract-only
cd $SRCNAM
chown -R root:root .
@@ -99,163 +107,13 @@ find -L . \
\( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
-o -perm 440 -o -perm 400 \) -exec chmod 644 {} \;
-# Build package directory structure
-mkdir -p $PKG/install $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/{drivers,extensions} \
- $PKG/etc/OpenCL/vendors/ $PKG/usr/lib$LIBDIRSUFFIX/{tls,vdpau} \
- $PKG/etc/X11/glvnd/egl_vendor.d \
- $PKG/usr/{bin,man/man1,sbin} $PKG/usr/share/{applications,nvidia,pixmaps} \
- $PKG/usr/include/GL $PKG/etc/vulkan/icd.d $PKG/usr/doc/$PRGNAM-$VERSION
-
-# Main X driver and modules
-install -m 755 nvidia_drv.so $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/drivers/
-install -m 755 libglx.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/extensions/libglx.so.$VERSION
-# We'll move this over but will leave X.org's libwfb alone
-install -m 755 libnvidia-wfb.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/xorg/modules/libnvidia-wfb.so.$VERSION
-
-if [ "$GLVND" = "no" ]; then
-# The non-GLVND GLX client libraries
- install -m 755 libGL.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
- install -m 755 libEGL.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-else
-# GLVND GLX client libraries libraries are the default, conflict with non-GLVND versions
- install -m 755 libGL.so.1.0.0 $PKG/usr/lib$LIBDIRSUFFIX/
- install -m 755 libEGL.so.1 $PKG/usr/lib$LIBDIRSUFFIX/libEGL.so.1-nvidia
-fi
-
-# Common libs, EGL requires the non-conflicting GLVND libs
-# we'll try leaving these in to get EGL which needs GLVND (see README.txt)
-install -m 755 libGL.la $PKG/usr/lib$LIBDIRSUFFIX/libGL.la-nvidia
-install -m 755 libGLESv1_CM.so.1 $PKG/usr/lib$LIBDIRSUFFIX/libGLESv1_CM.so.1-nvidia
-install -m 755 libGLESv2.so.2 $PKG/usr/lib$LIBDIRSUFFIX/libGLESv2.so.2-nvidia
-install -m 755 libGLX_nvidia.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libOpenGL.so.0 $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libGLdispatch.so.0 $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libGLX.so.0 $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libEGL_nvidia.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libGLESv1_CM_nvidia.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libGLESv2_nvidia.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libOpenCL.so.1.0.0 $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libcuda.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvcuvid.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-cfg.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-compiler.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-eglcore.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-egl-wayland.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-glcore.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-encode.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-fatbinaryloader.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-fbc.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-glsi.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-ifr.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-ml.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-opencl.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-ptxjitcompiler.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/
-install -m 755 libnvidia-tls.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX
-install -m 755 tls/libnvidia-tls.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/tls/
-install -m 755 libvdpau_nvidia.so.$VERSION $PKG/usr/lib$LIBDIRSUFFIX/vdpau
-
-# non-conflict symlinks; see also 'nvidia-switch'
-cd $PKG/usr/lib$LIBDIRSUFFIX
- ln -sf libcuda.so.$VERSION libcuda.so
- ln -sf libGLX.so.0 libGLX.so
- ln -sf libGLX_nvidia.so.$VERSION libGLX_nvidia.so.0
- ln -sf libGLX_nvidia.so.$VERSION libGLX_indirect.so.0
- ln -sf libOpenGL.so.0 libOpenGL.so
- ln -sf libEGL_nvidia.so.$VERSION libEGL_nvidia.so.0
- ln -sf libGLESv1_CM_nvidia.so.$VERSION libGLESv1_CM_nvidia.so.1
- ln -sf libGLESv2_nvidia.so.$VERSION libGLESv2_nvidia.so.2
- ln -sf libnvidia-tls.so.$VERSION libnvidia-tls.so
- ln -sf vdpau/libvdpau_nvidia.so.$VERSION libvdpau_nvidia.so
-cd -
-cd $PKG/usr/lib$LIBDIRSUFFIX/tls
- ln -sf libnvidia-tls.so.$VERSION libnvidia-tls.so
-cd -
-
-# Add optional 32-bit support
-if [ "$ARCH" = "x86_64" -a "${COMPAT32}" = "yes" ]; then
- mkdir -p $PKG/usr/lib/{tls,vdpau}
- if [ "$GLVND" = "no" ]; then
-# The non-GLVND GLX client libraries
- install -m 755 32/libGL.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libEGL.so.$VERSION $PKG/usr/lib/
- else
-# GLVND GLX client libraries libraries are the default, conflict with non-GLVND versions
- install -m 755 32/libGL.so.1.0.0 $PKG/usr/lib/libGL.so.1.0.0
- install -m 755 32/libEGL.so.1 $PKG/usr/lib/libEGL.so.1-nvidia
- fi
-
-# Common libs, EGL requires the non-conflicting GLVND libs
-# we'll try leaving these in to get EGL which needs GLVND (see README.txt)
- install -m 755 32/libGL.la $PKG/usr/lib/libGL.la-nvidia
- install -m 755 32/libGLESv1_CM.so.1 $PKG/usr/lib/libGLESv1_CM.so.1-nvidia
- install -m 755 32/libGLESv2.so.2 $PKG/usr/lib/libGLESv2.so.2-nvidia
- install -m 755 32/libGLX_nvidia.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libOpenGL.so.0 $PKG/usr/lib/
- install -m 755 32/libGLdispatch.so.0 $PKG/usr/lib/
- install -m 755 32/libGLX.so.0 $PKG/usr/lib/
- install -m 755 32/libEGL_nvidia.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libGLESv1_CM_nvidia.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libGLESv2_nvidia.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libOpenCL.so.1.0.0 $PKG/usr/lib/
- install -m 755 32/libcuda.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvcuvid.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-compiler.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-eglcore.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-glcore.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-encode.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-fatbinaryloader.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-fbc.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-glsi.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-ifr.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-ml.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-opencl.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-ptxjitcompiler.so.$VERSION $PKG/usr/lib/
- install -m 755 32/libnvidia-tls.so.$VERSION $PKG/usr/lib/
- install -m 755 32/tls/libnvidia-tls.so.$VERSION $PKG/usr/lib/tls/
- install -m 755 32/libvdpau_nvidia.so.$VERSION $PKG/usr/lib/vdpau/
-
-# non-conflict symlinks for optional 32-bit support; see also 'nvidia-switch'
- cd $PKG/usr/lib
- ln -sf libcuda.so.$VERSION libcuda.so
- ln -sf libGLX.so.0 libGLX.so
- ln -sf libGLX_nvidia.so.$VERSION libGLX_nvidia.so.0
- ln -sf libGLX_nvidia.so.$VERSION libGLX_indirect.so.0
- ln -sf libOpenGL.so.0 libOpenGL.so
- ln -sf libEGL_nvidia.so.$VERSION libEGL_nvidia.so.0
- ln -sf libGLESv1_CM_nvidia.so.$VERSION libGLESv1_CM_nvidia.so.1
- ln -sf libGLESv2_nvidia.so.$VERSION libGLESv2_nvidia.so.2
- ln -sf libnvidia-tls.so.$VERSION libnvidia-tls.so
- ln -sf vdpau/libvdpau_nvidia.so.$VERSION libvdpau_nvidia.so
- cd -
- cd $PKG/usr/lib/tls
- ln -sf libnvidia-tls.so.$VERSION libnvidia-tls.so
- cd -
-fi
-
-#ICDs
-install -m 644 nvidia.icd $PKG/etc/OpenCL/vendors/
-install -m 644 nvidia_icd.json $PKG/etc/vulkan/icd.d
-# Shouldn't hurt to have this as well regardless of GLX client libraries used
-install -m 644 10_nvidia.json $PKG/etc/X11/glvnd/egl_vendor.d/
-
-# Next come the apps
-for i in nvidia-smi nvidia-bug-report.sh nvidia-debugdump; do
- install -m 755 $i $PKG/usr/bin/
-done
-
-install -m 644 nvidia-smi.1.gz $PKG/usr/man/man1/
-
-# New CUDA MPS server for 64-bit Linux only, and requires a device that supports
-# Unified Virtual Address (UVA) and CUDA 4.0+. See NVIDIA docs.
-if [ "$ARCH" = "x86_64" -a "${CPROXY}" = "yes" ]; then
- install -m 755 nvidia-cuda-mps-control $PKG/usr/bin/
- install -m 755 nvidia-cuda-mps-server $PKG/usr/bin/
- install -m 644 nvidia-cuda-mps-control.1.gz $PKG/usr/man/man1/
-fi
-
+# Compiling the various open source apps instead of using the precompiled binaries
# Compiling nvidia-installer from source
-# Not really needed for this SBo package...yet!
cd $TMP/nvidia-installer-$VERSION
+
+# Let's try to remove the conflicting files and GPU detection
+ patch -p1 < $CWD/skip_conflict-GPU_detect.patch
+
chown -R root:root .
find -L . \
\( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
@@ -267,6 +125,7 @@ cd $TMP/nvidia-installer-$VERSION
install -m 755 _out/Linux_$TARGET/nvidia-installer $PKG/usr/bin/
install -m 644 _out/Linux_$TARGET/nvidia-installer.1.gz $PKG/usr/man/man1/
+
cd -
# Compiling nvidia-settings from source
@@ -294,7 +153,7 @@ cd $TMP/nvidia-settings-$VERSION
# For nvidia-settings GUI support
install -m 755 src/_out/Linux_$TARGET/libnvidia-gtk2.so $PKG/usr/lib$LIBDIRSUFFIX/libnvidia-gtk2.so.$VERSION
install -m 755 src/_out/Linux_$TARGET/libnvidia-gtk3.so $PKG/usr/lib$LIBDIRSUFFIX/libnvidia-gtk3.so.$VERSION
-cd ../
+cd -
# Compiling nvidia-xconfig from source
cd $TMP/nvidia-xconfig-$VERSION
@@ -312,7 +171,7 @@ cd $TMP/nvidia-xconfig-$VERSION
install -m 644 _out/Linux_$TARGET/nvidia-xconfig.1.gz $PKG/usr/man/man1/
cd -
-# Some new optional "useless" utilities, such as laptop GPU switching
+# Some optional utilities, such as laptop for possible GPU switching and
# nvidia-modprobe needed to create device nodes, see README!
# FIXME: Needs cleanup at a later date.
@@ -345,9 +204,54 @@ cd -
install -m 644 _out/Linux_$TARGET/nvidia-persistenced.1.gz $PKG/usr/man/man1/
cd -
+# Now we need to copy these newly compiled binaries to the driver source tree
+# since we can't stop the installer from installing the precompiled ones. The installer
+# will then "reinstall" the proper set to the package tree!
+mv -f $PKG/usr/bin/nvidia-* $TMP/$SRCNAM
+mv -f $PKG/usr/lib$LIBDIRSUFFIX/libnvidia-gtk2.so.$VERSION $TMP/$SRCNAM
+mv -f $PKG/usr/lib$LIBDIRSUFFIX/libnvidia-gtk3.so.$VERSION $TMP/$SRCNAM
+
+# Configure options
+if [ "$GLVND" = "yes" ]; then
+ GLVNDOPT="--install-libglvnd --glvnd-glx-client --glvnd-egl-client"
+else
+ GLVNDOPT="--no-install-libglvnd --no-glvnd-glx-client --no-glvnd-egl-client"
+fi
+if [ "$ARCH" = "x86_64" -a "${COMPAT32}" = "yes" ]; then
+ COMP32="--install-compat32-libs --compat32-prefix=$PKG/usr"
+ MULTI="_multi"
+else
+ if [ ! "$ARCH" = "x86_64" ]; then
+ COMP32=""
+ else
+ COMP32="--no-install-compat32-libs"
+ MULTI=""
+ fi
+fi
+
+# Install the binary libs using nvidia-installer compiled above
+cd $TMP/$SRCNAM
+./nvidia-installer -s -N --no-kernel-module -z -n -b \
+ --no-rpms --no-distro-scripts --no-kernel-module-source \
+ --no-x-check --force-libglx-indirect \
+ --x-prefix=$PKG/usr \
+ --x-module-path=$PKG/usr/lib64/xorg/modules \
+ --x-library-path=$PKG/usr/lib64 \
+ --x-sysconfig-path=$PKG/etc/X11/xorg.conf.d \
+ --opengl-prefix=$PKG/usr \
+ --utility-prefix=$PKG/usr \
+ --documentation-prefix=$PKG/usr \
+ --application-profile-path=$PKG/usr/share/nvidia \
+ --glvnd-egl-config-path=$PKG/etc/X11/glvnd/egl_vendor.d \
+ $GLVNDOPT \
+ $COMP32
+
+# Clean-up: we really do not need this:
+rm -rf /var/lib/nvidia
+
# Bash script to cleanly install (in doinst.sh) and uninstall the nvidia files
# so we don't stomp on the overlapping xorg files.
-# Note: switching "on the fly" is no longer supported.
+# Note: switching can be problematic ;-)
install -m 0755 $CWD/nvidia-switch $PKG/usr/sbin/
sed -i s/PKGVERSION/$VERSION/g $PKG/usr/sbin/nvidia-switch
sed -i s/LIBDIRSUFFIX/$LIBDIRSUFFIX/g $PKG/usr/sbin/nvidia-switch
@@ -355,39 +259,84 @@ if [ "$GLVND" = "yes" ]; then
sed -i s/GLVNDFLAG/yes/g $PKG/usr/sbin/nvidia-switch
else
sed -i s/GLVNDFLAG/no/g $PKG/usr/sbin/nvidia-switch
-fi
+fi
if [ ${COMPAT32} = "yes" ]; then
sed -i s/LIB32FLAG/yes/g $PKG/usr/sbin/nvidia-switch
else
sed -i s/LIB32FLAG/no/g $PKG/usr/sbin/nvidia-switch
fi
-# These update placeholders and correct wrong paths
-sed -i "s|__LIBGL_PATH__|/usr/lib$LIBDIRSUFFIX/|" $PKG/usr/lib$LIBDIRSUFFIX/libGL.la-nvidia
-sed -i "s|/usr/X11R6/lib|/usr/lib$LIBDIRSUFFIX/|" $PKG/usr/lib$LIBDIRSUFFIX/libGL.la-nvidia
-sed -i "s|__UTILS_PATH__|/usr/bin|" $PKG/usr/share/applications/nvidia-settings.desktop
-sed -i "s|__PIXMAP_PATH__|/usr/share/pixmaps|" $PKG/usr/share/applications/nvidia-settings.desktop
-sed -i "s|__NVIDIA_SETTINGS_DESKTOP_CATEGORIES__|Application;Settings|" $PKG/usr/share/applications/nvidia-settings.desktop
+# These correct wrong paths
+sed -i "s|$TMP/package-$PRGNAM/usr|/usr|" $PKG/usr/lib$LIBDIRSUFFIX/libGL.la
+sed -i "s|/usr/X11R6/lib|/usr/lib$LIBDIRSUFFIX|" $PKG/usr/lib$LIBDIRSUFFIX/libGL.la
+sed -i "s|$PKG/usr/bin|/usr/bin|" \
+ $PKG/usr/share/applications/nvidia-settings.desktop
+sed -i "s|$PKG/usr/share/doc/NVIDIA_GLX-1.0|/usr/share/pixmaps|" \
+ $PKG/usr/share/applications/nvidia-settings.desktop
+
if [ "$ARCH" = "x86_64" -a "${COMPAT32}" = "yes" ]; then
- sed -i "s|__LIBGL_PATH__|/usr/lib/|" $PKG/usr/lib/libGL.la-nvidia
- sed -i "s|/usr/X11R6/lib|/usr/lib/|" $PKG/usr/lib/libGL.la-nvidia
+ sed -i "s|$TMP/package-$PRGNAM/usr|/usr|" $PKG/usr/lib/libGL.la
+ sed -i "s|/usr/X11R6/lib|/usr/lib|" $PKG/usr/lib/libGL.la
fi
-# Basic docs
-cd $TMP/$SRCNAM
-cp -a LICENSE NVIDIA_Changelog README.txt html $PKG/usr/doc/$PRGNAM-$VERSION
-# sample start/stop scripts for nvidia-persistenced
-cp -a nvidia-persistenced-init.tar.bz2 $PKG/usr/doc/$PRGNAM-$VERSION
+# rename conficting files as needed; remove conflicting symlinks created by installer
+cd $PKG/usr/lib$LIBDIRSUFFIX
+ if [ "$GLVND" = "yes" ]; then
+ mv libEGL.so.1 libEGL.so.1-nvidia
+ fi
+ mv libGL.la libGL.la-nvidia
+ mv libGLESv1_CM.so.1 libGLESv1_CM.so.1-nvidia
+ mv libGLESv2.so.2 libGLESv2.so.2-nvidia
+ rm -f libEGL.so
+ rm -f libGL.so
+ rm -f libGL.so.1
+ rm -f libGLESv1_CM.so
+ rm -f libGLESv2.so
+ rm -f xorg/modules/libwfb.so
+ rm -f xorg/modules/extensions/libglx.so
+cd -
+
+if [ "$ARCH" = "x86_64" -a "${COMPAT32}" = "yes" ]; then
+ cd $PKG/usr/lib
+ if [ "$GLVND" = "yes" ]; then
+ mv libEGL.so.1 libEGL.so.1-nvidia
+ fi
+ mv libGL.la libGL.la-nvidia
+ mv libGLESv1_CM.so.1 libGLESv1_CM.so.1-nvidia
+ mv libGLESv2.so.2 libGLESv2.so.2-nvidia
+ rm -f libEGL.so
+ rm -f libGL.so
+ rm -f libGL.so.1
+ rm -f libGLESv1_CM.so
+ rm -f libGLESv2.so
+ cd -
+fi
+
+#ICDs
+install -m 644 nvidia.icd $PKG/etc/OpenCL/vendors/
+install -m 644 nvidia_icd.json $PKG/etc/vulkan/icd.d/
+
+# Remove xorg conf file since we take care of that in nvidia-driver
+rm -rf $PKG/etc/X11/xorg.conf.d
+cat <<EOF > $PKG/var/log/nvidia/README.txt
+Do NOT delete this directory!
+nvidia-switch will backup the original X.org libraries here.
+EOF
+
+cd $TMP/$SRCNAM
+# put docs in the right place
+mv $PKG/usr/share/man/man1/nvidia-* $PKG/usr/man/man1
+rm -rf $PKG/usr/share/man
+mv $PKG/usr/share/doc/NVIDIA_GLX-1.0 $PKG/usr/doc/$PRGNAM-$VERSION
+rm -rf $PKG/usr/share/doc
+cp -a LICENSE NVIDIA_Changelog README.txt $PKG/usr/doc/$PRGNAM-$VERSION
cat $CWD/README > $PKG/usr/doc/$PRGNAM-$VERSION/README.Slackware
cat $CWD/$PRGNAM.SlackBuild > $PKG/usr/doc/$PRGNAM-$VERSION/$PRGNAM.SlackBuild
-# nvidia-settings application profile support (see documention for use).
-install -m 755 nvidia-application-profiles-$VERSION-key-documentation $PKG/usr/share/nvidia/
-install -m 755 nvidia-application-profiles-$VERSION-rc $PKG/usr/share/nvidia/
-
sed "s/PKGVERSION/$VERSION/g" $CWD/slack-desc > $PKG/install/slack-desc
cat $CWD/doinst.sh > $PKG/install/doinst.sh
+# Flag install as multlib as needed and build package.
cd $PKG
/sbin/makepkg -l y -c n $OUTPUT/$PRGNAM-$VERSION$MULTI-$TARGET-$BUILD$TAG.${PKGTYPE:-tgz}
diff --git a/system/nvidia-driver/nvidia-driver.info b/system/nvidia-driver/nvidia-driver.info
index b3fcaa1324c1c..e189aedb99e98 100644
--- a/system/nvidia-driver/nvidia-driver.info
+++ b/system/nvidia-driver/nvidia-driver.info
@@ -1,30 +1,30 @@
PRGNAM="nvidia-driver"
-VERSION="375.39"
+VERSION="375.66"
HOMEPAGE="http://www.nvidia.com"
-DOWNLOAD="https://download.nvidia.com/XFree86/Linux-x86/375.39/NVIDIA-Linux-x86-375.39.run \
- https://download.nvidia.com/XFree86/nvidia-installer/nvidia-installer-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-modprobe/nvidia-modprobe-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-persistenced/nvidia-persistenced-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-settings/nvidia-settings-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-xconfig/nvidia-xconfig-375.39.tar.bz2"
-MD5SUM="9247d5eb9df58bb7755c9060ef5d103d \
- 1a1b3ecbbd9cf17085548cc5d8fe6cba \
- f630cbefa0c300d58df7a1d989c7766c \
- d147dd34877b73000448f5fe8d06371d \
- ced26b5504b08abaf4e156740021b2bc \
- 7f41d52c1220feb4d837982a54190d6c"
-DOWNLOAD_x86_64="https://download.nvidia.com/XFree86/Linux-x86_64/375.39/NVIDIA-Linux-x86_64-375.39.run \
- https://download.nvidia.com/XFree86/nvidia-installer/nvidia-installer-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-modprobe/nvidia-modprobe-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-persistenced/nvidia-persistenced-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-settings/nvidia-settings-375.39.tar.bz2 \
- https://download.nvidia.com/XFree86/nvidia-xconfig/nvidia-xconfig-375.39.tar.bz2"
-MD5SUM_x86_64="35b32baba21089dfe5d960ae89d98cde \
- 1a1b3ecbbd9cf17085548cc5d8fe6cba \
- f630cbefa0c300d58df7a1d989c7766c \
- d147dd34877b73000448f5fe8d06371d \
- ced26b5504b08abaf4e156740021b2bc \
- 7f41d52c1220feb4d837982a54190d6c"
+DOWNLOAD="https://download.nvidia.com/XFree86/Linux-x86/375.66/NVIDIA-Linux-x86-375.66.run \
+ https://download.nvidia.com/XFree86/nvidia-installer/nvidia-installer-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-modprobe/nvidia-modprobe-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-persistenced/nvidia-persistenced-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-settings/nvidia-settings-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-xconfig/nvidia-xconfig-375.66.tar.bz2"
+MD5SUM="47dddb796fe39497cf6ae374591f6eb9 \
+ 1a09312f35b2a9211d6256272f5a5e02 \
+ 53c8efb0bb4a18bb05cbddc8845d9aaa \
+ f97000abef5f7c7ae27a8f8572558b96 \
+ eb29b20b91703323a69d08db1be7237d \
+ 5fd9daa01c3d6309ae91083d0f01e8be"
+DOWNLOAD_x86_64="https://download.nvidia.com/XFree86/Linux-x86_64/375.66/NVIDIA-Linux-x86_64-375.66.run \
+ https://download.nvidia.com/XFree86/nvidia-installer/nvidia-installer-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-modprobe/nvidia-modprobe-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-persistenced/nvidia-persistenced-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-settings/nvidia-settings-375.66.tar.bz2 \
+ https://download.nvidia.com/XFree86/nvidia-xconfig/nvidia-xconfig-375.66.tar.bz2"
+MD5SUM_x86_64="9cf2c0a342a088211f25c5d8137097e6 \
+ 1a09312f35b2a9211d6256272f5a5e02 \
+ 53c8efb0bb4a18bb05cbddc8845d9aaa \
+ f97000abef5f7c7ae27a8f8572558b96 \
+ eb29b20b91703323a69d08db1be7237d \
+ 5fd9daa01c3d6309ae91083d0f01e8be"
REQUIRES="nvidia-kernel"
MAINTAINER="Edward W. Koenig"
EMAIL="kingbeowulf@gmail.com"
diff --git a/system/nvidia-driver/nvidia-switch b/system/nvidia-driver/nvidia-switch
index f92f6837cf336..82eaf53932743 100644
--- a/system/nvidia-driver/nvidia-switch
+++ b/system/nvidia-driver/nvidia-switch
@@ -20,20 +20,18 @@
# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
-# nvidia-switch utility 3.0
+# nvidia-switch utility 4.0
#
# A tool to install and cleanly remove the nvidia driver without stomping on the xorg files.
# Note: this tool "should" allow switching on the fly, but why? Pick a driver! You will still
# need to edit a bunch of other config files.
-# TO-DO: needs more cleanup; still way too brittle.
-# might be better to move mesa and xorg conflicts to /var/lib/nvidia
-
+# TO-DO: needs more cleanup, simplify linking using system tools
ROOT="${ROOT:-/}"
CWD=$(pwd)
-LIBSUFFIX="LIBDIRSUFFIX" # This will be replaced in the build script
COMPAT32="LIB32FLAG" # This will be replaced in the build script (yes | no)
+LIBSUFFIX="LIBDIRSUFFIX" # This will be replaced in the build script
INC="${ROOT}usr/include/GL"
LIB="${ROOT}usr/lib${LIBSUFFIX}"
LIB32="${ROOT}usr/lib"
@@ -43,56 +41,67 @@ NV_VERSION="PKGVERSION" # This will be replaced in the build script
GL_VERSION="1.2.0"
GLVND="GLVNDFLAG" # This will be replaced in the build script (yes | no)
NV_CONF="/usr/share/X11/xorg.conf.d/10-nvidia.conf"
+SAVELIBS="/var/log/nvidia"
save_GL(){
+# backup original mesa and xorg conflicts to /var/lib/nvidia
cd $2
+ if [ "$2" = "$LIB32" ]; then
+ SAVELIBS="/var/log/nvidia/32"
+ fi
+ if [ "$2" = "$LIB" ]; then
+ SAVELIBS="/var/log/nvidia/64"
+ fi
case "$1" in
"nvidia")
- mv libGL.so.$GL_VERSION xorg-libGL.so.$GL_VERSION
- mv libGL.la xorg-libGL.la
+
+ mv libGL.so.$GL_VERSION $SAVELIBS/libGL.so.$GL_VERSION
+ mv libGL.la $SAVELIBS/libGL.la
+ mv libEGL.so.1.0.0 $SAVELIBS/libEGL.so.1.0.0
+ mv libGLESv1_CM.so.1.1.0 $SAVELIBS/libGLESv1_CM.so.1.1.0
+ mv libGLESv2.so.2.0.0 $SAVELIBS/libGLESv2.so.2.0.0
mv libGL.la-nvidia libGL.la
- mv libEGL.so.1.0.0 xorg-libEGL.so.1.0.0
if [ "$GLVND" = "yes" ]; then
ln -sf libGL.so.1.0.0 libGL.so.1
- ln -sf libGL.so.1 libGL.so
+ ln -sf libGL.so.1.0.0 libGL.so
ln -sf libEGL.so.1-nvidia libEGL.so.1
- ln -sf libEGL.so.1 libEGL.so
+ ln -sf libEGL.so.1-nvidia libEGL.so
else
ln -sf libGL.so.$NV_VERSION libGL.so.1
- ln -sf libGL.so.1 libGL.so
+ ln -sf libGL.so.$NV_VERSION libGL.so
ln -sf libEGL.so.$NV_VERSION libEGL.so.1
- ln -sf libEGL.so.1 libEGL.so
+ ln -sf libEGL.so.$NV_VERSION libEGL.so
fi
- mv libGLESv1_CM.so.1.1.0 xorg-libGLESv1_CM.so.1.1.0
ln -sf libGLESv1_CM.so.1-nvidia libGLESv1_CM.so.1
- ln -sf libGLESv1_CM.so.1 libGLESv1_CM.so
- mv libGLESv2.so.2.0.0 xorg-libGLESv2.so.2.0.0
+ ln -sf libGLESv1_CM.so.1-nvidia libGLESv1_CM.so
+
ln -sf libGLESv2.so.2-nvidia libGLESv2.so.2
- ln -sf libGLESv2.so.2 libGLESv2.so
+ ln -sf libGLESv2.so.2-nvidia libGLESv2.so
;;
"xorg")
mv libGL.la libGL.la-nvidia
- mv xorg-libGL.la libGL.la
- mv xorg-libEGL.so.1.0.0 libEGL.so.1.0.0
- mv xorg-libGL.so.$GL_VERSION libGL.so.$GL_VERSION
+ mv $SAVELIBS/libGL.so.$GL_VERSION libGL.so.$GL_VERSION
+ mv $SAVELIBS/libGL.la libGL.la
+ mv $SAVELIBS/libEGL.so.1.0.0 libEGL.so.1.0.0
+ mv $SAVELIBS/libGLESv1_CM.so.1.1.0 libGLESv1_CM.so.1.1.0
+ mv $SAVELIBS/libGLESv2.so.2.0.0 libGLESv2.so.2.0.0
ln -sf libGL.so.$GL_VERSION libGL.so.1
ln -sf libGL.so.$GL_VERSION libGL.so
ln -sf libEGL.so.1.0.0 libEGL.so.1
ln -sf libEGL.so.1.0.0 libEGL.so
- mv xorg-libGLESv1_CM.so.1.1.0 libGLESv1_CM.so.1.1.0
ln -sf libGLESv1_CM.so.1.1.0 libGLESv1_CM.so.1
ln -sf libGLESv1_CM.so.1.1.0 libGLESv1_CM.so
- mv xorg-libGLESv2.so.2.0.0 libGLESv2.so.2.0.0
ln -sf libGLESv2.so.2.0.0 libGLESv2.so.2
ln -sf libGLESv2.so.2.0.0 libGLESv2.so
;;
+
*)
- echo "nothind to do for save_gl?"
+ echo "nothing to do for save_gl?"
exit 1
;;
esac
@@ -117,7 +126,7 @@ save_glx(){
fi
;;
*)
- echo "nothind to do for save_glx?"
+ echo "nothing to do for save_glx?"
exit 1
;;
esac
@@ -152,11 +161,7 @@ nvidia_install(){
save_wfb "nvidia"
# Check for multilib configuration
if [ "$COMPAT32" = "yes" ]; then
- if [ -e $LIB32/libGL.so.$GL_VERSION ]; then
- save_GL "nvidia" $LIB32
- else
- echo "mesa-compat32 is not installed, skipping..."
- fi
+ save_GL "nvidia" $LIB32
fi
}
@@ -169,32 +174,10 @@ nvidia_remove(){
save_glx "xorg"
save_GL "xorg" $LIB
save_wfb "xorg"
-# remove dangling sylinks
- rm -f $LIB/libnvcuvid.so.1
- rm -f $LIB/libnvidia-cfg.so.1
- rm -f $LIB/libnvidia-encode.so.1
- rm -f $LIB/libnvidia-fbc.so.1
- rm -f $LIB/libnvidia-ifr.so.1
- rm -f $LIB/libnvidia-ml.so.1
- rm -f $LIB/libnvidia-opencl.so.1
- rm -f $LIB/libcuda.so.1
- rm -f $LIB/libOpenCL.so.1
+
# Check for multilib configuration
if [ "$COMPAT32" = "yes" ]; then
- if [ -e $LIB32/xorg-libGL.so.$GL_VERSION ]; then
- save_GL "xorg" $LIB32
- else
- echo "mesa-compat32 is not installed, skipping..."
- fi
-# remove dangling sylinks
- rm -f $LIB32/libnvcuvid.so.1
- rm -f $LIB32/libnvidia-encode.so.1
- rm -f $LIB32/libnvidia-fbc.so.1
- rm -f $LIB32/libnvidia-ifr.so.1
- rm -f $LIB32/libnvidia-ml.so.1
- rm -f $LIB32/libnvidia-opencl.so.1
- rm -f $LIB32/libcuda.so.1
- rm -f $LIB32/libOpenCL.so.1
+ save_GL "xorg" $LIB32
fi
if [ -e $NV_CONF ]; then
@@ -211,9 +194,9 @@ restore(){
# User must:
# 1. remove any dangling symlinks and xorg-*, *-nvidia files in /usr/lib*/,
# and any other housekeeping tasks.
-# 2. copy stock Slackware packages to /root/Slackware
-# 3. be running STOCK Slackware-14.2
-# 4. realize that COMPAT32 is not supported ;-)
+# 2. copy stock Slackware packages to /root/Slackware or provide an alternate location
+# 3. be running Slackware-14.2, not current
+# 4. realize that COMPAT32 is not stable ;-)
if [ "$LIBSUFFIX" = "64" ]; then
ARCH="x86_64"
@@ -221,7 +204,7 @@ else
ARCH="x86"
fi
-PKGPATH="/root/Slackware"
+PKGPATH=${PKGPATH:-/root/Slackware}
MESA="mesa-11.2.2-$ARCH-1.txz"
MESA32="mesa-compat32-11.2.2-$ARCH-1compat32.txz"
XORG="xorg-server-1.18.3-$ARCH-2.txz"
@@ -231,9 +214,9 @@ if [ -d $PKGPATH ]; then
if [ `find $PKGPATH -prune -empty -type d` ]; then
echo "Your $PKGPATH is empty!"
else
- upgradepkg --reinstall $MESA $XORG
+ upgradepkg --reinstall --install-new $MESA $XORG
if [ "COMPAT32" = "yes" ]; then
- upgradepkg --reinstall $MESA32
+ upgradepkg --reinstall --install-new $MESA32
fi
fi
else
@@ -243,10 +226,14 @@ fi
usage(){
echo "Usage:"
- echo " --install Set up nvidia driver files (only during pkg install)"
- echo " --remove Return to stock xorg files and remove all symlinks"
- echo " --restore Reinstall stock Mesa and xorg-server [EXPERIMENTAL]"
- echo " --help Show this help message"
+ echo " --install Set up nvidia driver files"
+ echo " --remove Return to stock xorg files and restore all symlinks"
+ echo " --restore Reinstall stock Mesa and xorg-server [EXPERIMENTAL]"
+ echo " mesa-11.2.2, org-server-1.18.3, and optionally"
+ echo " mesa-compat32-11.2.2 are expected in /root/Slackware"
+ echo " Use 'PKGPATH="<location>" nvidia-switch --restore'"
+ echo " to override."
+ echo " --help Show this help message"
}
case "$1" in
diff --git a/system/nvidia-driver/skip_conflict-GPU_detect.patch b/system/nvidia-driver/skip_conflict-GPU_detect.patch
new file mode 100644
index 0000000000000..b98a12ccbbc13
--- /dev/null
+++ b/system/nvidia-driver/skip_conflict-GPU_detect.patch
@@ -0,0 +1,28 @@
+diff -uaN nvidia-installer-375.66/command-list.c nvidia-installer-375.66.new/command-list.c
+--- nvidia-installer-375.66/command-list.c 2017-05-01 16:41:24.000000000 -0700
++++ nvidia-installer-375.66.new/command-list.c 2017-07-01 18:15:25.087868229 -0700
+@@ -903,6 +903,8 @@
+ // Allocate enough space for the whole file list, plus two extra files and
+ // a NULL at the end.
+ cfList = nvalloc((p->num_entries + 3) * sizeof(ConflictingFileInfo));
++/* let's just return an empty list! */
++ return cfList;
+
+ for (i = 0; i < p->num_entries; i++) {
+ PackageEntry *entry = &p->entries[i];
+Common subdirectories: nvidia-installer-375.66/common-utils and nvidia-installer-375.66.new/common-utils
+diff -uaN nvidia-installer-375.66/misc.c nvidia-installer-375.66.new/misc.c
+--- nvidia-installer-375.66/misc.c 2017-05-01 16:41:24.000000000 -0700
++++ nvidia-installer-375.66.new/misc.c 2017-07-01 18:19:22.310846284 -0700
+@@ -2290,7 +2290,10 @@
+ "For further details, please see the appendix SUPPORTED "
+ "NVIDIA GRAPHICS CHIPS in the README available on the Linux "
+ "driver download page at www.nvidia.com.", p->version);
+- return FALSE;
++ /* return FALSE;
+++ * We're just going to keep the message but skip the result
+++ * so we can run this in a VM.
+++ */
+ }
+
+ if (!found_vga_device)