summaryrefslogtreecommitdiffstats
path: root/system/nvidia-driver/nvidia-switch
diff options
context:
space:
mode:
Diffstat (limited to 'system/nvidia-driver/nvidia-switch')
-rw-r--r--system/nvidia-driver/nvidia-switch111
1 files changed, 49 insertions, 62 deletions
diff --git a/system/nvidia-driver/nvidia-switch b/system/nvidia-driver/nvidia-switch
index f92f6837cf..82eaf53932 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