From 68788991f84facdb430b2666904847e71d78bcc8 Mon Sep 17 00:00:00 2001 From: Peter Georg Date: Jul 26 2021 19:54:50 +0000 Subject: Initial version --- diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..0eb67a8 --- /dev/null +++ b/.gitignore @@ -0,0 +1 @@ +SOURCES/mpt3sas-4.18.0-310.el8.tar.xz diff --git a/.kmod-mpt3sas.metadata b/.kmod-mpt3sas.metadata new file mode 100644 index 0000000..7866161 --- /dev/null +++ b/.kmod-mpt3sas.metadata @@ -0,0 +1 @@ +2e5fda09ba0b6f8e5dae30f125688c6fefd7dbc0 SOURCES/mpt3sas-4.18.0-310.el8.tar.xz diff --git a/SOURCES/0001-add-deprecated-ids.patch b/SOURCES/0001-add-deprecated-ids.patch new file mode 100644 index 0000000..3996c17 --- /dev/null +++ b/SOURCES/0001-add-deprecated-ids.patch @@ -0,0 +1,37 @@ +--- a/src/mpt3sas_scsih.c ++++ b/src/mpt3sas_scsih.c +@@ -12274,6 +12274,24 @@ + * The pci device ids are defined in mpi/mpi2_cnfg.h. + */ + static const struct pci_device_id mpt3sas_pci_table[] = { ++ /* Spitfire ~ 2004 */ ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2004, ++ PCI_ANY_ID, PCI_ANY_ID }, ++ /* Falcon ~ 2008 */ ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2008, ++ PCI_ANY_ID, PCI_ANY_ID }, ++ /* Liberator ~ 2108 */ ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2108_1, ++ PCI_ANY_ID, PCI_ANY_ID }, ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2108_2, ++ PCI_ANY_ID, PCI_ANY_ID }, ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2108_3, ++ PCI_ANY_ID, PCI_ANY_ID }, ++ /* Meteor ~ 2116 */ ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2116_1, ++ PCI_ANY_ID, PCI_ANY_ID }, ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2116_2, ++ PCI_ANY_ID, PCI_ANY_ID }, + /* Thunderbolt ~ 2208 */ + { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SAS2208_1, + PCI_ANY_ID, PCI_ANY_ID }, +@@ -12298,6 +12316,9 @@ + PCI_ANY_ID, PCI_ANY_ID }, + { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SWITCH_MPI_EP_1, + PCI_ANY_ID, PCI_ANY_ID }, ++ /* SSS6200 */ ++ { MPI2_MFGPAGE_VENDORID_LSI, MPI2_MFGPAGE_DEVID_SSS6200, ++ PCI_ANY_ID, PCI_ANY_ID }, + /* Fury ~ 3004 and 3008 */ + { MPI2_MFGPAGE_VENDORID_LSI, MPI25_MFGPAGE_DEVID_SAS3004, + PCI_ANY_ID, PCI_ANY_ID }, diff --git a/SPECS/kmod-mpt3sas.spec b/SPECS/kmod-mpt3sas.spec new file mode 100644 index 0000000..67b0b63 --- /dev/null +++ b/SPECS/kmod-mpt3sas.spec @@ -0,0 +1,122 @@ +%global pkg mpt3sas + +%global kernel_version_min 4.18.0-310.el8 + +# To pick a specific kernel use `--define "kernel_version 4.18.0-315.el8"` +# Otherwise the latest installed kernel-devel version later than +# %%{kernel_version_min} will be used. + +%global kernel_version_latest %({ echo %{kernel_version_min}; rpm --query kernel-devel --queryformat '%%{VERSION}-%%{RELEASE}\\\n' | grep -v "package kernel-devel is not installed"; } | sort -V | sed -e '0,/^%{kernel_version_min}$/d' | tail -n 1) + +%if "%{kernel_version_latest}" != "" +%{!?kernel_version:%{expand:%%global kernel_version %{kernel_version_latest}}} +%endif + +%global _use_internal_dependency_generator 0 + +%global debug_package %{nil} + +%global __spec_install_post \ + %{?__debug_package:%{__debug_install_post}} \ + %{__arch_install_post} \ + %{__os_install_post} \ + %{__mod_compress_install_post} + +%global __mod_compress_install_post find %{buildroot}/lib/modules -type f -name \*.ko -exec xz \{\} \\; + + +Name: kmod-%{pkg} +Version: 4.18.0 +Release: 310%{?dist} +Summary: LSI MPT Fusion SAS 3.0 Device (%{pkg}) driver + +License: GPLv2 +URL: https://www.kernel.org/ + +Source0: %{pkg}-%{kernel_version_min}.tar.xz +Patch1: 0001-add-deprecated-ids.patch + +ExclusiveArch: x86_64 aarch64 + +BuildRequires: elfutils-libelf-devel +BuildRequires: gcc +BuildRequires: kernel-abi-whitelists +BuildRequires: kernel-rpm-macros +BuildRequires: kmod +BuildRequires: make +BuildRequires: redhat-rpm-config +BuildRequires: xz + +%{!?kernel_version: +BuildRequires: kernel-devel >= %{kernel_version_min} +} + +%{?kernel_version: +BuildRequires: kernel-devel = %{kernel_version} + +Supplements: kernel = %{kernel_version} + +Requires: (kernel = %{kernel_version} if kernel) + +Provides: kernel-modules = %{kernel_version}.%{_arch} +} + +Requires(post): /usr/sbin/depmod +Requires(postun): /usr/sbin/depmod + +Provides: %{name} = %{?epoch:%{epoch}:}%{version}-%{release} + + +%description +This package provides the LSI MPT Fusion SAS 3.0 Device (%{pkg}) driver. +Compared to the in-kernel driver this driver re-enables support for deprecated +mpt2sas adapters: + +- 0x1000:0x0064: LSI SAS2116_1 +- 0x1000:0x0065: LSI SAS2116_2 +- 0x1000:0x0070: LSI SAS2004 +- 0x1000:0x0072: LSI SAS2008 +- 0x1000:0x0074: LSI SAS2108_1 +- 0x1000:0x0076: LSI SAS2108_2 +- 0x1000:0x0077: LSI SAS2108_3 +- 0x1000:0x007E: LSI SSS6200 + + +%prep +%autosetup -p1 -n %{pkg}-%{kernel_version_min} + + +%build +pushd src +%{__make} -C /usr/src/kernels/%{kernel_version}.%{_arch} %{?_smp_mflags} M=$PWD modules +popd + + +%install +%{__install} -D -t %{buildroot}/lib/modules/%{kernel_version}.%{_arch}/extra/drivers/scsi/%{pkg} src/%{pkg}.ko + +# Make .ko objects temporarily executable for automatic stripping +find %{buildroot}/lib/modules -type f -name \*.ko -exec chmod u+x \{\} \+ + + +%clean +%{__rm} -rf %{buildroot} + + +%post +/usr/sbin/depmod -aeF /lib/modules/%{kernel_version}.%{_arch}/System.map %{kernel_version}.%{_arch} + + +%postun +/usr/sbin/depmod -aeF /lib/modules/%{kernel_version}.%{_arch}/System.map %{kernel_version}.%{_arch} + + +%files +%defattr(644,root,root,755) +/lib/modules/%{kernel_version}.%{_arch} +%license COPYING + + +%changelog +* Fri Jul 23 2021 Peter Georg - 4.18-310 +- Initial version