From f78e4ceee558177de4503c0c220587ef587820ef Mon Sep 17 00:00:00 2001 From: Peter Georg Date: Oct 28 2021 06:28:35 +0000 Subject: Convert to kABI-tracking kmod package --- diff --git a/.gitignore b/.gitignore index 8f75746..a2c037a 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1 @@ -SOURCES/lpfc-4.18.0-305.17.1.el8_4.tar.xz +SOURCES/lpfc-4.18.0-305.el8.tar.xz diff --git a/.kmod-lpfc.metadata b/.kmod-lpfc.metadata index 2ad27a3..6f936ab 100644 --- a/.kmod-lpfc.metadata +++ b/.kmod-lpfc.metadata @@ -1 +1 @@ -7f337111451f4bed06fa43d5bcd389243c36ed42 SOURCES/lpfc-4.18.0-305.17.1.el8_4.tar.xz +de9f815f89072314f73e33dc1c215212d27441a0 SOURCES/lpfc-4.18.0-305.el8.tar.xz diff --git a/SPECS/kmod-lpfc.spec b/SPECS/kmod-lpfc.spec index 595b364..de2d36d 100644 --- a/SPECS/kmod-lpfc.spec +++ b/SPECS/kmod-lpfc.spec @@ -1,12 +1,12 @@ %global pkg lpfc -%global driver_version 4.18.0-305.17.1.el8_4 +%global driver_version 4.18.0-305.el8 -%global kernel_version 4.18.0-305.19.1.el8_4 +%global kernel_version 4.18.0-305.3.1.el8_4 %global _use_internal_dependency_generator 0 -%global __find_requires %{nil} -%global __find_provides /usr/lib/rpm/find-provides +%global __find_requires /usr/lib/rpm/redhat/find-requires +%global __find_provides /usr/lib/rpm/redhat/find-provides %global debug_package %{nil} @@ -20,8 +20,8 @@ Name: kmod-%{pkg} -Version: 4.18.0 -Release: 305.19.1%{?dist} +Version: 4.18.0.305 +Release: 1%{?dist} Summary: Emulex LightPulse Fibre Channel SCSI (%{pkg}) driver License: GPLv2 @@ -34,28 +34,29 @@ ExclusiveArch: x86_64 aarch64 BuildRequires: elfutils-libelf-devel BuildRequires: gcc +BuildRequires: kernel-rpm-macros BuildRequires: kmod BuildRequires: make BuildRequires: redhat-rpm-config BuildRequires: xz +BuildRequires: kernel-abi-stablelists = %{kernel_version} BuildRequires: kernel-devel = %{kernel_version} BuildRequires: kernel-devel-uname-r = %{kernel_version}.%{_arch} -Requires: kernel-core = %{kernel_version} -Requires: kernel-core-uname-r = %{kernel_version}.%{_arch} -Requires: kernel-modules = %{kernel_version} -Requires: kernel-modules-uname-r = %{kernel_version}.%{_arch} +Requires: kernel >= %{kernel_version} +Requires: kernel-uname-r >= %{kernel_version}.%{_arch} +Requires: kernel-modules >= %{kernel_version} +Requires: kernel-modules-uname-r >= %{kernel_version}.%{_arch} Provides: installonlypkg(kernel-module) -Provides: kernel-modules = %{kernel_version}.%{_arch} -Provides: %{name}-%{kernel_version}.%{_arch} = %{?epoch:%{epoch}:}%{version}-%{release} +Provides: kernel-modules >= %{kernel_version}.%{_arch} -Requires(post): /usr/sbin/depmod -Requires(postun): /usr/sbin/depmod +Requires(post): %{_sbindir}/depmod +Requires(postun): %{_sbindir}/depmod -Requires(post): /usr/bin/dracut -Requires(postun): /usr/bin/dracut +Requires(post): %{_sbindir}/weak-modules +Requires(postun): %{_sbindir}/weak-modules %description @@ -119,6 +120,13 @@ popd # Make .ko objects temporarily executable for automatic stripping find %{buildroot}/lib/modules -type f -name \*.ko -exec chmod u+x \{\} \+ +# Generate depmod.conf +%{__install} -d %{buildroot}/%{_sysconfdir}/depmod.d/ +for kmod in $(find %{buildroot}/lib/modules/%{kernel_version}.%{_arch}/extra -type f -name \*.ko -printf "%%P\n" | sort) +do + echo "override $(basename $kmod .ko) * weak-updates/$(dirname $kmod)" >> %{buildroot}/%{_sysconfdir}/depmod.d/%{pkg}.conf +done + %clean %{__rm} -rf %{buildroot} @@ -126,63 +134,36 @@ find %{buildroot}/lib/modules -type f -name \*.ko -exec chmod u+x \{\} \+ %post mkdir -p %{_localstatedir}/lib/rpm-state/sig-kmods -touch %{_localstatedir}/lib/rpm-state/sig-kmods/%{kernel_version}.%{_arch} +printf '%s\n' "/lib/modules/%{kernel_version}.%{_arch}/extra/drivers/scsi/%{pkg}/%{pkg}.ko.xz" >> %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-add %preun mkdir -p %{_localstatedir}/lib/rpm-state/sig-kmods -touch %{_localstatedir}/lib/rpm-state/sig-kmods/%{kernel_version}.%{_arch} +rpm -ql kmod-%{pkg}-%{?epoch:%{epoch}:}%{version}-%{release}.%{_arch} | grep '/lib/modules/%{kernel_version}.%{_arch}/.*\.ko\.xz$' >> %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-remove %postun -if [ -f %{_localstatedir}/lib/rpm-state/sig-kmods/%{kernel_version}.%{_arch} ] +if [ -f %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-remove ] then - if [ -f /lib/modules/%{kernel_version}.%{_arch}/System.map ] - then - /usr/sbin/depmod -aeF /lib/modules/%{kernel_version}.%{_arch}/System.map %{kernel_version}.%{_arch} - fi - - if [ -f /boot/initramfs-%{kernel_version}.%{_arch}.img ] - then - if /usr/bin/dracut -f --rebuild /boot/initramfs-%{kernel_version}.%{_arch}.img /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew %{kernel_version}.%{_arch} - then - if ! cmp -s /boot/initramfs-%{kernel_version}.%{_arch}.img /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew - then - mv /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew /boot/initramfs-%{kernel_version}.%{_arch}.img - else - rm -f /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew - fi - fi - fi - - rm -f %{_localstatedir}/lib/rpm-state/sig-kmods/%{kernel_version}.%{_arch} + modules=( $(cat %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-remove) ) + rm -f %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-remove rmdir --ignore-fail-on-non-empty %{_localstatedir}/lib/rpm-state/sig-kmods + printf '%s\n' "${modules[@]}" | %{_sbindir}/weak-modules --remove-modules fi +%pretrans -p +posix.unlink("%{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-add") +posix.unlink("%{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-remove") + + %posttrans -if [ -f %{_localstatedir}/lib/rpm-state/sig-kmods/%{kernel_version}.%{_arch} ] +if [ -f %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-add ] then - if [ -f /lib/modules/%{kernel_version}.%{_arch}/System.map ] - then - /usr/sbin/depmod -aeF /lib/modules/%{kernel_version}.%{_arch}/System.map %{kernel_version}.%{_arch} - fi - - if [ -f /boot/initramfs-%{kernel_version}.%{_arch}.img ] - then - if /usr/bin/dracut -f --rebuild /boot/initramfs-%{kernel_version}.%{_arch}.img /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew %{kernel_version}.%{_arch} - then - if ! cmp -s /boot/initramfs-%{kernel_version}.%{_arch}.img /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew - then - mv /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew /boot/initramfs-%{kernel_version}.%{_arch}.img - else - rm -f /boot/initramfs-%{kernel_version}.%{_arch}.img.rpmnew - fi - fi - fi - - rm -f %{_localstatedir}/lib/rpm-state/sig-kmods/%{kernel_version}.%{_arch} + modules=( $(cat %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-add) ) + rm -f %{_localstatedir}/lib/rpm-state/sig-kmods/weak-modules-add rmdir --ignore-fail-on-non-empty %{_localstatedir}/lib/rpm-state/sig-kmods + printf '%s\n' "${modules[@]}" | %{_sbindir}/weak-modules --add-modules fi @@ -190,9 +171,16 @@ fi %defattr(644,root,root,755) /lib/modules/%{kernel_version}.%{_arch} %license COPYING +%config(noreplace) %{_sysconfdir}/depmod.d/%{pkg}.conf %changelog +* Thu Oct 28 2021 Peter Georg - 4.18.0.305-1 +- Convert to kABI tracking kmod package (kernel >= 4.18.0-305.3.1.el8) +- Build 4.18.0-305.el8 for 4.18.0-305.3.1.el8_4 +- Use release number independent of kernel +- Add driver release number to version + * Wed Sep 15 2021 Peter Georg - 4.18.0-305.19.1 - Rebuild for 4.18.0-305.19.1.el8_4