summaryrefslogtreecommitdiff
path: root/macros.kmp
diff options
context:
space:
mode:
authorCoprDistGit <infra@openeuler.org>2024-08-29 06:33:38 +0000
committerCoprDistGit <infra@openeuler.org>2024-08-29 06:33:38 +0000
commit6be8483f86d6af135c5f41298b5ade0ba93e8f93 (patch)
tree79cf12161389b3bc8b2d3d253166f175ea31fa55 /macros.kmp
parent1175fc575d157169d8592e937cba42181d0ec3f2 (diff)
automatic import of openEuler-rpm-config
Diffstat (limited to 'macros.kmp')
-rw-r--r--macros.kmp64
1 files changed, 64 insertions, 0 deletions
diff --git a/macros.kmp b/macros.kmp
new file mode 100644
index 0000000..291066e
--- /dev/null
+++ b/macros.kmp
@@ -0,0 +1,64 @@
+# Use these macros to differentiate between @VENDOR@ and other KMP implementation(s).
+
+kernel_module_package_release 1
+
+%__find_provides /usr/lib/rpm/find-provides
+%__find_requires /usr/lib/rpm/@VENDOR@/find-requires
+
+#kernel_module_package [ -n name ] [ -v version ] [ -r release ] [ -s script ]
+# [ -f filelist] [ -x ] [ -p preamble ] flavor flavor ...
+
+%kernel_module_package_buildreqs %global kmodtool_generate_buildreqs 1 \
+ kernel-devel
+
+%kernel_module_package(n:v:r:s:f:xp:) %{expand:%( \
+ %define kmodtool %{-s*}%{!-s:/usr/lib/rpm/@VENDOR@/kmodtool} \
+ %define kmp_version %{-v*}%{!-v:%{version}} \
+ %define kmp_release %{-r*}%{!-r:%{release}} \
+ %define latest_kernel %(rpm -q --qf '%%{VERSION}-%%{RELEASE}.%%{ARCH}\\\\n' `rpm -q kernel-devel | head -n 1` | head -n 1) \
+ %{!?kernel_version:%{expand:%%global kernel_version %{latest_kernel}}} \
+ %global kverrel %(%kmodtool verrel %{?kernel_version} 2>/dev/null) \
+ flavors="default" \
+ if [ "i686" == "%{_target_cpu}" ] || [ "x86_64" == "%{_target_cpu}" ] \
+ then \
+ xenver=$(rpm -q kernel-xen-devel-%{kverrel}|head -n 1)\
+ kdver=$(rpm -q kernel-kdump-devel-%{kverrel}|head -n 1)\
+ if [ "kernel-xen-devel-%{kverrel}" == "$xenver" ] \
+ then \
+ flavors="$flavors xen" \
+ fi \
+ if [ "kernel-kdump-devel-%{kverrel}" == "$kdver" ] \
+ then \
+ flavors="$flavors kdump" \
+ fi \
+ fi \
+ if [ -z "%*" ]; then \
+ flavors_to_build=$flavors \
+ elif [ -z "%{-x}" ]; then \
+ flavors_to_build="%*" \
+ else \
+ flavors_to_build=" $flavors "\
+ rm -rf /tmp/tmp.$$ \
+ echo "[$flavors_to_build]" >/tmp/tmp.$$ \
+ for i in %* \
+ do \
+ flavors_to_build=${flavors_to_build//$i /}
+ done \
+ fi \
+ echo "%%global flavors_to_build ${flavors_to_build:-%%nil}" \
+ echo "%%global kernel_source() /usr/src/kernels/%kverrel\\\$([ %%%%{1} = default ] || echo "%%%%{1}.")" \
+ if [ ! -z "%{-f*}" ] \
+ then \
+ filelist="%{-f*}" \
+ fi \
+ if [ ! -z "%{-p*}" ] \
+ then \
+ preamble="%{-p*}" \
+ fi \
+ nobuildreqs="yes" \
+ if [ "x%{kmodtool_generate_buildreqs}" != "x1" ] \
+ then \
+ nobuildreqs="no" \
+ fi \
+ kmp_override_filelist="$filelist" kmp_override_preamble="$preamble" kmp_nobuildreqs="$nobuildreqs" %{kmodtool} rpmtemplate_kmp %{-n*}%{!-n:%name} %{kverrel} $flavors_to_build 2>/dev/null \
+)}