diff options
Diffstat (limited to 'media-video/nvidia-kernel')
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} +} |