X-Git-Url: http://git.pld-linux.org/?a=blobdiff_plain;f=X11-driver-nvidia.spec;h=7093a21bdf2c199e163cc67bb09fb0b68506f836;hb=0f9f638e51434be25c4c5cdf63f0496a969f4982;hp=150aef84473bbf0b82010f44c4bfd4dd4f871aa8;hpb=fbb29b2ab1522a9f2f42160c1c7ba8eabc30837f;p=packages%2FX11-driver-nvidia.git diff --git a/X11-driver-nvidia.spec b/X11-driver-nvidia.spec index 150aef8..7093a21 100644 --- a/X11-driver-nvidia.spec +++ b/X11-driver-nvidia.spec @@ -1,3 +1,5 @@ +# TODO +# - missing CC quotes somewhere: ccache: invalid option -- S # # Conditional build: %bcond_without dist_kernel # without distribution kernel @@ -6,9 +8,14 @@ %bcond_without incall # include all tarballs %bcond_without userspace # don't build userspace programs %bcond_with verbose # verbose build (V=1) +%bcond_with grsec_kernel # build for kernel-grsecurity +# +%if %{with kernel} && %{with dist_kernel} && %{with grsec_kernel} +%define alt_kernel grsecurity +%endif # %define _nv_ver 1.0 -%define _nv_rel 7676 +%define _nv_rel 9746 %define _min_x11 6.7.0 %define _rel 1 # @@ -25,37 +32,36 @@ %define need_x8664 1 %endif %endif -# -Summary: Linux Drivers for nVidia TNT/TNT2/GeForce/Quadro Chips -Summary(pl): Sterowniki do kart graficznych nVidia TNT/TNT2/GeForce/Quadro +Summary: Linux Drivers for NVIDIA GeForce/Quadro Chips +Summary(pl): Sterowniki do kart graficznych NVIDIA GeForce/Quadro Name: X11-driver-nvidia Version: %{_nv_ver}.%{_nv_rel} Release: %{_rel} License: nVidia Binary -Vendor: nVidia Corp. -Group: X11/XFree86 +Group: X11 # why not pkg0!? %if %{need_x86} -Source0: http://download.nvidia.com/XFree86/Linux-x86/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-pkg0.run -# Source0-md5: 2474c5513006668b0fba401e042dc009 +Source0: http://download.nvidia.com/XFree86/Linux-x86/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-pkg1.run +# Source0-md5: cf0cdbd9099a6df028de429044e7f4da %endif %if %{need_x8664} -Source1: http://download.nvidia.com/XFree86/Linux-x86_64/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86_64-%{_nv_ver}-%{_nv_rel}-pkg0.run -# Source1-md5: 06a0a2d06c7f849510b4682d9d13946a +Source1: http://download.nvidia.com/XFree86/Linux-x86_64/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86_64-%{_nv_ver}-%{_nv_rel}-pkg1.run +# Source1-md5: 6af676cc903bff3bc141098a47f78182 %endif -Patch0: %{name}-gcc34.patch -Patch1: %{name}-GL.patch -Patch2: %{name}-conftest.patch +Source2: %{name}-settings.desktop +Source3: %{name}-xinitrc.sh +Patch0: %{name}-GL.patch +Patch1: %{name}-conftest.patch # http://www.minion.de/files/1.0-6629/ URL: http://www.nvidia.com/object/linux.html -BuildRequires: grep -%{?with_dist_kernel:BuildRequires: kernel-module-build >= 2.6.7} +%if %{with kernel} +%{?with_dist_kernel:BuildRequires: kernel%{_alt_kernel}-module-build >= 3:2.6.7} +%endif BuildRequires: %{kgcc_package} -BuildRequires: rpmbuild(macros) >= 1.213 -BuildRequires: sed >= 4.0 -BuildRequires: textutils #BuildRequires: X11-devel >= %{_min_x11} # disabled for now +BuildRequires: rpmbuild(macros) >= 1.330 +BuildRequires: sed >= 4.0 BuildConflicts: XFree86-nvidia Requires: X11-Xserver Requires: X11-libs >= %{_min_x11} @@ -77,29 +83,34 @@ BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %define _noautoreqdep libGL.so.1 libGLcore.so.1 %define _prefix /usr/X11R6 +%define _mandir %{_prefix}/man %ifarch %{x8664} %define _libdir32 %{_prefix}/lib %endif %description -This driver set adds improved 2D functionality to the Xorg/XFree86 X -server as well as high performance OpenGL acceleration, AGP support, -support for most flat panels, and 2D multiple monitor support. - -Hardware: nVidia TNT, TNT2, GeForce, or Quadro based graphics -accelerator. The nVidia NV1 and RIVA 128/128ZX chips are supported in -the base Xorg/XFree86 install and are not supported by this driver -set. +This driver set adds improved 2D functionality to the Xorg X server as +well as high performance OpenGL acceleration, AGP support, support for +most flat panels, and 2D multiple monitor support. Supported hardware: +modern NVIDIA GeForce (from GeForce2 MX) and Quadro (Quadro4 and up) +based graphics accelerators. + +The older graphics chips are unsupported: +- NV1 and RIVA 128/128ZX chips are supported in the base Xorg install + (nv driver) +- TNT/TNT2/GeForce 256/GeForce2 Ultra/Quadro2 are suported by -legacy + drivers. %description -l pl -Usprawnione sterowniki dla kart graficznych nVidia do serwera -Xorg/XFree86, daj±ce wysokowydajn± akceleracjê OpenGL, obs³ugê AGP i -wielu monitorów 2D. +Usprawnione sterowniki dla kart graficznych NVIDIA do serwera Xorg, +daj±ce wysokowydajn± akceleracjê OpenGL, obs³ugê AGP i wielu monitorów +2D. Obs³uguj± w miarê nowe karty NVIDIA GeForce (od wersji GeForce2 +MX) oraz Quadro (od wersji Quadro4) do serwera Xorg/XFree86. -Obs³uguj± karty nVidia TNT/TNT2/GeForce/Quadro do serwera -Xorg/XFree86; Karty nVidia NV1 i Riva 128/128ZX s± obs³ugiwane przez -sterownik nv z pakietów Xorg/XFree8 - NIE s± obs³ugiwane przez ten -pakiet. +Starsze uk³ady graficzne NVIDIA nie s± obs³ugiwane przez ten pakiet: +- NV1 i Riva 128/128ZX s± obs³ugiwane przez sterownik nv z Xorg. +- TNT/TNT2/GeForce 256/GeForce2 Ultra/Quadro2 obs³ugiwane s± przez + sterownik NVIDIA w wersji -legacy. %package devel Summary: OpenGL for X11R6 development (only gl?.h) @@ -131,7 +142,7 @@ Tools for advanced control of nVidia graphic cards. %description progs -l pl Narzêdzia do zarz±dzania kartami graficznymi nVidia. -%package -n kernel-video-nvidia +%package -n kernel%{_alt_kernel}-video-nvidia Summary: nVidia kernel module for nVidia Architecture support Summary(de): Das nVidia-Kern-Modul für die nVidia-Architektur-Unterstützung Summary(pl): Modu³ j±dra dla obs³ugi kart graficznych nVidia @@ -144,17 +155,17 @@ Requires: dev >= 2.7.7-10 Provides: X11-driver-nvidia(kernel) Obsoletes: XFree86-nvidia-kernel -%description -n kernel-video-nvidia +%description -n kernel%{_alt_kernel}-video-nvidia nVidia Architecture support for Linux kernel. -%description -n kernel-video-nvidia -l de +%description -n kernel%{_alt_kernel}-video-nvidia -l de Die nVidia-Architektur-Unterstützung für den Linux-Kern. -%description -n kernel-video-nvidia -l pl +%description -n kernel%{_alt_kernel}-video-nvidia -l pl Obs³uga architektury nVidia dla j±dra Linuksa. Pakiet wymagany przez sterownik nVidii dla Xorg/XFree86. -%package -n kernel-smp-video-nvidia +%package -n kernel%{_alt_kernel}-smp-video-nvidia Summary: nVidia kernel module for nVidia Architecture support Summary(de): Das nVidia-Kern-Modul für die nVidia-Architektur-Unterstützung Summary(pl): Modu³ j±dra dla obs³ugi kart graficznych nVidia @@ -166,13 +177,13 @@ Requires: dev >= 2.7.7-10 Provides: X11-driver-nvidia(kernel) Obsoletes: XFree86-nvidia-kernel -%description -n kernel-smp-video-nvidia +%description -n kernel%{_alt_kernel}-smp-video-nvidia nVidia Architecture support for Linux kernel SMP. -%description -n kernel-smp-video-nvidia -l de +%description -n kernel%{_alt_kernel}-smp-video-nvidia -l de Die nVidia-Architektur-Unterstützung für den Linux-Kern SMP. -%description -n kernel-smp-video-nvidia -l pl +%description -n kernel%{_alt_kernel}-smp-video-nvidia -l pl Obs³uga architektury nVidia dla j±dra Linuksa SMP. Pakiet wymagany przez sterownik nVidii dla Xorg/XFree86. @@ -181,44 +192,26 @@ cd %{_builddir} rm -rf NVIDIA-Linux-x86*-%{_nv_ver}-%{_nv_rel}-pkg* %ifarch %{ix86} /bin/sh %{SOURCE0} --extract-only -%setup -qDT -n NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-pkg0 +%setup -qDT -n NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-pkg1 %else /bin/sh %{SOURCE1} --extract-only -%setup -qDT -n NVIDIA-Linux-x86_64-%{_nv_ver}-%{_nv_rel}-pkg0 +%setup -qDT -n NVIDIA-Linux-x86_64-%{_nv_ver}-%{_nv_rel}-pkg1 %endif %patch0 -p1 -%patch1 -p1 -%patch2 -p1 +#%patch1 -p1 sed -i 's:-Wpointer-arith::' usr/src/nv/Makefile.kbuild %build %if %{with kernel} cd usr/src/nv/ ln -sf Makefile.kbuild Makefile -for cfg in %{?with_dist_kernel:%{?with_smp:smp} up}%{!?with_dist_kernel:nondist}; do - if [ ! -r "%{_kernelsrcdir}/config-$cfg" ]; then - exit 1 - fi - rm -rf include - install -d include/{linux,config} - ln -sf %{_kernelsrcdir}/config-$cfg .config - ln -sf %{_kernelsrcdir}/include/linux/autoconf-$cfg.h include/linux/autoconf.h - ln -sf %{_kernelsrcdir}/include/asm-%{_target_base_arch} include/asm - touch include/config/MARKER - %{__make} -C %{_kernelsrcdir} clean \ - RCS_FIND_IGNORE="-name '*.ko' -o -name nv-kernel.o -o" \ - SYSSRC=%{_kernelsrcdir} \ - SYSOUT=$PWD \ - M=$PWD O=$PWD \ - %{?with_verbose:V=1} - %{__make} -C %{_kernelsrcdir} modules \ - CC="%{__cc}" CPP="%{__cpp}" \ - SYSSRC=%{_kernelsrcdir} \ - SYSOUT=$PWD \ - M=$PWD O=$PWD \ - %{?with_verbose:V=1} - mv nvidia.ko nvidia-$cfg.ko -done +cat >> Makefile <<'EOF' + +$(obj)/nv-kernel.o: $(src)/nv-kernel.o.bin + cp $< $@ +EOF +mv nv-kernel.o{,.bin} +%build_kernel_modules -m nvidia %endif %install @@ -226,11 +219,17 @@ rm -rf $RPM_BUILD_ROOT %if %{with userspace} install -d $RPM_BUILD_ROOT%{_libdir}/modules/{drivers,extensions} \ - $RPM_BUILD_ROOT{/usr/include/GL,/usr/%{_lib}/tls,%{_bindir}} + $RPM_BUILD_ROOT{/usr/include/GL,/usr/%{_lib}/tls,%{_bindir},%{_mandir}/man1} \ + $RPM_BUILD_ROOT{%{_pixmapsdir},%{_desktopdir},/etc/X11/xinit/xinitrc.d} ln -sf $RPM_BUILD_ROOT%{_libdir} $RPM_BUILD_ROOT%{_prefix}/../lib install usr/bin/nvidia-settings $RPM_BUILD_ROOT%{_bindir} +install usr/bin/nvidia-xconfig $RPM_BUILD_ROOT%{_bindir} +install usr/share/pixmaps/nvidia-settings.png $RPM_BUILD_ROOT%{_pixmapsdir} +install usr/share/man/man1/nvidia-[sx]* $RPM_BUILD_ROOT%{_mandir}/man1 +install %{SOURCE2} $RPM_BUILD_ROOT%{_desktopdir}/nvidia-settings.desktop +install %{SOURCE3} $RPM_BUILD_ROOT/etc/X11/xinit/xinitrc.d/nvidia-settings.sh install usr/lib/libnvidia-tls.so.%{version} $RPM_BUILD_ROOT/usr/%{_lib} install usr/lib/tls/libnvidia-tls.so.%{version} $RPM_BUILD_ROOT/usr/%{_lib}/tls install usr/lib/libGL{,core}.so.%{version} $RPM_BUILD_ROOT%{_libdir} @@ -243,11 +242,10 @@ install usr/X11R6/lib/modules/extensions/libglx.so.%{version} \ #install usr/lib32/libGL{,core}.so.%{version} $RPM_BUILD_ROOT%{_libdir32} %endif -install usr/X11R6/lib/modules/drivers/nvidia_drv.o $RPM_BUILD_ROOT%{_libdir}/modules/drivers +install usr/X11R6/lib/modules/drivers/nvidia_drv.so $RPM_BUILD_ROOT%{_libdir}/modules/drivers install usr/X11R6/lib/libXvMCNVIDIA.so.%{version} $RPM_BUILD_ROOT%{_libdir} install usr/X11R6/lib/libXvMCNVIDIA.a $RPM_BUILD_ROOT%{_libdir} install usr/include/GL/*.h $RPM_BUILD_ROOT/usr/include/GL -#install usr/bin/nvidia-settings $RPM_BUILD_ROOT%{_bindir} ln -sf libGL.so.1 $RPM_BUILD_ROOT%{_libdir}/libGL.so ln -sf libglx.so.%{version} $RPM_BUILD_ROOT%{_libdir}/modules/extensions/libglx.so @@ -259,14 +257,7 @@ ln -sf %{_libdir}/libGL.so $RPM_BUILD_ROOT/usr/%{_lib}/libGL.so %endif %if %{with kernel} -cd usr/src/nv/ -install -d $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}{,smp}/misc -install nvidia-%{?with_dist_kernel:up}%{!?with_dist_kernel:nondist}.ko \ - $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/misc/nvidia.ko -%if %{with smp} && %{with dist_kernel} -install nvidia-smp.ko \ - $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/misc/nvidia.ko -%endif +%install_kernel_modules -m usr/src/nv/nvidia -d misc %endif %clean @@ -289,16 +280,16 @@ EOF %postun -p /sbin/ldconfig -%post -n kernel-video-nvidia +%post -n kernel%{_alt_kernel}-video-nvidia %depmod %{_kernel_ver} -%postun -n kernel-video-nvidia +%postun -n kernel%{_alt_kernel}-video-nvidia %depmod %{_kernel_ver} -%post -n kernel-smp-video-nvidia +%post -n kernel%{_alt_kernel}-smp-video-nvidia %depmod %{_kernel_ver}smp -%postun -n kernel-smp-video-nvidia +%postun -n kernel%{_alt_kernel}-smp-video-nvidia %depmod %{_kernel_ver}smp %if %{with userspace} @@ -325,16 +316,16 @@ EOF %attr(755,root,root) /usr/%{_lib}/libGL.so.1 %attr(755,root,root) /usr/%{_lib}/libGL.so %attr(755,root,root) %{_libdir}/modules/extensions/libglx.so* -%attr(755,root,root) %{_libdir}/modules/drivers/nvidia_drv.o +%attr(755,root,root) %{_libdir}/modules/drivers/nvidia_drv.so %endif %if %{with kernel} -%files -n kernel-video-nvidia +%files -n kernel%{_alt_kernel}-video-nvidia %defattr(644,root,root,755) /lib/modules/%{_kernel_ver}/misc/*.ko* %if %{with smp} && %{with dist_kernel} -%files -n kernel-smp-video-nvidia +%files -n kernel%{_alt_kernel}-smp-video-nvidia %defattr(644,root,root,755) /lib/modules/%{_kernel_ver}smp/misc/*.ko* %endif @@ -350,6 +341,10 @@ EOF %files progs %defattr(644,root,root,755) -%doc usr/share/doc/nvidia-settings-user-guide.txt %attr(755,root,root) %{_bindir}/nvidia-settings +%attr(755,root,root) %{_bindir}/nvidia-xconfig +%attr(755,root,root) /etc/X11/xinit/xinitrc.d/*.sh +%{_desktopdir}/*.desktop +%{_mandir}/man1/* +%{_pixmapsdir}/* %endif