diff options
Diffstat (limited to 'media-video/nvidia-kernel')
-rw-r--r-- | media-video/nvidia-kernel/ChangeLog | 11 | ||||
-rw-r--r-- | media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.4191-r1 | 1 | ||||
-rw-r--r-- | media-video/nvidia-kernel/nvidia-kernel-1.0.4191-r1.ebuild | 122 |
3 files changed, 133 insertions, 1 deletions
diff --git a/media-video/nvidia-kernel/ChangeLog b/media-video/nvidia-kernel/ChangeLog index dd83a56f8eac..a7da7d1c51b6 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 Gentoo Technologies, Inc.; Distributed under the GPL -# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-kernel/ChangeLog,v 1.15 2002/12/14 15:55:42 azarah Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-kernel/ChangeLog,v 1.16 2002/12/18 21:15:07 styx Exp $ + +*nvidia-kernel-1.0.4191-1 (18 Dec 2002) + + 18 Dec 2002; Joachim Blaabjerg <styx@gentoo.org> + nvidia-kernel-1.0.4191-1.ebuild : + + Adding ${FILESDIR}/${NV_PACKAGE}-rmap.diff, so it works with rmap kernels as + well. It's all #ifdef'ed, so it shouldn't interfere with other AA kernels. + Bumping anyway, per vapier's instructions ;) 14 Dec 2002; Martin Schlemmer <azarah@gentoo.org> nvidia-kernel-1.0.4191.ebuild: As it seems this version need MTRR support for most chipsets, die if its not diff --git a/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.4191-r1 b/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.4191-r1 new file mode 100644 index 000000000000..37e8dd61fb58 --- /dev/null +++ b/media-video/nvidia-kernel/files/digest-nvidia-kernel-1.0.4191-r1 @@ -0,0 +1 @@ +MD5 47967b5bd30fedabaaa2ffa6751792ce NVIDIA_kernel-1.0-4191.tar.gz 612129 diff --git a/media-video/nvidia-kernel/nvidia-kernel-1.0.4191-r1.ebuild b/media-video/nvidia-kernel/nvidia-kernel-1.0.4191-r1.ebuild new file mode 100644 index 000000000000..852d5e288665 --- /dev/null +++ b/media-video/nvidia-kernel/nvidia-kernel-1.0.4191-r1.ebuild @@ -0,0 +1,122 @@ +# Copyright 1999-2002 Gentoo Technologies, Inc. +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-kernel/nvidia-kernel-1.0.4191-r1.ebuild,v 1.1 2002/12/18 21:15:07 styx Exp $ + +inherit eutils + +# Make sure Portage does _NOT_ strip symbols. Need both lines for +# Portage 1.8.9+ +DEBUG="yes" +RESTRICT="nostrip" + +NV_V="${PV/1.0./1.0-}" +NV_PACKAGE="NVIDIA_kernel-${NV_V}" +S="${WORKDIR}/${NV_PACKAGE}" +DESCRIPTION="Linux kernel module for the NVIDIA's X driver" +SRC_URI="http://download.nvidia.com/XFree86_40/${NV_V}/${NV_PACKAGE}.tar.gz" +HOMEPAGE="http://www.nvidia.com/" + +# The slow needs to be set to $KV to prevent unmerges of +# modules for other kernels. +LICENSE="NVIDIA" +SLOT="${KV}" +KEYWORDS="~x86 -ppc -sparc -alpha" + +DEPEND="virtual/linux-sources + >=sys-apps/portage-1.9.10" + + +pkg_setup() { + if [ ! -f /proc/mtrr ] + then + eerror "This version needs MTRR support for most chisets!" + 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 +} + +src_unpack() { + unpack ${A} + + # Next section applies patches for linux-2.5 kernel, or if + # linux-2.4, the page_alloc.c patch courtesy of NVIDIA Corporation. + # All these are from: + # + # http://www.minion.de/nvidia/ + # + # Many thanks to Christian Zander <zander@minion.de> for bringing + # these to us, and being so helpful to select which to use. + # This should close bug #9704. + +# local KV_major="`uname -r | cut -d. -f1`" +# local KV_minor="`uname -r | cut -d. -f2`" +# +# cd ${S} +# if [ "${KV_major}" -eq 2 -a "${KV_minor}" -eq 5 ] +# then +# EPATCH_SINGLE_MSG="Applying tasklet patch for kernel 2.5..." \ +# epatch ${FILESDIR}/${NV_PACKAGE}-2.5-tl.diff +# EPATCH_SINGLE_MSG="Applying page_alloc.c patch..." \ +# epatch ${FILESDIR}/${NV_PACKAGE}-2.5-tl-pa.diff +# else +# EPATCH_SINGLE_MSG="Applying page_alloc.c patch..." \ +# epatch ${FILESDIR}/${NV_PACKAGE}-pa.diff +# fi + + # This is a minor patch to make it work with rmap enabled kernels + EPATCH_SINGLE_MSG="Applying rmap compat patch for kernel 2.4..." + epatch ${FILESDIR}/${NV_PACKAGE}-rmap.diff +} + +src_compile() { + # Portage should determine the version of the kernel sources + check_KV + #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" KERNDIR="/usr/src/linux" \ + clean nvidia.o || die +} + +src_install() { + # The driver goes into the standard modules location + insinto /lib/modules/${KV}/video + doins nvidia.o + + # 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 ] && [ -x /sbin/NVmakedevices.sh ] + then + /sbin/NVmakedevices.sh >/dev/null 2>&1 + fi + fi + + echo + einfo "If you are not using devfs, loading the module automatically at" + einfo "boot up, you need to add \"nvidia\" to your /etc/modules.autoload." + echo + ewarn "Please note that the driver name changed from \"NVdriver\"" + ewarn "to \"nvidia.o\"." + echo +} + |