From 9976b67e5b90ddc36bbcab74a08ba12a41aee124 Mon Sep 17 00:00:00 2001 From: CentOS Sources Date: Tue, 16 May 2023 06:16:36 +0000 Subject: [PATCH] import kmod-redhat-oracleasm-2.0.8-17.el8 --- .gitignore | 1 - .kmod-redhat-oracleasm.metadata | 1 - SOURCES/find-requires.ksyms | 162 --------------- SPECS/kmod-redhat-oracleasm.spec | 338 +++++++++++-------------------- 4 files changed, 122 insertions(+), 380 deletions(-) delete mode 100755 SOURCES/find-requires.ksyms diff --git a/.gitignore b/.gitignore index fd2b900..cfc0f71 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1 @@ -SOURCES/kernel-devel-4.18.0-425.10.1.el8_7.x86_64.rpm SOURCES/oracleasm-redhat-2.0.8.tar.bz2 diff --git a/.kmod-redhat-oracleasm.metadata b/.kmod-redhat-oracleasm.metadata index 5280ea7..cf0a1a0 100644 --- a/.kmod-redhat-oracleasm.metadata +++ b/.kmod-redhat-oracleasm.metadata @@ -1,2 +1 @@ -4b8bc8bbbebd7aa3626d2196b7f508b4b2bced14 SOURCES/kernel-devel-4.18.0-425.10.1.el8_7.x86_64.rpm 3f7008b7f30674a0078edda3e8d32941578dae21 SOURCES/oracleasm-redhat-2.0.8.tar.bz2 diff --git a/SOURCES/find-requires.ksyms b/SOURCES/find-requires.ksyms deleted file mode 100755 index ac0947c..0000000 --- a/SOURCES/find-requires.ksyms +++ /dev/null @@ -1,162 +0,0 @@ -#! /bin/bash -# -# This script is called during external module building to create dependencies -# both upon the RHEL kernel, and on additional external modules. Symbols that -# cannot be reconciled against those provided by the kernel are assumed to be -# provided by an external module and "ksym" replaces th regular "kernel" dep. - -IFS=$'\n' - -# Extract all of the symbols provided by this module. -all_provides() { - for module in "$@"; do - tmpfile="" - if [ "x${module%.ko}" = "x${module}" ]; then - tmpfile=$(mktemp -t ${0##*/}.XXXXXX.ko) - proc_bin= - case "${module##*.}" in - xz) - proc_bin=xz - ;; - bz2) - proc_bin=bzip2 - ;; - gz) - proc_bin=gzip - ;; - esac - - [ -n "$proc_bin" ] || continue - - "$proc_bin" -d -c - < "$module" > "$tmpfile" || continue - module="$tmpfile" - fi - - if [[ -n $(nm "$module" | sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p') ]]; then - nm "$module" \ - | sed -r -ne 's:^0*([0-9a-f]+) A __crc_(.+):0x\1 \2:p' \ - | awk --non-decimal-data '{printf("%s:0x%08x\n", $2, $1)}' - else - ELFRODATA=$(readelf -R .rodata "$module" | awk '/0x/{printf $2$3$4$5}') - if [[ -n $(readelf -h "$module" | grep "little endian") ]]; then - RODATA=$(echo $ELFRODATA | sed 's/\(..\)\(..\)\(..\)\(..\)/\4\3\2\1/g') - else - RODATA=$ELFRODATA - fi - for sym in $(nm "$module" | sed -r -ne 's:^0*([0-9a-f]+) R __crc_(.+):0x\1 \2:p'); do - echo $sym $RODATA - done \ - | awk --non-decimal-data '{printf("%s:0x%08s\n", $2, substr($3,($1*2)+1,8))}' - fi - - [ -z "$tmpfile" ] || rm -f -- "$tmpfile" - done \ - | LC_ALL=C sort -k1,1 -u -} - -# Extract all of the requirements of this module. -all_requires() { - for module in "$@"; do - set -- $(/sbin/modinfo -F vermagic "$module" | sed -e 's: .*::' -e q) - /sbin/modprobe --dump-modversions "$module" \ - | awk --non-decimal-data ' - BEGIN { FS = "\t" ; OFS = "\t" } - {printf("%s:0x%08x\n", $2, $1)}' \ - | sed -r -e 's:$:\t'"$1"':' - done \ - | LC_ALL=C sort -k1,1 -u -} - -# Filter out requirements fulfilled by the module itself. -mod_requires() { - LC_ALL=C join -t $'\t' -j 1 -v 1 \ - <(all_requires "$@") \ - <(all_provides "$@") \ - | LC_ALL=C sort -k1,1 -u -} - -if ! [ -e /sbin/modinfo -a -e /sbin/modprobe ]; then - cat > /dev/null - exit 0 -fi - -check_kabi() { - arch=$(uname -m) - kabi_file="/lib/modules/kabi-current/kabi_whitelist_$arch" - - # If not installed, output a warning and return (continue) - if [ ! -f "$kabi_file" ]; then - echo "" >&2 - echo "********************************************************************************" >&2 - echo "*********************** KERNEL ABI COMPATIBILITY WARNING ***********************" >&2 - echo "********************************************************************************" >&2 - echo "The kernel ABI reference files (provided by "kabi-whitelists") were not found." >&2 - echo "No compatibility check was performed. Please install the kABI reference files" >&2 - echo "and rebuild if you would like to verify compatibility with kernel ABI." >&2 - echo "" >&2 - return - fi - - unset non_kabi - for symbol in "$@"; do - if ! egrep "^[[:space:]]$symbol\$" $kabi_file >/dev/null; then - non_kabi=("${non_kabi[@]}" "$symbol") - fi - done - - if [ ${#non_kabi[@]} -gt 0 ]; then - echo "" >&2 - echo "********************************************************************************" >&2 - echo "*********************** KERNEL ABI COMPATIBILITY WARNING ***********************" >&2 - echo "********************************************************************************" >&2 - echo "The following kernel symbols are not guaranteed to remain compatible with" >&2 - echo "future kernel updates to this RHEL release:" >&2 - echo "" >&2 - for symbol in "${non_kabi[@]}"; do - printf "\t$symbol\n" >&2 - done - echo "" >&2 - echo "Red Hat recommends that you consider using only official kernel ABI symbols" >&2 - echo "where possible. Requests for additions to the kernel ABI can be filed with" >&2 - echo "your partner or customer representative (component: driver-update-program)." >&2 - echo "" >&2 - fi -} - -modules=($(grep -E '/lib/modules/.+\.ko(\.gz|\.bz2|\.xz)?$')) -if [ ${#modules[@]} -gt 0 ]; then - kernel=$(/sbin/modinfo -F vermagic "${modules[0]}" | sed -e 's: .*::' -e q) - - # get all that kernel provides - symvers=$(mktemp -t ${0##*/}.XXXXX) - - symvers_path="/usr/src/kernels/$kernel/Module.symvers" - bundled_path="$(echo "${modules[0]}" | sed "s|/BUILDROOT/\([^/]*\)-[^/]*/.*|/BUILD/\1/usr/src/kernels/$kernel/Module.symvers|")" - echo "Bundled: $bundled_path" >&2 - if [ -e $bundled_path ]; then - symvers_path="$bundled_path" - fi - - cat "$symvers_path" | awk ' - BEGIN { FS = "\t" ; OFS = "\t" } - { print $2 ":" $1 } - ' \ - | sed -r -e 's:$:\t'"$kernel"':' \ - | LC_ALL=C sort -k1,1 -u > $symvers - - # Symbols matching with the kernel get a "kernel" dependency - mod_req=$(mktemp -t mod_req.XXXXX) - mod_requires "${modules[@]}" > "$mod_req" - LC_ALL=C join -t $'\t' -j 1 $symvers "$mod_req" | LC_ALL=C sort -u \ - | awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print "kernel(" $1 ") = " $2 }' - - # Symbols from elsewhere get a "ksym" dependency - LC_ALL=C join -t $'\t' -j 1 -v 2 $symvers "$mod_req" | LC_ALL=C sort -u \ - | awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print "ksym(" $1 ") = " $2 }' - - # Check kABI if the kabi-whitelists package is installed - # Do this last so we can try to output this error at the end - kabi_check_symbols=($(LC_ALL=C join -t $'\t' -j 1 $symvers "$mod_req" | LC_ALL=C sort -u \ - | awk 'BEGIN { FS = "[\t:]" ; OFS = "\t" } { print $1 }')) - check_kabi "${kabi_check_symbols[@]}" -fi diff --git a/SPECS/kmod-redhat-oracleasm.spec b/SPECS/kmod-redhat-oracleasm.spec index 4cb5cf3..e8379f2 100644 --- a/SPECS/kmod-redhat-oracleasm.spec +++ b/SPECS/kmod-redhat-oracleasm.spec @@ -3,27 +3,23 @@ %define kmod_rpm_name kmod-redhat-oracleasm %define kmod_driver_version 2.0.8 %define kmod_driver_epoch 8 -%define kmod_rpm_release 15.1 -%define kmod_kernel_version 4.18.0-425.3.1.el8 -%define kmod_kernel_version_min 4.18.0-425.el8 +%define kmod_rpm_release 17 +%define kmod_kernel_version 4.18.0-444.el8 +%define kmod_kernel_version_min 4.18.0-444.el8 %define kmod_kernel_version_dep 4.18.0 %define kmod_kbuild_dir drivers/block/oracleasm -%define kmod_install_path_ga updates/kmod-redhat-oracleasm %define kmod_install_path extra/kmod-redhat-oracleasm %define kernel_pkg kernel %define kernel_devel_pkg kernel-devel %define kernel_modules_pkg kernel-modules -%define kmod_rpm_name_ga %{kmod_rpm_name}-kernel_4_18_0_425_3_1 - -%define kmod_rpm_name_z %{kmod_rpm_name}-kernel_4_18_0_425_10_1 -%define kmod_kernel_version_z 4.18.0-425.10.1.el8_7 - -%define kmod_list %{kmod_rpm_name_ga}:%{kmod_kernel_version}:%{kmod_install_path_ga}: %{kmod_rpm_name_z}:%{kmod_kernel_version_z}:%{kmod_install_path}:%{SOURCE1} - -%{!?dist: %define dist .el8_7} +%{!?dist: %define dist .el8_4} %{!?make_build: %define make_build make} +%if "%{kmod_kernel_version_dep}" == "" +%define kmod_kernel_version_dep %{kmod_kernel_version} +%endif + Source0: %{kmod_name}-%{kmod_vendor}-%{kmod_driver_version}.tar.bz2 # Source code patches @@ -33,15 +29,8 @@ Patch2: 0002-oracleasm-driver-make-bio_for_each_segment_all-worki.patch Patch3: 0003-oracleasm-copy-rhel8-s-bio_map_user_iov.patch Patch4: 0004-update-bdi-writeback-acct_dirty-flags.patch -Source1: kernel-devel-%{kmod_kernel_version_z}.x86_64.rpm - -Source9000: find-requires.ksyms - %define findpat %( echo "%""P" ) -# We bundle our own slightly modified version of find-requires.ksyms in order -# to get kernel() Requires: for the kmod versions build against bundled -# kernel-devel packages to be generated properly. -%define __find_requires "%{SOURCE9000}" +%define __find_requires /usr/lib/rpm/redhat/find-requires.ksyms %define __find_provides /usr/lib/rpm/redhat/find-provides.ksyms %{kmod_name} %{?epoch:%{epoch}:}%{version}-%{release} %define sbindir %( if [ -d "/sbin" -a \! -h "/sbin" ]; then echo "/sbin"; else echo %{_sbindir}; fi ) %define dup_state_dir %{_localstatedir}/lib/rpm-state/kmod-dups @@ -62,9 +51,8 @@ URL: https://github.com/oracle/linux-uek/tree/uek6/master/drivers/block/oraclea BuildRoot: %(mktemp -ud %{_tmppath}/%{name}-%{version}-%{release}-XXXXXX) BuildRequires: %kernel_devel_pkg = %kmod_kernel_version BuildRequires: redhat-rpm-config kernel-abi-whitelists elfutils-libelf-devel kernel-rpm-macros kmod -# For unpacking bundled kernel-devel packages -BuildRequires: rpm cpio ExclusiveArch: x86_64 +%global kernel_source() /usr/src/kernels/%{kmod_kernel_version}.$(arch) %global _use_internal_dependency_generator 0 Provides: %kernel_modules_pkg >= %{kmod_kernel_version_min}.%{_target_cpu} @@ -73,149 +61,96 @@ Provides: %{kmod_name} = %{?epoch:%{epoch}:}%{version}-%{release} Provides: %{kmod_name}-kmod = %{?epoch:%{epoch}:}%{version}-%{release} Requires(post): %{sbindir}/weak-modules Requires(postun): %{sbindir}/weak-modules +Requires: kernel >= 4.18.0-240.el8 # if there are multiple kmods for the same driver from different vendors, # they should conflict with each other. Conflicts: kmod-%{kmod_name} Obsoletes: %{name}-kernel_4_18_0_240 Obsoletes: %{name}-kernel_4_18_0_240_14_1 - -# Set Requires: based on kernel version(s) installed -# "with" is important here: otherwise, ">=" and "<" parts maybe satisfied -# by different versions that are installed simultaneously (for example, -# 4.18.0-9999 and 4.18.0-80, respectively). -Requires: (%{kmod_rpm_name_ga} if (kernel >= %{kmod_kernel_version} with kernel < %{kmod_kernel_version_z})) -Requires: (%{kmod_rpm_name_z} if kernel >= %{kmod_kernel_version_z}) +Obsoletes: %{name}-kernel_4_18_0_425_3_1 +Obsoletes: %{name}-kernel_4_18_0_425_10_1 %description oracleasm kernel module -%package -n %{kmod_rpm_name_ga} -Summary: oracleasm kernel module for kernel version %{kmod_kernel_version}..%{kmod_kernel_version_z} -Provides: %kernel_modules_pkg >= %{kmod_kernel_version_z}.%{_target_cpu} -BuildRequires: %kernel_devel_pkg = %kmod_kernel_version -Requires: %{kmod_rpm_name} = %{?epoch:%{epoch}:}%{version}-%{release} -Requires(post): %{sbindir}/weak-modules -Requires(postun): %{sbindir}/weak-modules -Requires: kernel >= %{kmod_kernel_version} +%post +modules=( $(find /lib/modules/%{kmod_kernel_version}.%(arch)/%{kmod_install_path} | grep '\.ko$') ) +printf '%s\n' "${modules[@]}" | %{sbindir}/weak-modules --add-modules --no-initramfs -%description -n %{kmod_rpm_name_ga} -oracleasm kernel module for kernel version %{kmod_kernel_version_z} and higher. +mkdir -p "%{kver_state_dir}" +touch "%{kver_state_file}" -%package -n %{kmod_rpm_name_z} -Summary: oracleasm kernel module for kernel version %{kmod_kernel_version_z} and higher -Provides: %kernel_modules_pkg >= %{kmod_kernel_version_z}.%{_target_cpu} -## We can't have nice things (such as multiple kernel package versions in a brew -## buildroot despite its parallel installability, even), so we bundle it -## in Source1. -#BuildRequires: %%kernel_devel_pkg = %%kmod_kernel_version_z -Requires: %{kmod_rpm_name} = %{?epoch:%{epoch}:}%{version}-%{release} -Requires(post): %{sbindir}/weak-modules -Requires(postun): %{sbindir}/weak-modules -Requires: kernel >= %{kmod_kernel_version_z} +exit 0 -%description -n %{kmod_rpm_name_z} -oracleasm kernel module for kernel version %{kmod_kernel_version_z} and higher. +%posttrans +# We have to re-implement part of weak-modules here because it doesn't allow +# calling initramfs regeneration separately +if [ -f "%{kver_state_file}" ]; then + kver_base="%{kmod_kernel_version_dep}" + kvers=$(ls -d "/lib/modules/${kver_base%%.*}"*) -# Usage: kmod_scripts RPMNAME KVER -%define kmod_scripts() %{expand: \ -%files -n %1 \ - %defattr(644,root,root,755) \ - /lib/modules/%2.%(arch) \ - %doc /usr/share/doc/%{kmod_rpm_name}/greylist.txt.%2 \ - \ -%post -n %1 \ - kver="%2" \ - modules=( $( { [ -e "/lib/modules/${kver}.%(arch)/%{kmod_install_path}" ] && find "/lib/modules/${kver}.%(arch)/%{kmod_install_path}"; } | grep '\.ko$' ) ) \ - printf '%s\\n' "${modules[@]}" | %{sbindir}/weak-modules --add-modules --no-initramfs \ - \ - mkdir -p "%{kver_state_dir}" \ - touch "%{kver_state_dir}/${kver}.%(arch)" \ - \ - exit 0 \ - \ -%posttrans -n %1 \ - # We have to re-implement part of weak-modules here because it doesn't allow \ - # calling initramfs regeneration separately \ - kver="%2" \ - kver_state_file="%{kver_state_dir}/${kver}.%(arch)" \ - if [ -f "${kver_state_file}" ]; then \ - kver_base="%{kmod_kernel_version_dep}" \ - kvers=$(ls -d "/lib/modules/${kver_base%%.*}"*) \ - \ - for k_dir in $kvers; do \ - k="${k_dir#/lib/modules/}" \ - \ - tmp_initramfs="/boot/initramfs-$k.tmp" \ - dst_initramfs="/boot/initramfs-$k.img" \ - \ - # The same check as in weak-modules: we assume that the kernel present \ - # if the symvers file exists. \ - if [ -e "/boot/symvers-$k.gz" ] || [ -e "$k_dir/symvers.gz" ]; then \ - # Additional depmod call as weak-modules \ - # seems to ignore the depmod configuration \ - /usr/sbin/depmod "$k" \ - /usr/bin/dracut -f "$tmp_initramfs" "$k" || exit 1 \ - cmp -s "$tmp_initramfs" "$dst_initramfs" \ - if [ "$?" = 1 ]; then \ - mv "$tmp_initramfs" "$dst_initramfs" \ - else \ - rm -f "$tmp_initramfs" \ - fi \ - fi \ - done \ - \ - rm -f "%{kver_state_dir}/${kver}.%(arch)" \ - rmdir "%{kver_state_dir}" 2> /dev/null \ - fi \ - \ - rmdir "%{dup_state_dir}" 2> /dev/null \ - \ - exit 0 \ - \ - \ -%preun -n "%1" \ - if rpm -q --filetriggers kmod 2> /dev/null| grep -q "Trigger for weak-modules call on kmod removal"; then \ - kver="%2" \ - mkdir -p "%{kver_state_dir}" \ - touch "%{kver_state_dir}/${kver}.%(arch)" \ - fi \ - \ - mkdir -p "%{dup_state_dir}" \ - rpm -ql "%1-%{kmod_driver_version}-%{kmod_rpm_release}%{?dist}.%(arch)" | \\\ - grep '\\.ko$' > "%{dup_module_list}" \ - \ - exit 0 \ - \ - \ -%postun -n %1 \ - if rpm -q --filetriggers kmod 2> /dev/null| grep -q "Trigger for weak-modules call on kmod removal"; then \ - initramfs_opt="--no-initramfs" \ - else \ - initramfs_opt="" \ - fi \ - \ - modules=( $(cat "%{dup_module_list}") ) \ - rm -f "%{dup_module_list}" \ - printf '%s\\n' "${modules[@]}" | %{sbindir}/weak-modules --remove-modules $initramfs_opt \ - \ - rmdir "%{dup_state_dir}" 2> /dev/null \ - \ - exit 0 \ -} + for k_dir in $kvers; do + k="${k_dir#/lib/modules/}" -%kmod_scripts %{kmod_rpm_name_ga} %{kmod_kernel_version} -%kmod_scripts %{kmod_rpm_name_z} %{kmod_kernel_version_z} + tmp_initramfs="/boot/initramfs-$k.tmp" + dst_initramfs="/boot/initramfs-$k.img" + # The same check as in weak-modules: we assume that the kernel present + # if the symvers file exists. + if [ -e "/boot/symvers-$k.gz" ] || [ -e "$k_dir/symvers.gz" ]; then + /usr/bin/dracut -f "$tmp_initramfs" "$k" || exit 1 + cmp -s "$tmp_initramfs" "$dst_initramfs" + if [ "$?" = 1 ]; then + mv "$tmp_initramfs" "$dst_initramfs" + else + rm -f "$tmp_initramfs" + fi + fi + done + + rm -f "%{kver_state_file}" + rmdir "%{kver_state_dir}" 2> /dev/null +fi + +rmdir "%{dup_state_dir}" 2> /dev/null + +exit 0 + +%preun +if rpm -q --filetriggers kmod 2> /dev/null| grep -q "Trigger for weak-modules call on kmod removal"; then + mkdir -p "%{kver_state_dir}" + touch "%{kver_state_file}" +fi + +mkdir -p "%{dup_state_dir}" +rpm -ql kmod-redhat-oracleasm-%{kmod_driver_version}-%{kmod_rpm_release}%{?dist}.$(arch) | \ + grep '\.ko$' > "%{dup_module_list}" + +%postun +if rpm -q --filetriggers kmod 2> /dev/null| grep -q "Trigger for weak-modules call on kmod removal"; then + initramfs_opt="--no-initramfs" +else + initramfs_opt="" +fi + +modules=( $(cat "%{dup_module_list}") ) +rm -f "%{dup_module_list}" +printf '%s\n' "${modules[@]}" | %{sbindir}/weak-modules --remove-modules $initramfs_opt + +rmdir "%{dup_state_dir}" 2> /dev/null + +exit 0 %files -%doc /usr/share/doc/%{kmod_rpm_name}/greylist.txt +%defattr(644,root,root,755) +/lib/modules/%{kmod_kernel_version}.%(arch) /etc/depmod.d/%{kmod_name}.conf +%doc /usr/share/doc/%{kmod_rpm_name}/greylist.txt + %prep -# A hack for having directory name under builddir equivalent to RPM name -%setup -c -mv %{kmod_name}-%{kmod_vendor}-%{kmod_driver_version}/* . +%setup -n %{kmod_name}-%{kmod_vendor}-%{kmod_driver_version} %patch0 -p1 #%patch1 -p1 @@ -225,85 +160,54 @@ mv %{kmod_name}-%{kmod_vendor}-%{kmod_driver_version}/* . set -- * mkdir source mv "$@" source/ - -# Unpacking bundled kernel-devel packages -for name_kver in %{kmod_list}; do - src="${name_kver##*:}" - [ -n "$src" ] || continue - rpm2cpio "${src}" | cpio -idm -done +mkdir obj %build +rm -rf obj +cp -r source obj -for name_kver in %{kmod_list}; do - kver="${name_kver#*:}" - kver="${kver%%%%:*}" - src="${name_kver##*:}" +PWD_PATH="$PWD" +%if "%{workaround_no_pwd_rel_path}" != "1" +PWD_PATH=$(realpath --relative-to="%{kernel_source}" . 2>/dev/null || echo "$PWD") +%endif +%{make_build} -C %{kernel_source} V=1 M="$PWD_PATH/obj/%{kmod_kbuild_dir}" \ + NOSTDINC_FLAGS="-I$PWD_PATH/obj/include -I$PWD_PATH/obj/include/uapi %{nil}" \ + EXTRA_CFLAGS="%{nil}" \ + %{nil} +# mark modules executable so that strip-to-file can strip them +find obj/%{kmod_kbuild_dir} -name "*.ko" -type f -exec chmod u+x '{}' + - rm -rf obj.${kver} - cp -r source obj.${kver} - echo > source/greylist +whitelist="/lib/modules/kabi-current/kabi_whitelist_%{_target_cpu}" +for modules in $( find obj/%{kmod_kbuild_dir} -name "*.ko" -type f -printf "%{findpat}\n" | sed 's|\.ko$||' | sort -u ) ; do + # update depmod.conf + module_weak_path=$(echo "$modules" | sed 's/[\/]*[^\/]*$//') + if [ -z "$module_weak_path" ]; then + module_weak_path=%{name} + else + module_weak_path=%{name}/$module_weak_path + fi + echo "override $(echo $modules | sed 's/.*\///')" \ + "$(echo "%{kmod_kernel_version_dep}" | + sed 's/\.[^\.]*$//; + s/\([.+?^$\/\\|()\[]\|\]\)/\\\0/g').*" \ + "weak-updates/$module_weak_path" >> source/depmod.conf - kernel_source="${src:+.}/usr/src/kernels/${kver}.%(arch)" - kernel_source="$(realpath "${kernel_source}")" - PWD_PATH=$(realpath --relative-to="${kernel_source}" . 2>/dev/null || echo "$PWD") - %{make_build} -C ${kernel_source} V=1 M="$PWD_PATH/obj.${kver}/%{kmod_kbuild_dir}" \ - NOSTDINC_FLAGS="-I$PWD_PATH/obj.${kver}/include -I$PWD_PATH/obj.${kver}/include/uapi %{nil}" \ - EXTRA_CFLAGS="%{nil}" \ - %{nil} - # mark modules executable so that strip-to-file can strip them - find obj.${kver}/%{kmod_kbuild_dir} -name "*.ko" -type f -exec chmod u+x '{}' + - - whitelist="/lib/modules/kabi-current/kabi_whitelist_%{_target_cpu}" - for modules in $( find obj.${kver}/%{kmod_kbuild_dir} -name "*.ko" -type f -printf "%{findpat}\n" | sed 's|\.ko$||' | sort -u ) ; do - ## update depmod.conf - #module_weak_path=$(echo "$modules" | sed 's/[\/]*[^\/]*$//') - #if [ -z "$module_weak_path" ]; then - # module_weak_path=%{name} - #else - # module_weak_path=%{name}/$module_weak_path - #fi - #echo "override $(echo $modules | sed 's/.*\///')" \ - # "$(echo "%{kmod_kernel_version_dep}" | - # sed 's/\.[^\.]*$//; - # s/\([.+?^$\/\\|()\[]\|\]\)/\\\0/g').*" \ - # "weak-updates/$module_weak_path" >> source/depmod.conf - - # update greylist - nm -u obj.${kver}/%{kmod_kbuild_dir}/$modules.ko | sed 's/.*U //' | sed 's/^\.//' | sort -u | while read -r symbol; do - grep -q "^\s*$symbol\$" $whitelist || echo "$symbol" >> source/greylist - done + # update greylist + nm -u obj/%{kmod_kbuild_dir}/$modules.ko | sed 's/.*U //' | sed 's/^\.//' | sort -u | while read -r symbol; do + grep -q "^\s*$symbol\$" $whitelist || echo "$symbol" >> source/greylist done - sort -u source/greylist | uniq > source/greylist.txt.${kver} - - [ "x${kver}" != "x%{kmod_kernel_version}" ] || cp source/greylist.txt.${kver} source/greylist.txt done - -# Custom depmod conf to avoid touching the GA kernel -echo "override oracleasm 4\.18\.0-425\.[1-9][0-9][0-9]* weak-updates/kmod-redhat-oracleasm" > source/depmod.conf +sort -u source/greylist | uniq > source/greylist.txt %install export INSTALL_MOD_PATH=$RPM_BUILD_ROOT - -for name_kver in %{kmod_list}; do - rpm_name="${name_kver%%%%:*}" - kver="${name_kver#*:}" - install_path="${kver#*:}" - install_path="${install_path%%:*}" - kver="${kver%%%%:*}" - src="${name_kver##*:}" - - export INSTALL_MOD_DIR=${install_path} - - kernel_source="${src:+.}/usr/src/kernels/${kver}.%(arch)" - kernel_source="$(realpath "${kernel_source}")" - PWD_PATH=$(realpath --relative-to="${kernel_source}" . 2>/dev/null || echo "$PWD") - make -C "${kernel_source}" V=1 modules_install \ - M=$PWD_PATH/obj.${kver}/%{kmod_kbuild_dir} - - install -m 644 -D source/greylist.txt.${kver} $RPM_BUILD_ROOT/usr/share/doc/%{kmod_rpm_name}/greylist.txt.${kver} -done - +export INSTALL_MOD_DIR=%{kmod_install_path} +PWD_PATH="$PWD" +%if "%{workaround_no_pwd_rel_path}" != "1" +PWD_PATH=$(realpath --relative-to="%{kernel_source}" . 2>/dev/null || echo "$PWD") +%endif +make -C %{kernel_source} modules_install \ + M=$PWD_PATH/obj/%{kmod_kbuild_dir} # Cleanup unnecessary kernel-generated module dependency files. find $INSTALL_MOD_PATH/lib/modules -iname 'modules.*' -exec rm {} \; @@ -315,9 +219,11 @@ install -m 644 -D source/greylist.txt $RPM_BUILD_ROOT/usr/share/doc/%{kmod_rpm_n rm -rf $RPM_BUILD_ROOT %changelog -* Wed Jan 04 2023 Eugene Syromiatnikov 2.0.8-15.1 -- Build against kernel-4.18.0-425.10.1.el8_7 in addition to GA kernel - (#2155759). +* Wed Jan 04 2023 Eugene Syromiatnikov 2.0.8-17 +- Rebuild against kernel-4.18.0-444.el8 (#2148239). + +* Mon Dec 12 2022 Eugene Syromiatnikov 2.0.8-16 +- Rebuild against kernel-4.18.0-440.el8 (#2148239). * Mon Aug 29 2022 Eugene Syromiatnikov 2.0.8-15 - Rebuild against kernel-4.18.0-423.el8 (#2117753).