summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'media-video/nvidia-kernel')
-rw-r--r--media-video/nvidia-kernel/ChangeLog11
-rw-r--r--media-video/nvidia-kernel/Manifest6
-rw-r--r--media-video/nvidia-kernel/files/1.0.6111/conftest_koutput_includes.patch22
-rw-r--r--media-video/nvidia-kernel/files/1.0.6629/conftest_koutput_includes.patch22
-rw-r--r--media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.6111-r32
-rw-r--r--media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.66292
-rw-r--r--media-video/nvidia-kernel/nvidia-kernel-1.0.6111-r3.ebuild194
-rw-r--r--media-video/nvidia-kernel/nvidia-kernel-1.0.6629.ebuild182
8 files changed, 440 insertions, 1 deletions
diff --git a/media-video/nvidia-kernel/ChangeLog b/media-video/nvidia-kernel/ChangeLog
index 86bfbbd15855..ac0f880b516d 100644
--- a/media-video/nvidia-kernel/ChangeLog
+++ b/media-video/nvidia-kernel/ChangeLog
@@ -1,6 +1,15 @@
# ChangeLog for media-video/nvidia-kernel
# Copyright 2002-2004 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-kernel/ChangeLog,v 1.92 2004/11/06 05:05:34 cyfred Exp $
+# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-kernel/ChangeLog,v 1.93 2004/11/07 01:52:46 cyfred Exp $
+
+*nvidia-kernel-1.0.6111-r3 (07 Nov 2004)
+
+ 07 Nov 2004; Andrew Bevitt <cyfred@gentoo.org>
+ +files/1.0.6111/conftest_koutput_includes.patch,
+ +files/1.0.6629/conftest_koutput_includes.patch,
+ +nvidia-kernel-1.0.6111-r3.ebuild, +nvidia-kernel-1.0.6629.ebuild:
+ New version 1.0.6629! Also marking 1.0.6111 stable in -r3 (others to be
+ keyword masked in following commit).
06 Nov 2004; Andrew Bevitt <cyfred@gentoo.org>;
files/1.0.6111/power-suspend-2.6.9-changes.patch:
diff --git a/media-video/nvidia-kernel/Manifest b/media-video/nvidia-kernel/Manifest
index b548c82a57a7..84542e6d8d1f 100644
--- a/media-video/nvidia-kernel/Manifest
+++ b/media-video/nvidia-kernel/Manifest
@@ -1,4 +1,5 @@
MD5 8ce6e8510b5396c685ad67f806351d36 nvidia-kernel-1.0.6106-r1.ebuild 3622
+MD5 d182e547e31dc7a01af472f0c66cae5d nvidia-kernel-1.0.6629.ebuild 5694
MD5 b4a7988f8e10107742f255ea291478c0 nvidia-kernel-1.0.4499.ebuild 4028
MD5 0f6787ff3195ae6452dd584a199e3e31 nvidia-kernel-1.0.6111-r2.ebuild 4113
MD5 c65724336acbdb77c80842d7a9174301 nvidia-kernel-1.0.5332-r1.ebuild 4256
@@ -6,6 +7,7 @@ MD5 99bfcd484af08a27fbf2ea071b0943db nvidia-kernel-1.0.6111-r1.ebuild 3916
MD5 1e48aaa4989010b59109e1c81cd9741f nvidia-kernel-1.0.6111.ebuild 3723
MD5 f189c720f21a41c73a6c292ffec6cdfd nvidia-kernel-1.0.5328-r1.ebuild 4461
MD5 20f6ae4f9076cd8f5dd1d2383d0eaca7 nvidia-kernel-1.0.4496-r3.ebuild 4286
+MD5 a611242828d00a14abefefc1b6989693 nvidia-kernel-1.0.6111-r3.ebuild 6334
MD5 d5bc3ba053815cd1b559cba6bbd36452 nvidia-kernel-1.0.4363-r3.ebuild 4071
MD5 c48678134e8b2bfdab6383ed28c127d1 ChangeLog 22381
MD5 c84a79e7d9b69a204003fb8c2dbaad01 metadata.xml 297
@@ -16,8 +18,10 @@ MD5 1316f73c0eecd8832bb362a3d5ca4892 files/digest-nvidia-kernel-1.0.5336-r4 80
MD5 50ffea0f5eb12d252905f379bc7be2d6 files/digest-nvidia-kernel-1.0.6106-r1 163
MD5 ed1e098d85579c75542ef0a49ee4dd5c files/digest-nvidia-kernel-1.0.6111-r1 163
MD5 ed1e098d85579c75542ef0a49ee4dd5c files/digest-nvidia-kernel-1.0.6111-r2 163
+MD5 ed1e098d85579c75542ef0a49ee4dd5c files/digest-nvidia-kernel-1.0.6111-r3 163
MD5 046ed3744551619863faea8c5c83db02 files/digest-nvidia-kernel-1.0.4499 74
MD5 ed1e098d85579c75542ef0a49ee4dd5c files/digest-nvidia-kernel-1.0.6111 163
+MD5 8a4687b0fc3e7cc0b36c247697d94701 files/digest-nvidia-kernel-1.0.6629 163
MD5 56ebaa3ba92e9db848baea746a6aef1a files/digest-nvidia-kernel-1.0.4363-r3 74
MD5 a88479c177f936b6ef19fc73bb39d149 files/digest-nvidia-kernel-1.0.4496-r3 80
MD5 b6a9c4bdd3961980af4a70f57485d708 files/nvidia-1.1 441
@@ -38,7 +42,9 @@ MD5 5dc4b9a2463cb459721ae3e642f6239f files/1.0.5336/NVIDIA_kernel-1.0-5336-fix-m
MD5 7bf40e44b8f2181a1047ddfd13acd6b3 files/1.0.5336/NVIDIA_kernel-1.0-5336-basic-sysfs-support.patch 5439
MD5 bc61be48f85d84f91d2035fa3cc92a47 files/1.0.6106/NVIDIA_kernel-1.0-6106-koutput-support.patch 6659
MD5 762e6f6e16aa6dd5b2469e99fe8decd3 files/1.0.6111/nv-pci_find_class.patch 2903
+MD5 b5b7f947ffb9e6c19f7457ff7c14d0db files/1.0.6111/conftest_koutput_includes.patch 1082
MD5 14924b09123b075f910c73316baff848 files/1.0.6111/power-suspend-2.6.9-changes.patch 856
MD5 5177339888e44bb5f4b6124fa5830e7f files/1.0.6111/vmalloc-reserve.patch 542
MD5 29eafcaf7ab5d59dd90d3d3243bf57c3 files/1.0.6111/nv_enable_pci.patch 3640
MD5 c2b155f40d7b904f07550e8e326969c2 files/1.0.6111/nv-remap-range.patch 5715
+MD5 dbf80a2cbaf69a10521429e1b2a7e10c files/1.0.6629/conftest_koutput_includes.patch 1082
diff --git a/media-video/nvidia-kernel/files/1.0.6111/conftest_koutput_includes.patch b/media-video/nvidia-kernel/files/1.0.6111/conftest_koutput_includes.patch
new file mode 100644
index 000000000000..c1991cccccd5
--- /dev/null
+++ b/media-video/nvidia-kernel/files/1.0.6111/conftest_koutput_includes.patch
@@ -0,0 +1,22 @@
+--- conftest.sh.old 2004-11-07 12:24:54.733276104 +1100
++++ conftest.sh 2004-11-07 12:25:56.672859856 +1100
+@@ -17,7 +17,7 @@
+
+ if [ "$OUTPUT" != "$SOURCES" ]; then
+ CFLAGS="$CFLAGS -I$OUTPUT/include2 -I$OUTPUT/include \
+--I$HEADERS -I$HEADERS/asm/mach-default"
++-I$HEADERS -I$OUTPUT/include2/asm/mach-default"
+ else
+ CFLAGS="$CFLAGS -I$HEADERS -I$HEADERS/asm/mach-default"
+ fi
+@@ -257,8 +257,8 @@
+ echo "installed on your system. If you specified a separate";
+ echo "output directory using either the \"KBUILD_OUTPUT\" or";
+ echo "the \"O\" KBUILD parameter, make sure to specify this";
+- echo "directory with the SYSOUT environment variable or with";
+- echo "the appropriate nvidia-installer command line option.";
++ echo "directorys _PARENT_ with the KBUILD_OUTPUT_PREFIX";
++ echo "environment variable, (or see /etc/env.d/05kernel)";
+ echo "";
+ if [ "$VERBOSE" = "full_output" ]; then
+ echo "*** Unable to determine the target kernel version. ***";
diff --git a/media-video/nvidia-kernel/files/1.0.6629/conftest_koutput_includes.patch b/media-video/nvidia-kernel/files/1.0.6629/conftest_koutput_includes.patch
new file mode 100644
index 000000000000..193485bcf497
--- /dev/null
+++ b/media-video/nvidia-kernel/files/1.0.6629/conftest_koutput_includes.patch
@@ -0,0 +1,22 @@
+--- conftest.sh.old 2004-11-07 12:20:02.776660256 +1100
++++ conftest.sh 2004-11-07 12:23:32.432787680 +1100
+@@ -17,7 +17,7 @@
+
+ if [ "$OUTPUT" != "$SOURCES" ]; then
+ CFLAGS="$CFLAGS -I$OUTPUT/include2 -I$OUTPUT/include \
+--I$HEADERS -I$HEADERS/asm/mach-default"
++-I$HEADERS -I$OUTPUT/include2/asm/mach-default"
+ else
+ CFLAGS="$CFLAGS -I$HEADERS -I$HEADERS/asm/mach-default"
+ fi
+@@ -260,8 +260,8 @@
+ echo "installed on your system. If you specified a separate";
+ echo "output directory using either the \"KBUILD_OUTPUT\" or";
+ echo "the \"O\" KBUILD parameter, make sure to specify this";
+- echo "directory with the SYSOUT environment variable or with";
+- echo "the appropriate nvidia-installer command line option.";
++ echo "directorys _PARENT_ with the KBUILD_OUTPUT_PREFIX";
++ echo "environment variable, (or see /etc/env.d/05kernel)";
+ echo "";
+ if [ "$VERBOSE" = "full_output" ]; then
+ echo "*** Unable to determine the target kernel version. ***";
diff --git a/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.6111-r3 b/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.6111-r3
new file mode 100644
index 000000000000..891f45379b0a
--- /dev/null
+++ b/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.6111-r3
@@ -0,0 +1,2 @@
+MD5 51e83be46f83c52102ccb8995b54f4e2 NVIDIA-Linux-x86-1.0-6111-pkg1.run 8167999
+MD5 6c7b0c8b3ce5c34186e0c80042e6d046 NVIDIA-Linux-x86_64-1.0-6111-pkg2.run 7333486
diff --git a/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.6629 b/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.6629
new file mode 100644
index 000000000000..9324510b4ef9
--- /dev/null
+++ b/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.6629
@@ -0,0 +1,2 @@
+MD5 f7737c1e95371f37a4fd30da2f11e72c NVIDIA-Linux-x86-1.0-6629-pkg1.run 8725221
+MD5 652e69f549c81a7a3f2806daa74b9c36 NVIDIA-Linux-x86_64-1.0-6629-pkg2.run 7777882
diff --git a/media-video/nvidia-kernel/nvidia-kernel-1.0.6111-r3.ebuild b/media-video/nvidia-kernel/nvidia-kernel-1.0.6111-r3.ebuild
new file mode 100644
index 000000000000..762ff0f1ed18
--- /dev/null
+++ b/media-video/nvidia-kernel/nvidia-kernel-1.0.6111-r3.ebuild
@@ -0,0 +1,194 @@
+# Copyright 1999-2004 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-kernel/nvidia-kernel-1.0.6111-r3.ebuild,v 1.1 2004/11/07 01:52:46 cyfred Exp $
+
+inherit eutils kernel-mod
+
+X86_PKG_V="pkg1"
+AMD64_PKG_V="pkg2"
+NV_V="${PV/1.0./1.0-}"
+X86_NV_PACKAGE="NVIDIA-Linux-x86-${NV_V}"
+AMD64_NV_PACKAGE="NVIDIA-Linux-x86_64-${NV_V}"
+
+DESCRIPTION="Linux kernel module for the NVIDIA X11 driver"
+HOMEPAGE="http://www.nvidia.com/"
+SRC_URI="x86? (ftp://download.nvidia.com/XFree86/Linux-x86/${NV_V}/${X86_NV_PACKAGE}-${X86_PKG_V}.run)
+ amd64? (http://download.nvidia.com/XFree86/Linux-x86_64/${NV_V}/${AMD64_NV_PACKAGE}-${AMD64_PKG_V}.run)"
+
+if use x86; then
+ PKG_V="${X86_PKG_V}"
+ NV_PACKAGE="${X86_NV_PACKAGE}"
+elif use amd64; then
+ PKG_V="${AMD64_PKG_V}"
+ NV_PACKAGE="${AMD64_NV_PACKAGE}"
+fi
+
+S="${WORKDIR}/${NV_PACKAGE}-${PKG_V}/usr/src/nv"
+
+# The slot needs to be set to $KV to prevent unmerges of modules for other kernels.
+LICENSE="NVIDIA"
+SLOT="${KV}"
+KEYWORDS="-* x86 amd64"
+RESTRICT="nostrip"
+IUSE=""
+
+DEPEND="virtual/linux-sources"
+export _POSIX2_VERSION="199209"
+
+KMOD_SOURCES="none"
+
+# Check for mtrr and react appropriately
+mtrr_check() {
+ if [ ! -f /proc/mtrr ]
+ then
+ eerror "This version needs MTRR support for most chipsets!"
+ eerror "Please enable MTRR support in your kernel config, found at:"
+ eerror
+ eerror " Processor type and features -> [*] MTRR (Memory Type Range Register) support"
+ eerror
+ eerror "and recompile your kernel ..."
+ die "MTRR support not detected!"
+ fi
+}
+
+pkg_setup() {
+ mtrr_check
+}
+
+src_unpack() {
+ # setup the environment
+ kernel-mod_getversion
+ if [ ${KV_MINOR} -ge 5 ]
+ then
+ KV_OBJ="ko"
+ else
+ KV_OBJ="o"
+ fi
+
+ # 2.6.10_rc1-mm{1,2,3} all EXPORT_SYMBOL_GPL the udev functions, this breaks loading
+ CS="$(grep -c EXPORT_SYMBOL\(class_simple_create\)\; ${KERNEL_DIR}/drivers/base/class_simple.c)"
+ if [ "${CS}" == "0" ]
+ then
+ ewarn "Your current kernel uses EXPORT_SYMBOL_GPL() on some methods required by nvidia-kernel"
+ ewarn "This probably means 2.6.10_rc1-mm*, please change away from mm-sources until this is"
+ ewarn "revised and a solution released in the mm branch, development-sources will work."
+ die "Incompatible kernel export."
+ fi
+
+ # Right, we are officially not supporting < 2.6.7 in the 2.6 kernel tree
+ # In fact as this warning states its highly likely you CANNOT use those kernels
+ if [ ${KV_MINOR} -ge 6 -a ${KV_PATCH} -lt 7 ]
+ then
+ echo
+ ewarn "Your kernel version is ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
+ ewarn "This is not officially supported for ${P}. It is likely you"
+ ewarn "will not be able to compile or use the kernel module."
+ ewarn "It is recommended that you upgrade your kernel to a version >= 2.6.7"
+ echo
+ ewarn "DO NOT file bug reports for kernel versions less than 2.6.7 as they will be ignored."
+ fi
+
+ cd ${WORKDIR}
+ bash ${DISTDIR}/${NV_PACKAGE}-${PKG_V}.run --extract-only
+
+ # Add patches below, with a breif description.
+ # 1) SYSFS supported by nvidia
+ # 2) minion.de patches not released yet
+
+ cd ${S}
+
+ # Fix up the removal of PM_SAVE_STATE in kernels > 2.6.8
+ epatch ${FILESDIR}/${PV}/power-suspend-2.6.9-changes.patch
+ # Update pci stuff to work with irqroutes being changed in kernels
+ epatch ${FILESDIR}/${PV}/nv_enable_pci.patch
+ # Fix VMALLOC_RESERVE issues with the new 2.6.9 release candidates
+ epatch ${FILESDIR}/${PV}/vmalloc-reserve.patch
+ # Port pci_find_class() -> pci_get_class() for >= 2.6.9-rc2
+ epatch ${FILESDIR}/${PV}/nv-pci_find_class.patch
+ # Fix remap_page_range() -> remap_pfn_range() for >= 2.6.9-rc2
+ epatch ${FILESDIR}/${PV}/nv-remap-range.patch
+ # Fix the /usr/src/linux/include/asm not existing on koutput issue #58294
+ epatch ${FILESDIR}/${PV}/conftest_koutput_includes.patch
+
+ # if you set this then it's your own fault when stuff breaks :)
+ [ ! -z "${USE_CRAZY_OPTS}" ] && sed -i "s:-O:${CFLAGS}:" Makefile.*
+}
+
+src_compile() {
+ # Right as kmod was deprecated there is little room for kbuild but lets
+ # at least have some sembalance of support for those who are forcing
+ # a non-standard build directory.
+ if [ ${KV_MINOR} -ge 6 -a ${KV_PATCH} -ge 7 ]
+ then
+ # Is this really needed?
+ unset ARCH
+
+ if [ -n "${KBUILD_OUTPUT_PREFIX}" ]
+ then
+ einfo "Determining kernel output location"
+ OUTPUT="${KBUILD_OUTPUT_PREFIX}/${KV_VERSION_FULL}"
+ fi
+ fi
+ [ -z "${OUTPUT}" ] && OUTPUT=${KERNEL_DIR}
+ einfo "Using ${OUTPUT} as kernel output location"
+ echo
+ # Now its possible that we might be here without using a KBUILD kernel
+ # (ie the variable is set, but using non-kbuild kernel or different path)
+ if [ ! -d ${OUTPUT} ]
+ then
+ ewarn "Your system global KBUILD_OUTPUT is set to ${KBUILD_OUTPUT_PREFIX}"
+ ewarn "However your kernels output path ${OUTPUT} does not exist."
+ echo
+ ewarn "Using ${KERNEL_DIR} as your kernel output location."
+ echo
+ OUTPUT=${KERNEL_DIR}
+ fi
+
+ # IGNORE_CC_MISMATCH disables a sanity check that's needed when gcc has been
+ # updated but the running kernel is still compiled with an older gcc. This is
+ # needed for chrooted building, where the sanity check detects the gcc of the
+ # kernel outside the chroot rather than within.
+ make IGNORE_CC_MISMATCH="yes" SYSSRC="${KERNEL_DIR}" SYSOUT="${OUTPUT}" \
+ clean module V=1 || die "Failed to build module"
+}
+
+src_install() {
+ # The driver goes into the standard modules location
+ insinto /lib/modules/${KV}/video
+
+ # Insert the module
+ doins nvidia.${KV_OBJ}
+
+ # Add the aliases
+ insinto /etc/modules.d
+ newins ${FILESDIR}/nvidia-1.1 nvidia
+
+ # Docs
+ dodoc ${S}/README
+
+ # The device creation script
+ into /
+ newsbin ${S}/makedevices.sh NVmakedevices.sh
+}
+
+pkg_postinst() {
+ if [ "${ROOT}" = "/" ]
+ then
+ # Update module dependency
+ [ -x /usr/sbin/update-modules ] && /usr/sbin/update-modules
+ if [ ! -e /dev/.devfsd ] && [ ! -e /dev/.udev ] && [ -x /sbin/NVmakedevices.sh ]
+ then
+ /sbin/NVmakedevices.sh >/dev/null 2>&1
+ fi
+ fi
+
+ echo
+ einfo "If you need to load the module automatically on boot up you need"
+ einfo "to add \"nvidia\" to /etc/modules.autoload.d/kernel-${KV_MAJOR}.${KV_MINOR}"
+ echo
+ einfo "Please note that the driver name is \"nvidia\", not \"NVdriver\""
+ echo
+ einfo "This module will now work correctly under udev, you do not need to"
+ einfo "manually create the devices anymore."
+ echo
+}
diff --git a/media-video/nvidia-kernel/nvidia-kernel-1.0.6629.ebuild b/media-video/nvidia-kernel/nvidia-kernel-1.0.6629.ebuild
new file mode 100644
index 000000000000..a3c7dd076005
--- /dev/null
+++ b/media-video/nvidia-kernel/nvidia-kernel-1.0.6629.ebuild
@@ -0,0 +1,182 @@
+# Copyright 1999-2004 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-kernel/nvidia-kernel-1.0.6629.ebuild,v 1.1 2004/11/07 01:52:46 cyfred Exp $
+
+inherit eutils kernel-mod
+
+X86_PKG_V="pkg1"
+AMD64_PKG_V="pkg2"
+NV_V="${PV/1.0./1.0-}"
+X86_NV_PACKAGE="NVIDIA-Linux-x86-${NV_V}"
+AMD64_NV_PACKAGE="NVIDIA-Linux-x86_64-${NV_V}"
+
+DESCRIPTION="Linux kernel module for the NVIDIA X11 driver"
+HOMEPAGE="http://www.nvidia.com/"
+SRC_URI="x86? (ftp://download.nvidia.com/XFree86/Linux-x86/${NV_V}/${X86_NV_PACKAGE}-${X86_PKG_V}.run)
+ amd64? (http://download.nvidia.com/XFree86/Linux-x86_64/${NV_V}/${AMD64_NV_PACKAGE}-${AMD64_PKG_V}.run)"
+
+if use x86; then
+ PKG_V="${X86_PKG_V}"
+ NV_PACKAGE="${X86_NV_PACKAGE}"
+elif use amd64; then
+ PKG_V="${AMD64_PKG_V}"
+ NV_PACKAGE="${AMD64_NV_PACKAGE}"
+fi
+
+S="${WORKDIR}/${NV_PACKAGE}-${PKG_V}/usr/src/nv"
+
+# The slot needs to be set to $KV to prevent unmerges of modules for other kernels.
+LICENSE="NVIDIA"
+SLOT="${KV}"
+KEYWORDS="-* ~x86 ~amd64"
+RESTRICT="nostrip"
+IUSE=""
+
+DEPEND="virtual/linux-sources"
+export _POSIX2_VERSION="199209"
+
+KMOD_SOURCES="none"
+
+mtrr_check() {
+ if [ ! -f /proc/mtrr ]
+ then
+ eerror "This version needs MTRR support for most chipsets!"
+ eerror "Please enable MTRR support in your kernel config, found at:"
+ eerror
+ eerror " Processor type and features -> [*] MTRR (Memory Type Range Register) support"
+ eerror
+ eerror "and recompile your kernel ..."
+ die "MTRR support not detected!"
+ fi
+}
+
+pkg_setup() {
+ mtrr_check
+}
+
+src_unpack() {
+ # Setup the environment
+ kernel-mod_getversion
+ if [ ${KV_MINOR} -ge 5 ]
+ then
+ KV_OBJ="ko"
+ else
+ KV_OBJ="o"
+ fi
+
+ # 2.6.10_rc1-mm{1,2,3} all EXPORT_SYMBOL_GPL the udev functions, this breaks loading
+ CS="$(grep -c EXPORT_SYMBOL\(class_simple_create\)\; ${KERNEL_DIR}/drivers/base/class_simple.c)"
+ if [ "${CS}" == "0" ]
+ then
+ ewarn "Your current kernel uses EXPORT_SYMBOL_GPL() on some methods required by nvidia-kernel"
+ ewarn "This probably means 2.6.10_rc1-mm*, please change away from mm-sources until this is"
+ ewarn "revised and a solution released in the mm branch, development-sources will work."
+ die "Incompatible kernel export."
+ fi
+
+ if [ ${KV_MINOR} -ge 6 -a ${KV_PATCH} -lt 7 ]
+ then
+ echo
+ ewarn "Your kernel version is ${KV_MAJOR}.${KV_MINOR}.${KV_PATCH}"
+ ewarn "This is not officially supported for ${P}. It is likely you"
+ ewarn "will not be able to compile or use the kernel module."
+ ewarn "It is recommended that you upgrade your kernel to a version >= 2.6.7"
+ echo
+ ewarn "DO NOT file bug reports for kernel versions less than 2.6.7 as they will be ignored."
+ fi
+
+ cd ${WORKDIR}
+ bash ${DISTDIR}/${NV_PACKAGE}-${PKG_V}.run --extract-only
+
+ # Add patches below, with a breif description.
+ cd ${S}
+ # Fix the /usr/src/linux/include/asm not existing on koutput issue #58294
+ epatch ${FILESDIR}/${PV}/conftest_koutput_includes.patch
+
+ # if you set this then it's your own fault when stuff breaks :)
+ [ ! -z "${USE_CRAZY_OPTS}" ] && sed -i "s:-O:${CFLAGS}:" Makefile.*
+}
+
+src_compile() {
+ # Right as kmod was deprecated there is little room for kbuild but lets
+ # at least have some sembalance of support for those who are forcing
+ # a non-standard build directory.
+ if [ ${KV_MINOR} -ge 6 -a ${KV_PATCH} -ge 7 ]
+ then
+ # Is this even needed at all?
+ unset ARCH
+
+ # Find the kbuild output
+ if [ -n "${KBUILD_OUTPUT_PREFIX}" ]
+ then
+ echo
+ einfo "Determining kernel output location"
+ OUTPUT="${KBUILD_OUTPUT_PREFIX}/${KV_VERSION_FULL}"
+ fi
+ fi
+ [ -z "${OUTPUT}" ] && OUTPUT=${KERNEL_DIR}
+ einfo "Using ${OUTPUT} as kernel output location"
+ echo
+ # Now its possible that we might be here without using a KBUILD kernel
+ # (ie the variable is set, but using non-kbuild kernel or different path)
+ if [ ! -d ${OUTPUT} ]
+ then
+ ewarn "Your system global KBUILD_OUTPUT is set to ${KBUILD_OUTPUT_PREFIX}"
+ ewarn "However your kernels output path ${OUTPUT} does not exist."
+ echo
+ ewarn "Using ${KERNEL_DIR} as your kernel output location."
+ echo
+ OUTPUT=${KERNEL_DIR}
+ fi
+
+ # IGNORE_CC_MISMATCH disables a sanity check that's needed when gcc has been
+ # updated but the running kernel is still compiled with an older gcc. This is
+ # needed for chrooted building, where the sanity check detects the gcc of the
+ # kernel outside the chroot rather than within.
+ make IGNORE_CC_MISMATCH="yes" SYSSRC="${KERNEL_DIR}" SYSOUT="${OUTPUT}" \
+ clean module V=1 || die "Failed to build module"
+}
+
+src_install() {
+ # The driver goes into the standard modules location
+ insinto /lib/modules/${KV}/video
+
+ # Insert the module
+ doins nvidia.${KV_OBJ}
+
+ # Add the aliases
+ insinto /etc/modules.d
+ newins ${FILESDIR}/nvidia-1.1 nvidia
+
+ # Docs
+ dodoc ${S}/README
+
+ # The device creation script
+ into /
+ newsbin ${S}/makedevices.sh NVmakedevices.sh
+}
+
+pkg_postinst() {
+ if [ "${ROOT}" = "/" ]
+ then
+ # Update module dependency
+ [ -x /usr/sbin/update-modules ] && /usr/sbin/update-modules
+ if [ ! -e /dev/.devfsd ] && [ ! -e /dev/.udev ] && [ -x /sbin/NVmakedevices.sh ]
+ then
+ /sbin/NVmakedevices.sh >/dev/null 2>&1
+ fi
+ fi
+
+ echo
+ einfo "If you need to load the module automatically on boot up you need"
+ einfo "to add \"nvidia\" to /etc/modules.autoload.d/kernel-${KV_MAJOR}.${KV_MINOR}"
+ echo
+ einfo "Please note that the driver name is \"nvidia\", not \"NVdriver\""
+ echo
+ einfo "This module will now work correctly under udev, you do not need to"
+ einfo "manually create the devices anymore."
+ echo
+ einfo "Checking kernel module dependencies"
+ test -r "${ROOT}/usr/src/linux/System.map" && \
+ depmod -ae -F "${ROOT}/usr/src/linux/System.map" -b "${ROOT}" -r ${KV}
+}