diff options
6 files changed, 194 insertions, 0 deletions
diff --git a/system/nvidia-legacy173-kernel/NVIDIA-173.14.12-2.6.27.patch b/system/nvidia-legacy173-kernel/NVIDIA-173.14.12-2.6.27.patch new file mode 100644 index 0000000000..1ba936b509 --- /dev/null +++ b/system/nvidia-legacy173-kernel/NVIDIA-173.14.12-2.6.27.patch @@ -0,0 +1,87 @@ +diff -Nru NVIDIA-Linux-x86-173.14.12-pkg0.orig/usr/src/nv/nv.c NVIDIA-Linux-x86-173.14.12-pkg0/usr/src/nv/nv.c +--- usr/src/nv/nv.c 2008-07-18 03:42:50.000000000 +0200 ++++ NVIDIA-Linux-x86-173.14.12-pkg0/usr/src/nv/nv.c 2008-08-12 00:35:45.000000000 +0200 +@@ -1296,14 +1296,22 @@ + if (get_cpu() == cpu) + __nv_setup_pat_entries(NULL); + else ++ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) ++ smp_call_function(__nv_setup_pat_entries, hcpu, 1); ++ #else + smp_call_function(__nv_setup_pat_entries, hcpu, 1, 1); ++ #endif + put_cpu(); + break; + case CPU_DOWN_PREPARE: + if (get_cpu() == cpu) + __nv_restore_pat_entries(NULL); + else ++ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) ++ smp_call_function(__nv_restore_pat_entries, hcpu, 1); ++ #else + smp_call_function(__nv_restore_pat_entries, hcpu, 1, 1); ++ #endif + put_cpu(); + break; + } +diff -Nru NVIDIA-Linux-x86-173.14.12-pkg0.orig/usr/src/nv/nv-linux.h NVIDIA-Linux-x86-173.14.12-pkg0/usr/src/nv/nv-linux.h +--- usr/src/nv/nv-linux.h 2008-07-18 03:42:51.000000000 +0200 ++++ NVIDIA-Linux-x86-173.14.12-pkg0/usr/src/nv/nv-linux.h 2008-08-12 00:44:27.000000000 +0200 +@@ -104,7 +104,10 @@ + #endif + + #include <linux/spinlock.h> ++#if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) ++#else + #include <asm/semaphore.h> ++#endif + #include <linux/completion.h> + #include <linux/highmem.h> + +@@ -665,13 +668,21 @@ + #if defined(preempt_disable) + preempt_disable(); + #endif ++ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) ++ ret = smp_call_function(func, info, 1); ++ #else + ret = smp_call_function(func, info, 1, 1); ++ #endif + func(info); + #if defined(preempt_enable) + preempt_enable(); + #endif + #else ++ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) ++ ret = on_each_cpu(func, info, 1); ++ #else + ret = on_each_cpu(func, info, 1, 1); ++ #endif + #endif + return ret; + } +diff -Nru NVIDIA-Linux-x86-173.14.12-pkg0.orig/usr/src/nv/os-interface.c NVIDIA-Linux-x86-173.14.12-pkg0/usr/src/nv/os-interface.c +--- usr/src/nv/os-interface.c 2008-07-18 03:42:50.000000000 +0200 ++++ NVIDIA-Linux-x86-173.14.12-pkg0/usr/src/nv/os-interface.c 2008-08-12 00:48:07.000000000 +0200 +@@ -48,7 +48,11 @@ + #endif + local_bh_disable(); + atomic_set(&os_smp_barrier, 1); ++ #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 27) ++ ret = smp_call_function(ipi_handler, NULL, 0); ++ #else + ret = smp_call_function(ipi_handler, NULL, 1, 0); ++ #endif + #endif + return (ret == 0) ? RM_OK : RM_ERROR; + } +@@ -704,7 +708,9 @@ + U032 sig + ) + { ++ #if LINUX_VERSION_CODE <= KERNEL_VERSION(2, 6, 26) + return kill_proc(pid, sig, 1) ? RM_ERR_OPERATING_SYSTEM : RM_OK; ++ #endif + } + + /*******************************************************************************/ diff --git a/system/nvidia-legacy173-kernel/README b/system/nvidia-legacy173-kernel/README new file mode 100644 index 0000000000..59570a0bbc --- /dev/null +++ b/system/nvidia-legacy173-kernel/README @@ -0,0 +1,2 @@ +This is the kernel-module needed by the proprietary binary nvidia driver. +You also need the nvidia-legacy173-driver package from SlackBuilds.org. diff --git a/system/nvidia-legacy173-kernel/doinst.sh b/system/nvidia-legacy173-kernel/doinst.sh new file mode 100644 index 0000000000..79891f9acd --- /dev/null +++ b/system/nvidia-legacy173-kernel/doinst.sh @@ -0,0 +1,3 @@ + +chroot . /sbin/depmod -a + diff --git a/system/nvidia-legacy173-kernel/nvidia-legacy173-kernel.SlackBuild b/system/nvidia-legacy173-kernel/nvidia-legacy173-kernel.SlackBuild new file mode 100644 index 0000000000..95050a1b62 --- /dev/null +++ b/system/nvidia-legacy173-kernel/nvidia-legacy173-kernel.SlackBuild @@ -0,0 +1,76 @@ +#!/bin/sh + +# Slackware build script for nvidia-kernel + +# Copyright 2007-2008 Heinz Wiesinger <pprkut@liwjatan.at> +# 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. + +# Thanks to Robby Workman for suggestions to improve this script. + +KERNELVERSION=${KERNELVERSION:-$(uname -r)} +KERNELPATH=${KERNELPATH:-/lib/modules/${KERNELVERSION}/build} + +VERSION=173.14.12 +NAME=NVIDIA-Linux-x86-$VERSION-pkg1 +PKG_NAME=nvidia-legacy173-kernel +PKG_VERS=${VERSION}_$(echo $KERNELVERSION | tr - _) + +ARCH=${ARCH:-i486} +BUILD=${BUILD:-1} +TAG=${TAG:-_SBo} + +CWD=$(pwd) +TMP=${TMP:-/tmp/SBo} +PKG=${PKG:-$TMP/package-$PKG_NAME} +OUTPUT=${OUTPUT:-/tmp} + +rm -rf $PKG +mkdir -p $TMP $PKG $OUTPUT +cd $TMP || exit 1 +rm -rf $NAME +sh $CWD/$NAME.run --extract-only || exit 1 +cd $NAME || exit 1 +chown -R root:root . +chmod -R u+w,go+r-w,a-s . + +cd usr/src/nv/ || exit 1 + +if [ "${KERNELVERSION:0:6}" = "2.6.27" ]; then + patch -i $CWD/NVIDIA-$VERSION-2.6.27.patch +fi + +make SYSSRC=$KERNELPATH module || exit 1 + +# It seems better as DESTDIR doesn't work here, to install the module manually. +#make SYSSRC=$KERNELPATH install DESTDIR=$PKG || exit 1 + +mkdir -p $PKG/lib/modules/$KERNELVERSION/kernel/drivers/video +install -m 0664 nvidia.ko $PKG/lib/modules/$KERNELVERSION/kernel/drivers/video/ + +mkdir -p $PKG/usr/doc/$PKG_NAME-$PKG_VERS +cp -a README $PKG/usr/doc/$PKG_NAME-$PKG_VERS +cat $CWD/$PKG_NAME.SlackBuild > $PKG/usr/doc/$PKG_NAME-$PKG_VERS/$PKG_NAME.SlackBuild + +mkdir -p $PKG/install +cat $CWD/slack-desc > $PKG/install/slack-desc +cat $CWD/doinst.sh > $PKG/install/doinst.sh + +cd $PKG +/sbin/makepkg -l y -c n $OUTPUT/$PKG_NAME-$PKG_VERS-$ARCH-$BUILD$TAG.tgz diff --git a/system/nvidia-legacy173-kernel/nvidia-legacy173-kernel.info b/system/nvidia-legacy173-kernel/nvidia-legacy173-kernel.info new file mode 100644 index 0000000000..771e449003 --- /dev/null +++ b/system/nvidia-legacy173-kernel/nvidia-legacy173-kernel.info @@ -0,0 +1,8 @@ +PRGNAM="nvidia-legacy173-kernel" +VERSION="173.14.12" +HOMEPAGE="http://www.nvidia.com" +DOWNLOAD="http://us.download.nvidia.com/XFree86/Linux-x86/173.14.12/NVIDIA-Linux-x86-173.14.12-pkg1.run" +MD5SUM="c099b6e15ef34187571403fb017d58a1" +MAINTAINER="ppr:kut" +EMAIL="pprkut@liwjatan.at" +APPROVED="dsomero" diff --git a/system/nvidia-legacy173-kernel/slack-desc b/system/nvidia-legacy173-kernel/slack-desc new file mode 100644 index 0000000000..92bb68211d --- /dev/null +++ b/system/nvidia-legacy173-kernel/slack-desc @@ -0,0 +1,18 @@ +# HOW TO EDIT THIS FILE: +# The "handy ruler" below makes it easier to edit a package description. Line +# up the first '|' above the ':' following the base package name, and the '|' +# on the right side marks the last column you can put a character in. You must +# make exactly 11 lines for the formatting to be correct. It's also +# customary to leave one space after the ':'. + + |-----handy-ruler-------------------------------------| +nvidia-legacy173-kernel: nvidia-legacy173-kernel (nvidia driver kernel module) +nvidia-legacy173-kernel: +nvidia-legacy173-kernel: This is the kernel module needed by the binary +nvidia-legacy173-kernel: nvidia-driver. +nvidia-legacy173-kernel: +nvidia-legacy173-kernel: +nvidia-legacy173-kernel: +nvidia-legacy173-kernel: +nvidia-legacy173-kernel: +nvidia-legacy173-kernel: |