diff options
Diffstat (limited to 'media-video/nvidia-glx')
6 files changed, 234 insertions, 1 deletions
diff --git a/media-video/nvidia-glx/ChangeLog b/media-video/nvidia-glx/ChangeLog index a4b24faa7ba4..b0e48f28ee9f 100644 --- a/media-video/nvidia-glx/ChangeLog +++ b/media-video/nvidia-glx/ChangeLog @@ -1,6 +1,16 @@ # ChangeLog for media-video/nvidia-glx # Copyright 2002-2004 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-glx/ChangeLog,v 1.57 2004/07/19 10:24:49 cyfred Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-glx/ChangeLog,v 1.58 2004/08/06 01:01:08 cyfred Exp $ + +*nvidia-glx-1.0.6111 (06 Aug 2004) + + 06 Aug 2004; Andrew Bevitt <cyfred@gentoo.org>; + +files/1.0.6111/NVIDIA_glx-1.0.6111-defines.patch, + +files/1.0.6111/NVIDIA_glx-1.0.6111-glheader.patch, + +files/1.0.6111/NVIDIA_glx-1.0.6111-makefile.patch, + +nvidia-glx-1.0.6111.ebuild: + Version bump for 6111; nVidia haven't changed their GL headers in this release + so still applying the patches *nvidia-glx-1.0.4499-r1 (19 Jul 2004) diff --git a/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-defines.patch b/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-defines.patch new file mode 100644 index 000000000000..da9933f6337c --- /dev/null +++ b/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-defines.patch @@ -0,0 +1,11 @@ +diff -ur NVIDIA_GLX-1.0-4191/usr/include/GL/glx.h NVIDIA_GLX-1.0-4191.new/usr/include/GL/glx.h +--- NVIDIA_GLX-1.0-4191/usr/include/GL/glx.h 2002-12-09 21:26:55.000000000 +0100 ++++ NVIDIA_GLX-1.0-4191.new/usr/include/GL/glx.h 2003-01-30 18:20:23.000000000 +0100 +@@ -39,6 +39,7 @@ + typedef XID GLXPixmap; + typedef XID GLXDrawable; + typedef XID GLXPbuffer; ++typedef XID GLXPbufferSGIX; + typedef XID GLXWindow; + typedef XID GLXFBConfigID; + diff --git a/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-glheader.patch b/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-glheader.patch new file mode 100644 index 000000000000..de1c49632c58 --- /dev/null +++ b/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-glheader.patch @@ -0,0 +1,14 @@ +--- usr/include/GL/gl.g.orig 2004-07-17 19:56:59.789410584 +1000 ++++ usr/include/GL/gl.h 2004-07-17 19:59:08.844791184 +1000 +@@ -66,6 +66,11 @@ + typedef double GLclampd; + typedef void GLvoid; + ++/* Patching for some better defines in the global system */ ++#define GL_VERSION_1_2 ++#define GL_VERSION_1_3 ++#define GL_VERSION_1_4 ++#include <GL/glext.h> + + /*************************************************************/ + diff --git a/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-makefile.patch b/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-makefile.patch new file mode 100644 index 000000000000..4f9396abaa13 --- /dev/null +++ b/media-video/nvidia-glx/files/1.0.6111/NVIDIA_glx-1.0.6111-makefile.patch @@ -0,0 +1,15 @@ +--- Makefile.old 2004-07-01 15:01:21.414466112 +1000 ++++ Makefile 2004-07-01 15:01:48.486350560 +1000 +@@ -1,11 +1,5 @@ + default: +- @ echo +- @ echo "It is NOT recommended that you use this Makefile to install" +- @ echo "the NVIDIA driver. Instead, please use the nvidia-installer" +- @ echo "utility. However, should nvidia-installer not operate for you," +- @ echo "you may use this Makefile as a last resort. To install using" +- @ echo "this Makefile, please run 'make install'." +- @ echo ++ @echo "nvidia-installer not used by Gentoo" + + kernel_module_install: + cd usr/src/nv; make install diff --git a/media-video/nvidia-glx/files/digest-nvidia-glx-1.0.6111 b/media-video/nvidia-glx/files/digest-nvidia-glx-1.0.6111 new file mode 100644 index 000000000000..891f45379b0a --- /dev/null +++ b/media-video/nvidia-glx/files/digest-nvidia-glx-1.0.6111 @@ -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-glx/nvidia-glx-1.0.6111.ebuild b/media-video/nvidia-glx/nvidia-glx-1.0.6111.ebuild new file mode 100644 index 000000000000..8d4cb1e2ce6d --- /dev/null +++ b/media-video/nvidia-glx/nvidia-glx-1.0.6111.ebuild @@ -0,0 +1,181 @@ +# Copyright 1999-2004 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-video/nvidia-glx/nvidia-glx-1.0.6111.ebuild,v 1.1 2004/08/06 01:01:08 cyfred Exp $ + +inherit eutils + +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="NVIDIA X11 driver and GLX libraries" +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}" + +LICENSE="NVIDIA" +SLOT="0" +KEYWORDS="-* ~x86 ~amd64" +RESTRICT="nostrip" +IUSE="multilib" + +DEPEND="virtual/libc + virtual/x11 + >=x11-base/opengl-update-1.8.1 + ~media-video/nvidia-kernel-${PV}" + +PDEPEND="amd64? ( multilib? ( >=app-emulation/emul-linux-x86-nvidia-${PV} ) )" + +PROVIDE="virtual/opengl" +export _POSIX2_VERSION="199209" + +pkg_setup() { + # We need xfree-4.2.0-r9 to support the dynamic libGL* stuff + if has_version "x11-base/xfree" + then + if has_version "<x11-base/xfree-4.2.0-r9" + then + die "Upgrade to xfree 4.2.0-r9 or greater." + fi + fi + # Provide some information to the users + if use amd64 ; then + einfo + einfo "This release of nvidia-glx contains 32 bit compatibility" + einfo "libraries. These can be installed by either" + einfo " 1) emerge app-emulation/emul-linux-x86-nvidia" + einfo " 2) USE=\"multilib\" emerge media-video/nvidia-glx" + einfo " (or /etc/portage/package.use, see portage manual)" + einfo + fi +} + +src_unpack() { + cd ${WORKDIR} + bash ${DISTDIR}/${NV_PACKAGE}-${PKG_V}.run --extract-only + + # Patchs go below here, add breif description + + cd ${S} + + # nVidia wants us to use nvidia-installer, removing warning. + epatch ${FILESDIR}/${PV}/NVIDIA_glx-${PV}-makefile.patch + # Use the correct defines to make gtkglext build work + epatch ${FILESDIR}/${PV}/NVIDIA_glx-${PV}-defines.patch + # Use some more sensible gl headers and make way for new glext.h + epatch ${FILESDIR}/${PV}/NVIDIA_glx-${PV}-glheader.patch +} + +src_install() { + local NV_ROOT="/usr/lib/opengl/nvidia" + + # The X module + exeinto /usr/X11R6/lib/modules/drivers + doexe usr/X11R6/lib/modules/drivers/nvidia_drv.o + + # The GLX extension + exeinto ${NV_ROOT}/extensions + newexe usr/X11R6/lib/modules/extensions/libglx.so.${PV} libglx.so + + # The GLX libraries + exeinto ${NV_ROOT}/lib + doexe usr/lib/libGL.so.${PV} \ + usr/lib/libGLcore.so.${PV} \ + usr/lib/libnvidia-tls.so.${PV} + dosym libGL.so.${PV} ${NV_ROOT}/lib/libGL.so + dosym libGL.so.${PV} ${NV_ROOT}/lib/libGL.so.1 + dosym libGLcore.so.${PV} ${NV_ROOT}/lib/libGLcore.so + dosym libGLcore.so.${PV} ${NV_ROOT}/lib/libGLcore.so.1 + dosym libnvidia-tls.so.${PV} ${NV_ROOT}/lib/libnvidia-tls.so + dosym libnvidia-tls.so.${PV} ${NV_ROOT}/lib/libnvidia-tls.so.1 + + local TLS_ROOT="/usr/lib/opengl/nvidia/tls" + dodir ${TLS_ROOT} + exeinto ${TLS_ROOT} + doexe usr/lib/tls/libnvidia-tls.so.${PV} + dosym libnvidia-tls.so.${PV} ${TLS_ROOT}/libnvidia-tls.so + dosym libnvidia-tls.so.${PV} ${TLS_ROOT}/libnvidia-tls.so.1 + + # Install tls_test + dodir /usr/lib/misc + exeinto /usr/lib/misc + doexe usr/bin/tls_test + doexe usr/bin/tls_test_dso.so + + insinto /usr/X11R6/lib + doins usr/X11R6/lib/libXvMCNVIDIA.a + exeinto /usr/X11R6/lib + doexe usr/X11R6/lib/libXvMCNVIDIA.so.${PV} + + # Closing bug #37517 by letting virtual/x11 provide system wide glext.h + # 16 July 2004, opengl-update is now supplying glext.h for system wide + # compatibility, so we still need to remove this. + rm -f usr/include/GL/glext.h + + # Includes + insinto ${NV_ROOT}/include + doins usr/include/GL/*.h + + # Docs, remove nvidia-settings as provided by media-video/nvidia-settings + rm -f usr/share/doc/nvidia-settings* + dodoc usr/share/doc/* + + # nVidia want bug reports using this script + exeinto /usr/bin + doexe usr/bin/nvidia-bug-report.sh + + # Not sure whether installing the .la file is neccessary; + # this is adopted from the `nvidia' ebuild + local ver1="`echo ${PV} |cut -d '.' -f 1`" + local ver2="`echo ${PV} |cut -d '.' -f 2`" + local ver3="`echo ${PV} |cut -d '.' -f 3`" + sed -e "s:\${PV}:${PV}:" \ + -e "s:\${ver1}:${ver1}:" \ + -e "s:\${ver2}:${ver2}:" \ + -e "s:\${ver3}:${ver3}:" \ + ${FILESDIR}/libGL.la.2 > ${D}/${NV_ROOT}/lib/libGL.la + + # Should we install the .la for the 32bit libs on amd64? I think not. +} + +pkg_preinst() { + # Clean the dinamic libGL stuff's home to ensure + # we dont have stale libs floating around + if [ -d ${ROOT}/usr/lib/opengl/nvidia ] + then + rm -rf ${ROOT}/usr/lib/opengl/nvidia/* + fi + # Make sure we nuke the old nvidia-glx's env.d file + if [ -e ${ROOT}/etc/env.d/09nvidia ] + then + rm -f ${ROOT}/etc/env.d/09nvidia + fi +} + +pkg_postinst() { + #switch to the nvidia implementation + if [ "${ROOT}" = "/" ] + then + /usr/sbin/opengl-update nvidia + fi + + echo + einfo "To use the Nvidia GLX, run \"opengl-update nvidia\"" + echo + einfo "You may also be interested in media-video/nvidia-settings" + echo + einfo "nVidia have requested that any bug reports submitted have the" + einfo "output of /usr/bin/nvidia-bug-report.sh included." +} |