X-Git-Url: https://git.pld-linux.org/?p=packages%2Fxorg-driver-video-nvidia.git;a=blobdiff_plain;f=xorg-driver-video-nvidia.spec;h=f921b1aa0152f9cd887ade0b8a7e5c61e0eaad7a;hp=42beae46fb60d573b9d795d0c27bc0f6e2e38c34;hb=ebb24c730d742ab49f6f7626c1221bec74c721d9;hpb=ba94a1cfeef5a8165c05fd5ccf063374af95cdef diff --git a/xorg-driver-video-nvidia.spec b/xorg-driver-video-nvidia.spec index 42beae4..f921b1a 100644 --- a/xorg-driver-video-nvidia.spec +++ b/xorg-driver-video-nvidia.spec @@ -1,92 +1,104 @@ # # Conditional build: %bcond_without dist_kernel # without distribution kernel +%bcond_without up # without up packages %bcond_without smp # without smp packages %bcond_without kernel # without kernel packages +%bcond_without incall # include all tarballs +%bcond_without userspace # don't build userspace programs %bcond_with verbose # verbose build (V=1) # +%define no_install_post_strip 1 +# %define _nv_ver 1.0 -%define _nv_rel 7167 +%define _nv_rel 9746 %define _min_x11 6.7.0 %define _rel 1 # +%define need_x86 0 +%define need_x8664 0 +%if %{with incall} +%define need_x86 1 +%define need_x8664 1 +%else +%ifarch %{ix86} +%define need_x86 1 +%endif +%ifarch %{x8664} +%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 -Name: X11-driver-nvidia +Name: xorg-driver-video-nvidia Version: %{_nv_ver}.%{_nv_rel} Release: %{_rel} License: nVidia Binary -Vendor: nVidia Corp. -Group: X11/XFree86 -# why not pkg0!? -Source0: http://download.nvidia.com/XFree86/Linux-x86/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-pkg1.run -# Source0-md5: d88d606873be255e8c4926961a1f09bf -Source1: http://download.nvidia.com/XFree86/Linux-x86_64/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86_64-%{_nv_ver}-%{_nv_rel}-pkg2.run -# Source1-md5: a0433d841c41862af266300b589c12a7 -Patch0: %{name}-gcc34.patch -Patch1: %{name}-GL.patch -Patch2: %{name}-conftest.patch -# http://www.minion.de/files/1.0-6629/ -Patch3: NVIDIA_kernel-1.0-7167-1233959.diff -Patch4: NVIDIA_kernel-1.0-7167-1237815.diff +Group: X11 +%if %{need_x86} +Source0: http://us.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://us.download.nvidia.com/XFree86/Linux-x86_64/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86_64-%{_nv_ver}-%{_nv_rel}-pkg2.run +# Source1-md5: c0afc66e1c21a9a54ba6719b8edd3166 +%endif +Source2: %{name}-xinitrc.sh +Patch0: X11-driver-nvidia-GL.patch +Patch1: X11-driver-nvidia-desktop.patch URL: http://www.nvidia.com/object/linux.html -BuildConflicts: XFree86-nvidia -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.153 +BuildRequires: rpmbuild(macros) >= 1.330 BuildRequires: sed >= 4.0 -BuildRequires: textutils -#BuildRequires: X11-devel >= %{_min_x11} # disabled for now -Requires: X11-Xserver -Requires: X11-libs >= %{_min_x11} -Requires: X11-modules >= %{_min_x11} -Provides: X11-OpenGL-core -Provides: X11-OpenGL-libGL -Provides: XFree86-OpenGL-core -Provides: XFree86-OpenGL-libGL +BuildConflicts: XFree86-nvidia +Requires: xorg-xserver-server +Provides: OpenGL = 1.5 +Provides: OpenGL-GLX +Provides: xorg-xserver-modules-libglx Obsoletes: Mesa -Obsoletes: X11-OpenGL-core -Obsoletes: X11-OpenGL-libGL -Obsoletes: XFree86-OpenGL-core -Obsoletes: XFree86-OpenGL-libGL +Obsoletes: X11-OpenGL-core < 1:7.0.0 +Obsoletes: X11-OpenGL-libGL < 1:7.0.0 +Obsoletes: XFree86-OpenGL-core < 1:7.0.0 +Obsoletes: XFree86-OpenGL-libGL < 1:7.0.0 Obsoletes: XFree86-driver-nvidia Obsoletes: XFree86-nvidia Conflicts: XFree86-OpenGL-devel <= 4.2.0-3 -ExclusiveArch: %{ix86} amd64 +ExclusiveArch: %{ix86} %{x8664} BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %define _noautoreqdep libGL.so.1 libGLcore.so.1 -%define _prefix /usr/X11R6 -%ifarch amd64 -%define _libdir32 %{_prefix}/lib -%endif %description -This driver set adds improved 2D functionality to the XFree86 4.0 X +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 XFree86 4.0 install and are not supported by this driver set. - -Software: Linux kernel >= 2.2.12, XFree86 >= 4.0. +the base Xorg/XFree86 install and are not supported by this driver +set. %description -l pl -Usprawnione sterowniki dla kart graficznych nVidia do serwera XFree86 -4.0, daj±ce wysokowydajn± akceleracjê OpenGL, obs³ugê AGP i wielu -monitorów 2D. +Usprawnione sterowniki dla kart graficznych nVidia do serwera +Xorg/XFree86, daj±ce wysokowydajn± akceleracjê OpenGL, obs³ugê AGP i +wielu monitorów 2D. -Obs³uguj± karty nVidia TNT/TNT2/GeForce/Quadro do serwera XFree86 4.0; -Karty nVidia NV1 i Riva 128/128ZX s± obs³ugiwane przez sterownik nv z -pakietów XFree86 - NIE s± obs³ugiwane przez ten pakiet. +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. %package devel Summary: OpenGL for X11R6 development (only gl?.h) Summary(pl): Pliki nag³ówkowe OpenGL dla systemu X11R6 (tylko gl?.h) Group: X11/Development/Libraries Requires: %{name} = %{version}-%{release} +Provides: OpenGL-GLX-devel +Provides: OpenGL-devel = 1.5 Provides: OpenGL-devel-base Obsoletes: OpenGL-devel-base Obsoletes: XFree86-driver-nvidia-devel @@ -103,8 +115,8 @@ sterownik Summary: Tools for advanced control of nVidia graphic cards Summary(pl): Narzêdzia do zarz±dzania kartami graficznymi nVidia Group: Applications/System -Obsoletes: XFree86-driver-nvidia-progs Requires: %{name} = %{version}-%{release} +Obsoletes: XFree86-driver-nvidia-progs %description progs Tools for advanced control of nVidia graphic cards. @@ -112,52 +124,50 @@ 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 Version: %{_nv_ver}.%{_nv_rel} Release: %{_rel}@%{_kernel_ver_str} Group: Base/Kernel -PreReq: modutils >= 2.3.18-2 Requires(post,postun): /sbin/depmod Requires: dev >= 2.7.7-10 %{?with_dist_kernel:%requires_releq_kernel_up} 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 XFree86 4. +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 Release: %{_rel}@%{_kernel_ver_str} Group: Base/Kernel -PreReq: modutils >= 2.3.18-2 Requires(post,postun): /sbin/depmod Requires: dev >= 2.7.7-10 %{?with_dist_kernel:%requires_releq_kernel_smp} 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 XFree86 4. +przez sterownik nVidii dla Xorg/XFree86. %prep cd %{_builddir} @@ -171,84 +181,66 @@ rm -rf NVIDIA-Linux-x86*-%{_nv_ver}-%{_nv_rel}-pkg* %endif %patch0 -p1 %patch1 -p1 -%patch2 -p1 -%patch3 -p0 -%patch4 -p0 -sed -i 's:-Wpointer-arith::' usr/src/nv/Makefile.kbuild +echo 'EXTRA_CFLAGS += -Wno-pointer-arith -Wno-sign-compare -Wno-unused' >> 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 rm -rf $RPM_BUILD_ROOT -install -d $RPM_BUILD_ROOT%{_libdir}/modules/{drivers,extensions} \ - $RPM_BUILD_ROOT{/usr/include/GL,/usr/%{_lib}/tls,%{_bindir}} -ln -sf $RPM_BUILD_ROOT%{_libdir} $RPM_BUILD_ROOT%{_prefix}/../lib +%if %{with userspace} +install -d $RPM_BUILD_ROOT%{_libdir}/xorg/modules/{drivers,extensions} \ + $RPM_BUILD_ROOT{%{_includedir}/GL,%{_libdir},%{_bindir},%{_mandir}/man1} \ + $RPM_BUILD_ROOT{%{_desktopdir},%{_pixmapsdir},/etc/X11/xinit/xinitrc.d} + +install usr/bin/nvidia-{settings,xconfig,bug-report.sh} $RPM_BUILD_ROOT%{_bindir} +install usr/share/man/man1/nvidia-{settings,xconfig}.* $RPM_BUILD_ROOT%{_mandir}/man1 +install usr/share/applications/nvidia-settings.desktop $RPM_BUILD_ROOT%{_desktopdir} +install usr/share/pixmaps/nvidia-settings.png $RPM_BUILD_ROOT%{_pixmapsdir} +install %{SOURCE2} $RPM_BUILD_ROOT/etc/X11/xinit/xinitrc.d/nvidia-settings.sh + +for f in \ + usr/lib/tls/libnvidia-tls.so.%{version} \ + usr/lib/libnvidia-cfg.so.%{version} \ + usr/lib/libGL{,core}.so.%{version} \ + usr/X11R6/lib/libXvMCNVIDIA.so.%{version} \ + usr/X11R6/lib/libXvMCNVIDIA.a \ +; do + install $f $RPM_BUILD_ROOT%{_libdir} +done -install usr/bin/nvidia-settings $RPM_BUILD_ROOT%{_bindir} -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} install usr/X11R6/lib/modules/extensions/libglx.so.%{version} \ - $RPM_BUILD_ROOT%{_libdir}/modules/extensions -%ifarch amd64 -# support for running 32-bit OpenGL applications on 64-bit AMD64 Linux installations -#install -d $RPM_BUILD_ROOT%{_libdir32} -#install usr/lib32%{?with_tls:/tls}/libnvidia-tls.so.%{version} $RPM_BUILD_ROOT%{_libdir32} -#install usr/lib32/libGL{,core}.so.%{version} $RPM_BUILD_ROOT%{_libdir32} -%endif + $RPM_BUILD_ROOT%{_libdir}/xorg/modules/extensions +install usr/X11R6/lib/modules/drivers/nvidia_drv.so \ + $RPM_BUILD_ROOT%{_libdir}/xorg/modules/drivers +install usr/X11R6/lib/modules/libnvidia-wfb.so.%{version} \ + $RPM_BUILD_ROOT%{_libdir}/xorg/modules -install usr/X11R6/lib/modules/drivers/nvidia_drv.o $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} +install usr/include/GL/*.h $RPM_BUILD_ROOT%{_includedir}/GL -ln -sf libGL.so.1 $RPM_BUILD_ROOT%{_libdir}/libGL.so -ln -sf libglx.so.%{version} $RPM_BUILD_ROOT%{_libdir}/modules/extensions/libglx.so +ln -sf libglx.so.%{version} $RPM_BUILD_ROOT%{_libdir}/xorg/modules/extensions/libglx.so ln -sf libXvMCNVIDIA.so.%{version} $RPM_BUILD_ROOT%{_libdir}/libXvMCNVIDIA.so +ln -sf libXvMCNVIDIA.so.%{version} $RPM_BUILD_ROOT%{_libdir}/libXvMCNVIDIA_dynamic.so.1 +ln -sf libnvidia-wfb.so.%{version} $RPM_BUILD_ROOT%{_libdir}/xorg/modules/wfb.so # OpenGL ABI for Linux compatibility -ln -sf %{_libdir}/libGL.so.1 $RPM_BUILD_ROOT/usr/%{_lib}/libGL.so.1 -ln -sf %{_libdir}/libGL.so $RPM_BUILD_ROOT/usr/%{_lib}/libGL.so +ln -sf libGL.so.%{version} $RPM_BUILD_ROOT%{_libdir}/libGL.so.1 +ln -sf libGL.so.1 $RPM_BUILD_ROOT%{_libdir}/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 @@ -271,62 +263,68 @@ 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} %files %defattr(644,root,root,755) %doc LICENSE -%doc usr/share/doc/{README,NVIDIA_Changelog,XF86Config.sample} -#%%lang(de) %doc usr/share/doc/README.DE -%attr(755,root,root) %{_libdir}/libGL.so.*.* +%doc usr/share/doc/{README.txt,NVIDIA_Changelog,XF86Config.sample,html} +# OpenGL ABI for Linux compatibility %attr(755,root,root) %{_libdir}/libGL.so +%attr(755,root,root) %{_libdir}/libGL.so.1 +# +%attr(755,root,root) %{_libdir}/libGL.so.*.* %attr(755,root,root) %{_libdir}/libGLcore.so.*.* %attr(755,root,root) %{_libdir}/libXvMCNVIDIA.so.*.* -%dir /usr/%{_lib}/tls -%attr(755,root,root) /usr/%{_lib}/libnvidia-tls.so.*.*.* -%attr(755,root,root) /usr/%{_lib}/tls/libnvidia-tls.so.*.*.* -%ifarch amd64 -# support for running 32-bit OpenGL applications on 64-bit AMD64 Linux installations -#dir %{_libdir32} -#attr(755,root,root) %{_libdir32}/libGL.so.*.* -#attr(755,root,root) %{_libdir32}/libGLcore.so.*.* -#attr(755,root,root) %{_libdir32}/libXvMCNVIDIA.so.*.* -#attr(755,root,root) %{_libdir32}/libnvidia-tls.so.*.*.* +%attr(755,root,root) %{_libdir}/libXvMCNVIDIA_dynamic.so.1 +%attr(755,root,root) %{_libdir}/libnvidia-cfg.so.*.*.* +%attr(755,root,root) %{_libdir}/libnvidia-tls.so.*.*.* +%attr(755,root,root) %{_libdir}/xorg/modules/libnvidia-wfb.so.*.*.* +%attr(755,root,root) %{_libdir}/xorg/modules/wfb.so +%attr(755,root,root) %{_libdir}/xorg/modules/drivers/nvidia_drv.so +%attr(755,root,root) %{_libdir}/xorg/modules/extensions/libglx.so* %endif -%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 %if %{with kernel} -%files -n kernel-video-nvidia +%if %{with up} || %{without dist_kernel} +%files -n kernel%{_alt_kernel}-video-nvidia %defattr(644,root,root,755) /lib/modules/%{_kernel_ver}/misc/*.ko* +%endif %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 %endif +%if %{with userspace} %files devel %defattr(644,root,root,755) %attr(755,root,root) %{_libdir}/libXvMCNVIDIA.so -/usr/include/GL/*.h +%{_includedir}/GL/*.h # -static %{_libdir}/libXvMCNVIDIA.a %files progs -%defattr(755,root,root,755) -%{_bindir}/nvidia-settings +%defattr(644,root,root,755) +%attr(755,root,root) %{_bindir}/nvidia-settings +%attr(755,root,root) %{_bindir}/nvidia-xconfig +%attr(755,root,root) %{_bindir}/nvidia-bug-report.sh +%attr(755,root,root) /etc/X11/xinit/xinitrc.d/*.sh +%{_desktopdir}/nvidia-settings.desktop +%{_mandir}/man1/nvidia-* +%{_pixmapsdir}/nvidia-settings.png +%endif