aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--spl-modules.spec.in103
1 files changed, 75 insertions, 28 deletions
diff --git a/spl-modules.spec.in b/spl-modules.spec.in
index e18a3bfbc..7740d9422 100644
--- a/spl-modules.spec.in
+++ b/spl-modules.spec.in
@@ -3,6 +3,13 @@
# require_kver, require_kdir, require_obj constants for us, but if it does not
# not we attempt to determine the correct values based on your distro.
+# kdir: Full path to the kernel source headers
+# kobj: Full path to the kernel build objects
+# kver: Kernel version
+# kpkg: Kernel package name
+# kdevpkg: Kernel devel package name
+# kverpkg: Kernel package version
+
%if %{defined require_kver}
%define kver %{require_kver}
%endif
@@ -15,32 +22,51 @@
%define kobj %{require_kobj}
%endif
-# kdir: Full path to the kernel source headers
-# kobj: Full path to the kernel build objects
-# kver: Kernel version
-# kpkg: Kernel package name
-# kdevpkg: Kernel devel package name
-# kverpkg: Kernel package version
-
-# SLES*:
-%if %{defined sles_version}
+# SLES 10, SLES 11:
+%if %{defined suse_version}
%if %{undefined kver}
- %define klnk %{_usrsrc}/linux-obj/%{_target_cpu}/%{_target_cpu}
- %define kver %((echo X; %{__cat} %{klnk}/.kernelrelease
- 2>/dev/null) | tail -1)
+ %ifarch ppc64
+ %define kverextra ppc64
+ %else
+ %define kverextra default
+ %endif
+
+ %if %{suse_version} >= 1100
+ %define klnk %{_usrsrc}/linux-obj/%{_target_cpu}/%{kverextra}
+ %define krelease %{klnk}/include/config/kernel.release
+ %else
+ %define klnk %{_usrsrc}/linux-obj/%{_target_cpu}/%{kverextra}
+ %define krelease %{klnk}/.kernelrelease
+ %endif
+
+ %define kver %((echo X; %{__cat} %{krelease} 2>/dev/null)|tail -1)
+ %endif
+
+ %if %{undefined kverextra}
+ %define kverextra %(echo %{kver} | cut -f3 -d'-')
%endif
- %define kpkg kernel-%{_target_cpu}
- %define kdevpkg kernel-source kernel-syms
- %define kverpkg %(echo %{kver} | cut -d'-' -f1-2)
+
+ %define kpkg kernel-%{kverextra}
+ %define kdevpkg kernel-source
+ %define kverpkg %(echo %{kver} | %{__sed} -e 's/-%{kverextra}//g')
+
+ # The kernel and rpm versions do not strictly match under SLES11
+ # e.g. kernel version 2.6.27.19-5 != rpm version 2.6.27.19-5.1
+ %if %{suse_version} >= 1100
+ %define koppkg >=
+ %else
+ %define koppkg =
+ %endif
+
%if %{undefined kdir}
%define kdir %{_usrsrc}/linux-%{kverpkg}
%endif
%if %{undefined kobj}
- %define kobj %{kdir}-obj/%{_target_cpu}/%{_target_cpu}
+ %define kobj %{kdir}-obj/%{_target_cpu}/%{kverextra}
%endif
-
-# CHAOS4:
%else
+
+# CHAOS 4.x:
%if %{defined ch4}
%if %{undefined kver}
%define klnk %{_usrsrc}/kernels/*/include/config
@@ -50,16 +76,36 @@
%define kpkg chaos-kernel
%define kdevpkg chaos-kernel-devel
%define kverpkg %{kver}
+ %define koppkg =
%if %{undefined kdir}
%define kdir %{_usrsrc}/kernels/%{kver}
%endif
%if %{undefined kobj}
%define kobj %{kdir}
%endif
+%else
-# RHEL*/Fedora:
+# RHEL 5:
+%if %{defined el5}
+ %if %{undefined kver}
+ %define klnk %{_usrsrc}/kernels/*/include/config
+ %define kver %((echo X; %{__cat} %{klnk}/kernel.release
+ 2>/dev/null) | tail -1)
+ %endif
+ %define kpkg kernel
+ %define kdevpkg kernel-devel
+ %define kverpkg %{kver}
+ %define koppkg =
+ %if %{undefined kdir}
+ %define kdir %{_usrsrc}/kernels/%{kver}-%{_target_cpu}
+ %endif
+ %if %{undefined kobj}
+ %define kobj %{kdir}
+ %endif
%else
-%if %{defined fedora} || %{defined rhel}
+
+# Fedora 11:
+%if %{defined fedora}
%if %{undefined kver}
%define klnk %{_usrsrc}/kernels/*/include/config
%define kver %((echo X; %{__cat} %{klnk}/kernel.release
@@ -67,23 +113,24 @@
%endif
%define kpkg kernel
%define kdevpkg kernel-devel
- %define kverpkg %(echo %{kver} | cut -d'.' -f1-7)
+ %define kverpkg %(echo %{kver} | %{__sed} -e 's/.%{_target_cpu}//g')
+ %define koppkg =
%if %{undefined kdir}
%define kdir %{_usrsrc}/kernels/%{kver}
%endif
%if %{undefined kobj}
%define kobj %{kdir}
%endif
-
%else
# Unsupported distro:
%if %{undefined kver}
- %define kver X
+ %define kver X
%endif
- %define kpkg kernel
- %define kdevpkg kernel-devel
- %define kverpkg %{kver}
+ %define kpkg kernel
+ %define kdevpkg kernel-devel
+ %define kverpkg %{kver}
+ %define koppkg =
%if %{undefined kdir}
%define kdir %{_usrsrc}/kernels/%{kver}
%endif
@@ -94,13 +141,13 @@
%endif
%endif
%endif
+%endif
# Distro agnostic:
%define name @PACKAGE@-modules
%define version @VERSION@
%define debug_package %{nil}
-
# The kernel version should only be appended to a binary RPM. When
# building a source RPM it must be kernel version agnostic. This means
# the source RPM must never specify a required kernel version, but the
@@ -111,7 +158,7 @@
%else
%define relext %(echo %{kverpkg} | %{__sed} -e 's/-/_/g')
%define release @SPL_META_RELEASE@_%{relext}
-%define requires %{kpkg} = %{kverpkg}
+%define requires %{kpkg} %{koppkg} %{kverpkg}
%endif
Summary: Solaris Porting Layer Modules