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=6567a173b2f9f19423801a525e165b030854d19e;hp=1835d926a2740b499b5271d654a1053d4cfa92d7;hb=22d6cc34be2d8a74e6e73c5b86faca34a2b303a1;hpb=d4a34ce279cf0e8e82301e389844b8b5d0002317 diff --git a/xorg-driver-video-nvidia.spec b/xorg-driver-video-nvidia.spec index 1835d92..6567a17 100644 --- a/xorg-driver-video-nvidia.spec +++ b/xorg-driver-video-nvidia.spec @@ -2,15 +2,30 @@ # Conditional build: %bcond_without dist_kernel # without distribution kernel %bcond_without smp # without smp packages +%bcond_without kernel # without kernel packages +%bcond_without incall # include all tarballs %bcond_with verbose # verbose build (V=1) -%bcond_with tls # install libraries with tls support # %define _nv_ver 1.0 -%define _nv_rel 6106 -%define _nv_pkg pkg1 +%define _nv_rel 7667 %define _min_x11 6.7.0 -%define _rel 1 +%define _rel 3 # +%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 @@ -19,26 +34,35 @@ Release: %{_rel} License: nVidia Binary Vendor: nVidia Corp. Group: X11/XFree86 -Source0: http://download.nvidia.com/XFree86/Linux-x86/%{_nv_ver}-%{_nv_rel}/NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-%{_nv_pkg}.run -# Source0-md5: 5432f919f0211ce36b854d87108d7db0 +# 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: 1d062204da2902ae86154a03e1a40204 +%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: fa4e143a3193c0bd9cd697eb8637b354 +%endif Patch0: %{name}-gcc34.patch +Patch1: %{name}-GL.patch +Patch2: %{name}-conftest.patch +# http://www.minion.de/files/1.0-6629/ URL: http://www.nvidia.com/object/linux.html BuildConflicts: XFree86-nvidia BuildRequires: grep %{?with_dist_kernel:BuildRequires: kernel-module-build >= 2.6.7} BuildRequires: %{kgcc_package} -BuildRequires: rpmbuild(macros) >= 1.153 +BuildRequires: rpmbuild(macros) >= 1.213 +BuildRequires: sed >= 4.0 BuildRequires: textutils -Requires: X11-driver-nvidia(kernel) +#BuildRequires: X11-devel >= %{_min_x11} # disabled for now Requires: X11-Xserver Requires: X11-libs >= %{_min_x11} Requires: X11-modules >= %{_min_x11} -%{?with_tls:Requires: glibc(tls)} Provides: X11-OpenGL-core Provides: X11-OpenGL-libGL Provides: XFree86-OpenGL-core Provides: XFree86-OpenGL-libGL -Provides: XFree86-driver-nvidia Obsoletes: Mesa Obsoletes: X11-OpenGL-core Obsoletes: X11-OpenGL-libGL @@ -47,11 +71,14 @@ Obsoletes: XFree86-OpenGL-libGL Obsoletes: XFree86-driver-nvidia Obsoletes: XFree86-nvidia Conflicts: XFree86-OpenGL-devel <= 4.2.0-3 -ExclusiveArch: %{ix86} +ExclusiveArch: %{ix86} %{x8664} BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n) %define _noautoreqdep libGL.so.1 libGLcore.so.1 %define _prefix /usr/X11R6 +%ifarch %{x8664} +%define _libdir32 %{_prefix}/lib +%endif %description This driver set adds improved 2D functionality to the XFree86 4.0 X @@ -93,7 +120,8 @@ sterownik %package progs Summary: Tools for advanced control of nVidia graphic cards Summary(pl): Narzêdzia do zarz±dzania kartami graficznymi nVidia -Group: Application/System +Group: Applications/System +Obsoletes: XFree86-driver-nvidia-progs Requires: %{name} = %{version}-%{release} %description progs @@ -109,7 +137,6 @@ Summary(pl): Modu 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} @@ -132,7 +159,6 @@ Summary(de): Das nVidia-Kern-Modul f 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} @@ -151,46 +177,72 @@ przez sterownik nVidii dla XFree86 4. %prep cd %{_builddir} -rm -rf NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-%{_nv_pkg} +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}-%{_nv_pkg} +%setup -qDT -n NVIDIA-Linux-x86-%{_nv_ver}-%{_nv_rel}-pkg0 +%else +/bin/sh %{SOURCE1} --extract-only +%setup -qDT -n NVIDIA-Linux-x86_64-%{_nv_ver}-%{_nv_rel}-pkg0 +%endif %patch0 -p1 +%patch1 -p1 +%patch2 -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 modules \ - RCS_FIND_IGNORE="-name '*.ko' -o -name nv-kernel.o -o" \ - M=$PWD O=$PWD \ - %{?with_verbose:V=1} - mv nvidia.ko nvidia-$cfg.ko + 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 +%endif %install rm -rf $RPM_BUILD_ROOT install -d $RPM_BUILD_ROOT%{_libdir}/modules/{drivers,extensions} \ - $RPM_BUILD_ROOT{/usr/include/GL,/usr/%{_lib},%{_bindir}} + $RPM_BUILD_ROOT{/usr/include/GL,/usr/%{_lib}/tls,%{_bindir}} ln -sf $RPM_BUILD_ROOT%{_libdir} $RPM_BUILD_ROOT%{_prefix}/../lib install usr/bin/nvidia-settings $RPM_BUILD_ROOT%{_bindir} -install usr/lib%{?with_tls:/tls}/libnvidia-tls.so.%{version} $RPM_BUILD_ROOT%{_libdir} +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 %{x8664} +# 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 install usr/X11R6/lib/modules/drivers/nvidia_drv.o $RPM_BUILD_ROOT%{_libdir}/modules/drivers -install usr/X11R6/lib/libXvMCNVIDIA.* $RPM_BUILD_ROOT%{_libdir} +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} @@ -202,6 +254,7 @@ ln -sf libXvMCNVIDIA.so.%{version} $RPM_BUILD_ROOT%{_libdir}/libXvMCNVIDIA.so 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 +%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 \ @@ -210,11 +263,26 @@ install nvidia-%{?with_dist_kernel:up}%{!?with_dist_kernel:nondist}.ko \ install nvidia-smp.ko \ $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/misc/nvidia.ko %endif +%endif %clean rm -rf $RPM_BUILD_ROOT -%post -p /sbin/ldconfig +%post +/sbin/ldconfig +cat << EOF + + ******************************************************* + * * + * NOTE: * + * You must install: * + * kernel(24)(-smp)-video-nvidia-%{version} * + * for this driver to work * + * * + ******************************************************* + +EOF + %postun -p /sbin/ldconfig %post -n kernel-video-nvidia @@ -232,18 +300,29 @@ rm -rf $RPM_BUILD_ROOT %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 +%doc usr/share/doc/{README.txt,NVIDIA_Changelog,XF86Config.sample} +#%%lang(de) %doc usr/share/doc/README.DE %attr(755,root,root) %{_libdir}/libGL.so.*.* %attr(755,root,root) %{_libdir}/libGL.so %attr(755,root,root) %{_libdir}/libGLcore.so.*.* %attr(755,root,root) %{_libdir}/libXvMCNVIDIA.so.*.* -%attr(755,root,root) %{_libdir}/libnvidia-tls.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 %{x8664} +# 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.*.*.* +%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 %defattr(644,root,root,755) /lib/modules/%{_kernel_ver}/misc/*.ko* @@ -253,6 +332,7 @@ rm -rf $RPM_BUILD_ROOT %defattr(644,root,root,755) /lib/modules/%{_kernel_ver}smp/misc/*.ko* %endif +%endif %files devel %defattr(644,root,root,755) @@ -262,5 +342,6 @@ rm -rf $RPM_BUILD_ROOT %{_libdir}/libXvMCNVIDIA.a %files progs -%defattr(755,root,root,755) -%{_bindir}/nvidia-settings +%defattr(644,root,root,755) +%doc usr/share/doc/nvidia-settings-user-guide.txt +%attr(755,root,root) %{_bindir}/nvidia-settings