X-Git-Url: http://git.pld-linux.org/?p=packages%2Fe1000.git;a=blobdiff_plain;f=e1000.spec;h=093c280f734e2d64bca42dbfa22a3bef6fd0fc01;hp=35e754319c007b20fcd14cd379bd658dc4545048;hb=c259e07767f69000092395f37ae7de469340cf64;hpb=6d9878b02ee5f644d34c35464a7a6e6a3051719f diff --git a/e1000.spec b/e1000.spec index 35e7543..093c280 100644 --- a/e1000.spec +++ b/e1000.spec @@ -1,28 +1,27 @@ # # Conditional build: -# _without_dist_kernel without distribution kernel +%bcond_without dist_kernel # without distribution kernel +%bcond_without smp # don't build SMP module # %define _orig_name e1000 - -%{!?_without_dist_kernel:%define _mod_name %{_orig_name}_intel } -%{?_without_dist_kernel:%define _mod_name %{_orig_name} } +%define _mod_name e1000%{?with_dist_kernel:_intel} Summary: Intel(R) PRO/1000 driver for Linux Summary(pl): Sterownik do karty Intel(R) PRO/1000 Name: kernel-net-%{_orig_name} -Version: 5.2.20 +Version: 5.5.4 %define _rel 1 Release: %{_rel}@%{_kernel_ver_str} License: BSD Vendor: Intel Corporation Group: Base/Kernel Source0: ftp://aiedownload.intel.com/df-support/2897/eng/%{_orig_name}-%{version}.tar.gz -# Source0-md5: 52a65f13fda89257edbc4507958c6e3a -%{!?_without_dist_kernel:BuildRequires: kernel-headers >= 2.4.20 } +# Source0-md5: f6e55d5f3a112dca04397e62d720ef84 +%{?with_dist_kernel:BuildRequires: kernel-module-build >= 2.6.0} BuildRequires: %{kgcc_package} BuildRequires: rpmbuild(macros) >= 1.118 URL: http://support.intel.com/support/network/adapter/pro100/ -%{!?_without_dist_kernel:%requires_releq_kernel_up} +%{?with_dist_kernel:%requires_releq_kernel_up} Requires(post,postun): /sbin/depmod Provides: kernel(e1000) Obsoletes: e1000 @@ -42,7 +41,7 @@ Summary: Intel(R) PRO/1000 driver for Linux SMP Summary(pl): Sterownik do karty Intel(R) PRO/1000 Release: %{_rel}@%{_kernel_ver_str} Group: Base/Kernel -%{!?_without_dist_kernel:%requires_releq_kernel_smp} +%{?with_dist_kernel:%requires_releq_kernel_smp} Requires(post,postun): /sbin/depmod Provides: kernel(e1000) Obsoletes: e1000 @@ -60,31 +59,31 @@ Ten pakiet zawiera sterownik dla Linuksa SMP do kart sieciowych %setup -q -n %{_orig_name}-%{version} %build -%ifarch %{ix86} -%{__make} -C src SMP=1 CC="%{kgcc} -DCONFIG_X86_LOCAL_APIC -DSTB_WA" KSRC=%{_kernelsrcdir} -%endif -%ifarch ppc -%{__make} -C src SMP=1 CC="%{kgcc} -msoft-float -DSTB_WA" KSRC=%{_kernelsrcdir} -%endif -%ifnarch %{ix86} ppc -%{__make} -C src SMP=1 CC="%{kgcc} -DSTB_WA" KSRC=%{_kernelsrcdir} -%endif -mv -f src/%{_orig_name}.o src/%{_orig_name}-smp.o - -%{__make} -C src clean KSRC=%{_kernelsrcdir} - -%ifarch ppc -%{__make} -C src CC="%{kgcc} -msoft-float -DSTB_WA" KSRC=%{_kernelsrcdir} -%else -%{__make} -C src CC="%{kgcc} -DSTB_WA" KSRC=%{_kernelsrcdir} -%endif - +cd src +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 \ + EXTRA_CFLAGS="-I../include -DFUSE_VERSION='1.1'" \ + RCS_FIND_IGNORE="-name '*.ko' -o" \ + M=$PWD O=$PWD \ + %{?with_verbose:V=1} + mv e1000.ko e1000.ko-$cfg +done + %install rm -rf $RPM_BUILD_ROOT install -d $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/kernel/drivers/net/misc install -d $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/kernel/drivers/net/misc -install src/%{_orig_name}-smp.o $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/kernel/drivers/net/misc/%{_mod_name}.o -install src/%{_orig_name}.o $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/kernel/drivers/net/misc/%{_mod_name}.o +install src/%{_orig_name}.ko-smp $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}smp/kernel/drivers/net/misc/%{_mod_name}.ko +install src/%{_orig_name}.ko-up $RPM_BUILD_ROOT/lib/modules/%{_kernel_ver}/kernel/drivers/net/misc/%{_mod_name}.ko %clean rm -rf $RPM_BUILD_ROOT