summaryrefslogtreecommitdiffstats
path: root/system/nvidia-legacy390-driver/nvidia-switch
diff options
context:
space:
mode:
author Edward W. Koenig2018-11-10 01:18:09 +0100
committer Willy Sudiarto Raharjo2018-11-10 01:48:00 +0100
commit2bec5d0a5a79c0b4932fbb028f392a1db37279d0 (patch)
tree6c720b14e09be2f81bc3f11b2e8ee8229791486c /system/nvidia-legacy390-driver/nvidia-switch
parent499640e71099a817e4bf2c0bd7615a25e53e08e5 (diff)
downloadslackbuilds-2bec5d0a5a79c0b4932fbb028f392a1db37279d0.tar.gz
system/nvidia-legacy390-driver: Added (Nvidia Proprietary Driver).
Signed-off-by: David Spencer <idlemoor@slackbuilds.org>
Diffstat (limited to 'system/nvidia-legacy390-driver/nvidia-switch')
-rw-r--r--system/nvidia-legacy390-driver/nvidia-switch266
1 files changed, 266 insertions, 0 deletions
diff --git a/system/nvidia-legacy390-driver/nvidia-switch b/system/nvidia-legacy390-driver/nvidia-switch
new file mode 100644
index 0000000000..7d97f3304b
--- /dev/null
+++ b/system/nvidia-legacy390-driver/nvidia-switch
@@ -0,0 +1,266 @@
+#!/bin/sh
+
+# Copyright 2012-2017 Edward W. Koenig, Vancouver, WA, USA
+# All rights reserved.
+#
+# Redistribution and use of this script, with or without modification, is
+# permitted provided that the following conditions are met:
+#
+# 1. Redistributions of this script must retain the above copyright
+# notice, this list of conditions and the following disclaimer.
+#
+# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ''AS IS'' AND ANY EXPRESS OR IMPLIED
+# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
+# MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
+# EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
+# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
+# OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
+# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
+# OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
+# ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+#
+# 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, simplify linking using system tools
+
+ROOT="${ROOT:-/}"
+CWD=$(pwd)
+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"
+XMOD="${LIB}/xorg/modules"
+XLIB="$XMOD/extensions"
+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="${ROOT}usr/share/X11/xorg.conf.d/10-nvidia.conf"
+SAVELIBS="${ROOT}var/log/nvidia"
+
+save_GL(){
+# backup original mesa and xorg conflicts to /var/log/nvidia
+ cd $2
+ # Need to make sure save path is reset incase of multilib
+ SAVELIBS="${ROOT}var/log/nvidia"
+ if [ "$2" = "$LIB32" ]; then
+ SAVELIBS="${SAVELIBS}/32"
+ elif [ "$2" = "$LIB" ]; then
+ SAVELIBS="${SAVELIBS}/64"
+ fi
+
+ case "$1" in
+ "nvidia")
+
+ 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
+
+ if [ "$GLVND" = "yes" ]; then
+ ln -sf libGL.so.1.7.0 libGL.so.1
+ ln -sf libGL.so.1.7.0 libGL.so
+ ln -sf libEGL.so.1.1.0-nvidia libEGL.so.1.1.0
+ ln -sf libEGL.so.1.1.0-nvidia libEGL.so
+ else
+ ln -sf libGL.so.$NV_VERSION libGL.so.1
+ ln -sf libGL.so.$NV_VERSION libGL.so
+ ln -sf libEGL.so.$NV_VERSION libEGL.so.1
+ ln -sf libEGL.so.$NV_VERSION libEGL.so
+ fi
+
+ ln -sf libGLESv1_CM.so.1.2.0-nvidia libGLESv1_CM.so.1.2.0
+ ln -sf libGLESv1_CM.so.1.2.0-nvidia libGLESv1_CM.so.1
+ ln -sf libGLESv1_CM.so.1.2.0-nvidia libGLESv1_CM.so
+
+ ln -sf libGLESv2.so.2.1.0-nvidia libGLESv2.so.2.1.0
+ ln -sf libGLESv2.so.2.1.0-nvidia libGLESv2.so.2
+ ln -sf libGLESv2.so.2.1.0-nvidia libGLESv2.so
+ ;;
+
+ "xorg")
+ mv libGL.la libGL.la-nvidia
+ 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
+ rm -f libEGL.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
+ ln -sf libGLESv2.so.2.0.0 libGLESv2.so.2
+ ln -sf libGLESv2.so.2.0.0 libGLESv2.so
+ rm -f libGLESv1_CM.so.1.2.0
+ rm -f libGLESv2.so.2.1.0
+ ;;
+
+ *)
+ echo "nothing to do for save_gl?"
+ exit 1
+ ;;
+ esac
+ cd "$CWD"
+}
+
+save_glx(){
+ cd "$XLIB"
+ case "$1" in
+ "nvidia")
+ if [ -e libglx.so ]; then
+ mv libglx.so xorg-libglx.so
+ fi
+ ln -sf libglx.so.$NV_VERSION libglx.so
+ ;;
+ "xorg")
+ if [ -e xorg-libglx.so ]; then
+ rm -f libglx.so
+ mv xorg-libglx.so libglx.so
+ else
+ rm -f libglx.so
+ fi
+ ;;
+ *)
+ echo "nothing to do for save_glx?"
+ exit 1
+ ;;
+ esac
+ cd "$CWD"
+}
+
+save_wfb(){
+ cd "$XMOD"
+ if [ -e libwfb.so ]; then
+ echo "Using existing Xorg libwfb..."
+ else
+ if [ "$1" = "nvidia" ]; then
+ ln -sf libwfb.so.$NV_VERSION libwfb.so.1
+ ln -sf libwfb.so.1 libwfb.so
+ fi
+ if [ "$1" = "xorg" ]; then
+ rm -f libwfb.so
+ rm -f libwfb.so.1
+ fi
+ fi
+ cd "$CWD"
+}
+
+nvidia_install(){
+ if [ ! -d $SAVELIBS ]; then
+ echo "Creating missing $SAVELIB ..."
+ mkdir -p $SAVELIBS
+ fi
+ echo $'Installing to nvidia-legacy390-driver files!\n'
+ echo "Make sure the nvidia driver is ENABLED in /etc/X11/xorg.conf"
+ echo "and in /etc/X11/xorg.conf.d."
+ echo "Otherwise, this may lead to improperly working drivers."
+
+ save_glx "nvidia"
+ save_GL "nvidia" $LIB
+ save_wfb "nvidia"
+# Check for multilib configuration
+ if [ "$COMPAT32" = "yes" ]; then
+ save_GL "nvidia" $LIB32
+ fi
+}
+
+nvidia_remove(){
+ echo $'Returning to stock xorg files!\n'
+ echo "Make sure the nvidia driver is DISABLED in /usr/share/X11/xorg.conf.d"
+ echo "/etc/X11/xorg.conf and in /etc/X11/xorg.conf.d."
+ echo "Otherwise, this may lead to improperly working drivers."
+
+ save_glx "xorg"
+ save_GL "xorg" $LIB
+ save_wfb "xorg"
+
+# Check for multilib configuration
+ if [ "$COMPAT32" = "yes" ]; then
+ save_GL "xorg" $LIB32
+ fi
+
+ if [ -e $NV_CONF ]; then
+ echo "removing $NV_CONF: you will need to provide your own"
+ echo "or reinstall nvidia-legacy390-driver."
+ rm -f $NV_CONF
+ fi
+}
+
+restore(){
+# Attempt to reinstall damaged stock packages if something went wrong.
+# Obviously, you will need to run this after '--remove' and before
+# 'removepkg nvidia-legacy390-driver'.
+# 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 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"
+else
+ ARCH="x86"
+fi
+
+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"
+# Note: The above is for stock 14.2; modify as needed for /patches or
+# multilib updates
+if [ -d $PKGPATH ]; then
+ if [ `find $PKGPATH -prune -empty -type d` ]; then
+ echo "Your $PKGPATH is empty!"
+ else
+ upgradepkg --reinstall --install-new $MESA $XORG
+ if [ "COMPAT32" = "yes" ]; then
+ upgradepkg --reinstall --install-new $MESA32
+ fi
+ fi
+else
+ echo "Please create $PKGPATH containing the appropriate packages"
+fi
+}
+
+usage(){
+ echo "Usage:"
+ 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
+ "--install")
+ nvidia_install
+ ;;
+ "--remove")
+ nvidia_remove
+ ;;
+ "--restore")
+ restore
+ ;;
+ "--help")
+ usage
+ ;;
+ *)
+ usage
+ ;;
+esac