kernel-5.16-0.rc4.20211208git2a987e65025e.31
* Wed Dec 08 2021 Fedora Kernel Team <kernel-team@fedoraproject.org> [5.16-0.rc4.20211208git2a987e65025e.31] - common: arm64: ensure all the required arm64 errata are enabled (Peter Robinson) - kernel/rh_taint.c: Update to new messaging (Prarit Bhargava) [2019377] Resolves: rhbz#2019377 Signed-off-by: Justin M. Forbes <jforbes@fedoraproject.org>
This commit is contained in:
parent
f809de26bb
commit
19ab2fd97b
@ -12,7 +12,7 @@ RHEL_MINOR = 99
|
|||||||
#
|
#
|
||||||
# Use this spot to avoid future merge conflicts.
|
# Use this spot to avoid future merge conflicts.
|
||||||
# Do not trim this comment.
|
# Do not trim this comment.
|
||||||
RHEL_RELEASE = 30
|
RHEL_RELEASE = 31
|
||||||
|
|
||||||
#
|
#
|
||||||
# Early y+1 numbering
|
# Early y+1 numbering
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
https://gitlab.com/cki-project/kernel-ark/-/commit/32e41db9e05fedb40cae321e08e02668f030fd61
|
||||||
|
32e41db9e05fedb40cae321e08e02668f030fd61 kernel/rh_taint.c: Update to new messaging
|
||||||
|
|
||||||
https://gitlab.com/cki-project/kernel-ark/-/commit/07b3d9b051aa347237b4c637a1984c1915c750b2
|
https://gitlab.com/cki-project/kernel-ark/-/commit/07b3d9b051aa347237b4c637a1984c1915c750b2
|
||||||
07b3d9b051aa347237b4c637a1984c1915c750b2 Enable e1000 in rhel9 as unsupported
|
07b3d9b051aa347237b4c637a1984c1915c750b2 Enable e1000 in rhel9 as unsupported
|
||||||
|
|
||||||
|
18
kernel.spec
18
kernel.spec
@ -87,7 +87,7 @@ Summary: The Linux kernel
|
|||||||
# the --with-release option overrides this setting.)
|
# the --with-release option overrides this setting.)
|
||||||
%define debugbuildsenabled 0
|
%define debugbuildsenabled 0
|
||||||
|
|
||||||
%global distro_build 0.rc4.20211207gitcd8c917a56f2.30
|
%global distro_build 0.rc4.20211208git2a987e65025e.31
|
||||||
|
|
||||||
%if 0%{?fedora}
|
%if 0%{?fedora}
|
||||||
%define secure_boot_arch x86_64
|
%define secure_boot_arch x86_64
|
||||||
@ -132,13 +132,13 @@ Summary: The Linux kernel
|
|||||||
|
|
||||||
%define rpmversion 5.16.0
|
%define rpmversion 5.16.0
|
||||||
%define patchversion 5.16
|
%define patchversion 5.16
|
||||||
%define pkgrelease 0.rc4.20211207gitcd8c917a56f2.30
|
%define pkgrelease 0.rc4.20211208git2a987e65025e.31
|
||||||
|
|
||||||
# This is needed to do merge window version magic
|
# This is needed to do merge window version magic
|
||||||
%define patchlevel 16
|
%define patchlevel 16
|
||||||
|
|
||||||
# allow pkg_release to have configurable %%{?dist} tag
|
# allow pkg_release to have configurable %%{?dist} tag
|
||||||
%define specrelease 0.rc4.20211207gitcd8c917a56f2.30%{?buildid}%{?dist}
|
%define specrelease 0.rc4.20211208git2a987e65025e.31%{?buildid}%{?dist}
|
||||||
|
|
||||||
%define pkg_release %{specrelease}
|
%define pkg_release %{specrelease}
|
||||||
|
|
||||||
@ -689,7 +689,7 @@ BuildRequires: lld
|
|||||||
# exact git commit you can run
|
# exact git commit you can run
|
||||||
#
|
#
|
||||||
# xzcat -qq ${TARBALL} | git get-tar-commit-id
|
# xzcat -qq ${TARBALL} | git get-tar-commit-id
|
||||||
Source0: linux-5.16-rc4-12-gcd8c917a56f2.tar.xz
|
Source0: linux-5.16-rc4-31-g2a987e65025e.tar.xz
|
||||||
|
|
||||||
Source1: Makefile.rhelver
|
Source1: Makefile.rhelver
|
||||||
|
|
||||||
@ -1383,8 +1383,8 @@ ApplyOptionalPatch()
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
%setup -q -n kernel-5.16-rc4-12-gcd8c917a56f2 -c
|
%setup -q -n kernel-5.16-rc4-31-g2a987e65025e -c
|
||||||
mv linux-5.16-rc4-12-gcd8c917a56f2 linux-%{KVERREL}
|
mv linux-5.16-rc4-31-g2a987e65025e linux-%{KVERREL}
|
||||||
|
|
||||||
cd linux-%{KVERREL}
|
cd linux-%{KVERREL}
|
||||||
cp -a %{SOURCE1} .
|
cp -a %{SOURCE1} .
|
||||||
@ -2193,7 +2193,7 @@ InitBuildVars
|
|||||||
%global perf_build_extra_opts CORESIGHT=1
|
%global perf_build_extra_opts CORESIGHT=1
|
||||||
%endif
|
%endif
|
||||||
%global perf_make \
|
%global perf_make \
|
||||||
%{__make} %{?make_opts} EXTRA_CFLAGS="${RPM_OPT_FLAGS}" LDFLAGS="%{__global_ldflags}" %{?cross_opts} -C tools/perf V=1 NO_PERF_READ_VDSO32=1 NO_PERF_READ_VDSOX32=1 WERROR=0 NO_LIBUNWIND=1 HAVE_CPLUS_DEMANGLE=1 NO_GTK2=1 NO_STRLCPY=1 NO_BIONIC=1 LIBTRACEEVENT_DYNAMIC=1 %{?perf_build_extra_opts} prefix=%{_prefix} PYTHON=%{__python3}
|
%{__make} %{?make_opts} EXTRA_CFLAGS="${RPM_OPT_FLAGS}" LDFLAGS="%{__global_ldflags}" %{?cross_opts} -C tools/perf V=1 NO_PERF_READ_VDSO32=1 NO_PERF_READ_VDSOX32=1 WERROR=0 NO_LIBUNWIND=1 HAVE_CPLUS_DEMANGLE=1 NO_GTK2=1 NO_STRLCPY=1 NO_BIONIC=1 LIBBPF_DYNAMIC=1 LIBTRACEEVENT_DYNAMIC=1 %{?perf_build_extra_opts} prefix=%{_prefix} PYTHON=%{__python3}
|
||||||
%if %{with_perf}
|
%if %{with_perf}
|
||||||
# perf
|
# perf
|
||||||
# make sure check-headers.sh is executable
|
# make sure check-headers.sh is executable
|
||||||
@ -2981,6 +2981,10 @@ fi
|
|||||||
#
|
#
|
||||||
#
|
#
|
||||||
%changelog
|
%changelog
|
||||||
|
* Wed Dec 08 2021 Fedora Kernel Team <kernel-team@fedoraproject.org> [5.16-0.rc4.20211208git2a987e65025e.31]
|
||||||
|
- common: arm64: ensure all the required arm64 errata are enabled (Peter Robinson)
|
||||||
|
- kernel/rh_taint.c: Update to new messaging (Prarit Bhargava) [2019377]
|
||||||
|
|
||||||
* Tue Dec 07 2021 Fedora Kernel Team <kernel-team@fedoraproject.org> [5.16-0.rc4.20211207gitcd8c917a56f2.30]
|
* Tue Dec 07 2021 Fedora Kernel Team <kernel-team@fedoraproject.org> [5.16-0.rc4.20211207gitcd8c917a56f2.30]
|
||||||
- redhat/configs: enable CONFIG_AMD_PTDMA for ark (John W. Linville)
|
- redhat/configs: enable CONFIG_AMD_PTDMA for ark (John W. Linville)
|
||||||
- redhat/configs: enable CONFIG_RD_ZSTD for rhel (Tao Liu) [2020132]
|
- redhat/configs: enable CONFIG_RD_ZSTD for rhel (Tao Liu) [2020132]
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
arch/s390/kernel/ipl.c | 5 +
|
arch/s390/kernel/ipl.c | 5 +
|
||||||
arch/s390/kernel/setup.c | 4 +
|
arch/s390/kernel/setup.c | 4 +
|
||||||
arch/x86/kernel/cpu/common.c | 1 +
|
arch/x86/kernel/cpu/common.c | 1 +
|
||||||
arch/x86/kernel/setup.c | 69 ++++-
|
arch/x86/kernel/setup.c | 70 ++++-
|
||||||
crypto/rng.c | 73 ++++-
|
crypto/rng.c | 73 ++++-
|
||||||
drivers/acpi/apei/hest.c | 8 +
|
drivers/acpi/apei/hest.c | 8 +
|
||||||
drivers/acpi/irq.c | 17 +-
|
drivers/acpi/irq.c | 17 +-
|
||||||
@ -27,13 +27,13 @@
|
|||||||
drivers/iommu/iommu.c | 22 ++
|
drivers/iommu/iommu.c | 22 ++
|
||||||
drivers/message/fusion/mptsas.c | 10 +
|
drivers/message/fusion/mptsas.c | 10 +
|
||||||
drivers/message/fusion/mptspi.c | 11 +
|
drivers/message/fusion/mptspi.c | 11 +
|
||||||
drivers/net/ethernet/intel/e1000/e1000_main.c | 5 +
|
drivers/net/ethernet/intel/e1000/e1000_main.c | 2 +
|
||||||
drivers/net/team/team.c | 2 +
|
drivers/net/team/team.c | 2 +
|
||||||
drivers/net/wireguard/main.c | 7 +
|
drivers/net/wireguard/main.c | 7 +
|
||||||
drivers/nvme/host/core.c | 22 +-
|
drivers/nvme/host/core.c | 22 +-
|
||||||
drivers/nvme/host/multipath.c | 19 +-
|
drivers/nvme/host/multipath.c | 19 +-
|
||||||
drivers/nvme/host/nvme.h | 4 +
|
drivers/nvme/host/nvme.h | 4 +
|
||||||
drivers/pci/pci-driver.c | 29 ++
|
drivers/pci/pci-driver.c | 79 ++++++
|
||||||
drivers/pci/quirks.c | 24 ++
|
drivers/pci/quirks.c | 24 ++
|
||||||
drivers/scsi/aacraid/linit.c | 2 +
|
drivers/scsi/aacraid/linit.c | 2 +
|
||||||
drivers/scsi/be2iscsi/be_main.c | 2 +
|
drivers/scsi/be2iscsi/be_main.c | 2 +
|
||||||
@ -47,12 +47,12 @@
|
|||||||
fs/ext4/super.c | 5 +
|
fs/ext4/super.c | 5 +
|
||||||
fs/xfs/xfs_super.c | 5 +
|
fs/xfs/xfs_super.c | 5 +
|
||||||
include/linux/efi.h | 22 +-
|
include/linux/efi.h | 22 +-
|
||||||
include/linux/kernel.h | 17 ++
|
include/linux/kernel.h | 19 ++
|
||||||
include/linux/lsm_hook_defs.h | 2 +
|
include/linux/lsm_hook_defs.h | 2 +
|
||||||
include/linux/lsm_hooks.h | 6 +
|
include/linux/lsm_hooks.h | 6 +
|
||||||
include/linux/module.h | 1 +
|
include/linux/module.h | 1 +
|
||||||
include/linux/panic.h | 19 +-
|
include/linux/panic.h | 19 +-
|
||||||
include/linux/pci.h | 4 +
|
include/linux/pci.h | 16 ++
|
||||||
include/linux/random.h | 7 +
|
include/linux/random.h | 7 +
|
||||||
include/linux/rh_kabi.h | 297 +++++++++++++++++++++
|
include/linux/rh_kabi.h | 297 +++++++++++++++++++++
|
||||||
include/linux/rmi.h | 1 +
|
include/linux/rmi.h | 1 +
|
||||||
@ -63,7 +63,7 @@
|
|||||||
kernel/module.c | 2 +
|
kernel/module.c | 2 +
|
||||||
kernel/module_signing.c | 9 +-
|
kernel/module_signing.c | 9 +-
|
||||||
kernel/panic.c | 14 +
|
kernel/panic.c | 14 +
|
||||||
kernel/rh_taint.c | 109 ++++++++
|
kernel/rh_messages.c | 179 +++++++++++++
|
||||||
kernel/sysctl.c | 5 +
|
kernel/sysctl.c | 5 +
|
||||||
mm/cma.c | 10 +
|
mm/cma.c | 10 +
|
||||||
scripts/mod/modpost.c | 8 +
|
scripts/mod/modpost.c | 8 +
|
||||||
@ -72,7 +72,7 @@
|
|||||||
security/lockdown/Kconfig | 13 +
|
security/lockdown/Kconfig | 13 +
|
||||||
security/lockdown/lockdown.c | 1 +
|
security/lockdown/lockdown.c | 1 +
|
||||||
security/security.c | 6 +
|
security/security.c | 6 +
|
||||||
74 files changed, 1381 insertions(+), 188 deletions(-)
|
74 files changed, 1513 insertions(+), 188 deletions(-)
|
||||||
|
|
||||||
diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt
|
diff --git a/Documentation/admin-guide/kernel-parameters.txt b/Documentation/admin-guide/kernel-parameters.txt
|
||||||
index 9725c546a0d4..4d440bdcf5b9 100644
|
index 9725c546a0d4..4d440bdcf5b9 100644
|
||||||
@ -270,7 +270,7 @@ index 0083464de5e3..2de5f417f3f2 100644
|
|||||||
setup_force_cpu_cap(X86_FEATURE_CPUID);
|
setup_force_cpu_cap(X86_FEATURE_CPUID);
|
||||||
cpu_parse_early_param();
|
cpu_parse_early_param();
|
||||||
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
|
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
|
||||||
index 6a190c7f4d71..3fbfbf6ed21c 100644
|
index 6a190c7f4d71..f1e635696e01 100644
|
||||||
--- a/arch/x86/kernel/setup.c
|
--- a/arch/x86/kernel/setup.c
|
||||||
+++ b/arch/x86/kernel/setup.c
|
+++ b/arch/x86/kernel/setup.c
|
||||||
@@ -20,6 +20,7 @@
|
@@ -20,6 +20,7 @@
|
||||||
@ -289,7 +289,7 @@ index 6a190c7f4d71..3fbfbf6ed21c 100644
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* max_low_pfn_mapped: highest directly mapped pfn < 4 GB
|
* max_low_pfn_mapped: highest directly mapped pfn < 4 GB
|
||||||
@@ -723,6 +725,50 @@ static void __init early_reserve_memory(void)
|
@@ -723,6 +725,51 @@ static void __init early_reserve_memory(void)
|
||||||
trim_snb_memory();
|
trim_snb_memory();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -320,7 +320,8 @@ index 6a190c7f4d71..3fbfbf6ed21c 100644
|
|||||||
+ pr_crit("Detected processor %s %s\n",
|
+ pr_crit("Detected processor %s %s\n",
|
||||||
+ boot_cpu_data.x86_vendor_id,
|
+ boot_cpu_data.x86_vendor_id,
|
||||||
+ boot_cpu_data.x86_model_id);
|
+ boot_cpu_data.x86_model_id);
|
||||||
+ mark_hardware_unsupported("Processor");
|
+ mark_hardware_unmaintained("x86 processor", "%s %s", boot_cpu_data.x86_vendor_id,
|
||||||
|
+ boot_cpu_data.x86_model_id);
|
||||||
+ break;
|
+ break;
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
@ -340,7 +341,7 @@ index 6a190c7f4d71..3fbfbf6ed21c 100644
|
|||||||
/*
|
/*
|
||||||
* Dump out kernel offset information on panic.
|
* Dump out kernel offset information on panic.
|
||||||
*/
|
*/
|
||||||
@@ -941,6 +987,13 @@ void __init setup_arch(char **cmdline_p)
|
@@ -941,6 +988,13 @@ void __init setup_arch(char **cmdline_p)
|
||||||
if (efi_enabled(EFI_BOOT))
|
if (efi_enabled(EFI_BOOT))
|
||||||
efi_init();
|
efi_init();
|
||||||
|
|
||||||
@ -354,7 +355,7 @@ index 6a190c7f4d71..3fbfbf6ed21c 100644
|
|||||||
dmi_setup();
|
dmi_setup();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -1106,19 +1159,7 @@ void __init setup_arch(char **cmdline_p)
|
@@ -1106,19 +1160,7 @@ void __init setup_arch(char **cmdline_p)
|
||||||
/* Allocate bigger log buffer */
|
/* Allocate bigger log buffer */
|
||||||
setup_log_buf(1);
|
setup_log_buf(1);
|
||||||
|
|
||||||
@ -375,7 +376,7 @@ index 6a190c7f4d71..3fbfbf6ed21c 100644
|
|||||||
|
|
||||||
reserve_initrd();
|
reserve_initrd();
|
||||||
|
|
||||||
@@ -1231,6 +1272,8 @@ void __init setup_arch(char **cmdline_p)
|
@@ -1231,6 +1273,8 @@ void __init setup_arch(char **cmdline_p)
|
||||||
efi_apply_memmap_quirks();
|
efi_apply_memmap_quirks();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -1491,30 +1492,27 @@ index acd4805dcf83..5f814d447ab3 100644
|
|||||||
|
|
||||||
out_mptspi_probe:
|
out_mptspi_probe:
|
||||||
diff --git a/drivers/net/ethernet/intel/e1000/e1000_main.c b/drivers/net/ethernet/intel/e1000/e1000_main.c
|
diff --git a/drivers/net/ethernet/intel/e1000/e1000_main.c b/drivers/net/ethernet/intel/e1000/e1000_main.c
|
||||||
index 669060a2e6aa..49b17169987d 100644
|
index 669060a2e6aa..befd1f254436 100644
|
||||||
--- a/drivers/net/ethernet/intel/e1000/e1000_main.c
|
--- a/drivers/net/ethernet/intel/e1000/e1000_main.c
|
||||||
+++ b/drivers/net/ethernet/intel/e1000/e1000_main.c
|
+++ b/drivers/net/ethernet/intel/e1000/e1000_main.c
|
||||||
@@ -224,6 +224,11 @@ static int __init e1000_init_module(void)
|
@@ -933,6 +933,8 @@ static int e1000_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
|
||||||
|
int bars, need_ioport;
|
||||||
|
bool disable_dev = false;
|
||||||
|
|
||||||
pr_info("%s\n", e1000_copyright);
|
+ pci_hw_unmaintained(e1000_pci_tbl, pdev);
|
||||||
|
|
||||||
+#ifdef CONFIG_RHEL_DIFFERENCES
|
|
||||||
+ add_taint(TAINT_SUPPORT_REMOVED, LOCKDEP_STILL_OK);
|
|
||||||
+ mark_driver_unsupported(e1000_driver_name);
|
|
||||||
+#endif
|
|
||||||
+
|
+
|
||||||
ret = pci_register_driver(&e1000_driver);
|
/* do not allocate ioport bars when not needed */
|
||||||
if (copybreak != COPYBREAK_DEFAULT) {
|
need_ioport = e1000_is_need_ioport(pdev);
|
||||||
if (copybreak == 0)
|
if (need_ioport) {
|
||||||
diff --git a/drivers/net/team/team.c b/drivers/net/team/team.c
|
diff --git a/drivers/net/team/team.c b/drivers/net/team/team.c
|
||||||
index 8b2adc56b92a..f0ad908048c6 100644
|
index 8b2adc56b92a..3263b33c9b69 100644
|
||||||
--- a/drivers/net/team/team.c
|
--- a/drivers/net/team/team.c
|
||||||
+++ b/drivers/net/team/team.c
|
+++ b/drivers/net/team/team.c
|
||||||
@@ -3045,6 +3045,8 @@ static int __init team_module_init(void)
|
@@ -3045,6 +3045,8 @@ static int __init team_module_init(void)
|
||||||
if (err)
|
if (err)
|
||||||
goto err_nl_init;
|
goto err_nl_init;
|
||||||
|
|
||||||
+ mark_hardware_deprecated(DRV_NAME);
|
+ mark_driver_deprecated(DRV_NAME);
|
||||||
+
|
+
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -1688,7 +1686,7 @@ index b334af8aa264..b2a0e2fc6d47 100644
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c
|
diff --git a/drivers/pci/pci-driver.c b/drivers/pci/pci-driver.c
|
||||||
index 588588cfda48..1b90c69b7718 100644
|
index 588588cfda48..5218a8c10a93 100644
|
||||||
--- a/drivers/pci/pci-driver.c
|
--- a/drivers/pci/pci-driver.c
|
||||||
+++ b/drivers/pci/pci-driver.c
|
+++ b/drivers/pci/pci-driver.c
|
||||||
@@ -19,6 +19,7 @@
|
@@ -19,6 +19,7 @@
|
||||||
@ -1699,37 +1697,87 @@ index 588588cfda48..1b90c69b7718 100644
|
|||||||
#include <linux/dma-map-ops.h>
|
#include <linux/dma-map-ops.h>
|
||||||
#include "pci.h"
|
#include "pci.h"
|
||||||
#include "pcie/portdrv.h"
|
#include "pcie/portdrv.h"
|
||||||
@@ -295,6 +296,34 @@ static struct attribute *pci_drv_attrs[] = {
|
@@ -295,6 +296,84 @@ static struct attribute *pci_drv_attrs[] = {
|
||||||
};
|
};
|
||||||
ATTRIBUTE_GROUPS(pci_drv);
|
ATTRIBUTE_GROUPS(pci_drv);
|
||||||
|
|
||||||
|
+#if CONFIG_RHEL_DIFFERENCES
|
||||||
+/**
|
+/**
|
||||||
+ * pci_hw_vendor_status - Tell if a PCI device is supported by the HW vendor
|
+ * pci_hw_deprecated - Tell if a PCI device is deprecated
|
||||||
+ * @ids: array of PCI device id structures to search in
|
+ * @ids: array of PCI device id structures to search in
|
||||||
+ * @dev: the PCI device structure to match against
|
+ * @dev: the PCI device structure to match against
|
||||||
+ *
|
+ *
|
||||||
+ * Used by a driver to check whether this device is in its list of unsupported
|
+ * Used by a driver to check whether this device is in its list of deprecated
|
||||||
+ * devices. Returns the matching pci_device_id structure or %NULL if there is
|
+ * devices. Returns the matching pci_device_id structure or %NULL if there is
|
||||||
+ * no match.
|
+ * no match.
|
||||||
+ *
|
+ *
|
||||||
+ * Reserved for Internal Red Hat use only.
|
+ * Reserved for Internal Red Hat use only.
|
||||||
+ */
|
+ */
|
||||||
+const struct pci_device_id *pci_hw_vendor_status(
|
+const struct pci_device_id *pci_hw_deprecated(const struct pci_device_id *ids,
|
||||||
+ const struct pci_device_id *ids,
|
+ struct pci_dev *dev)
|
||||||
+ struct pci_dev *dev)
|
|
||||||
+{
|
+{
|
||||||
+ char devinfo[64];
|
|
||||||
+ const struct pci_device_id *ret = pci_match_id(ids, dev);
|
+ const struct pci_device_id *ret = pci_match_id(ids, dev);
|
||||||
+
|
+
|
||||||
+ if (ret) {
|
+ if (!ret)
|
||||||
+ snprintf(devinfo, sizeof(devinfo), "%s %s",
|
+ return NULL;
|
||||||
+ dev_driver_string(&dev->dev), dev_name(&dev->dev));
|
|
||||||
+ mark_hardware_deprecated(devinfo);
|
|
||||||
+ }
|
|
||||||
+
|
+
|
||||||
|
+ mark_hardware_deprecated(dev_driver_string(&dev->dev), "%04X:%04X @ %s",
|
||||||
|
+ dev->device, dev->vendor, pci_name(dev));
|
||||||
+ return ret;
|
+ return ret;
|
||||||
+}
|
+}
|
||||||
+EXPORT_SYMBOL(pci_hw_vendor_status);
|
+EXPORT_SYMBOL(pci_hw_deprecated);
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
+ * pci_hw_unmaintained - Tell if a PCI device is unmaintained
|
||||||
|
+ * @ids: array of PCI device id structures to search in
|
||||||
|
+ * @dev: the PCI device structure to match against
|
||||||
|
+ *
|
||||||
|
+ * Used by a driver to check whether this device is in its list of unmaintained
|
||||||
|
+ * devices. Returns the matching pci_device_id structure or %NULL if there is
|
||||||
|
+ * no match.
|
||||||
|
+ *
|
||||||
|
+ * Reserved for Internal Red Hat use only.
|
||||||
|
+ */
|
||||||
|
+const struct pci_device_id *pci_hw_unmaintained(const struct pci_device_id *ids,
|
||||||
|
+ struct pci_dev *dev)
|
||||||
|
+{
|
||||||
|
+ const struct pci_device_id *ret = pci_match_id(ids, dev);
|
||||||
|
+
|
||||||
|
+ if (!ret)
|
||||||
|
+ return NULL;
|
||||||
|
+
|
||||||
|
+ mark_hardware_unmaintained(dev_driver_string(&dev->dev), "%04X:%04X @ %s",
|
||||||
|
+ dev->device, dev->vendor, pci_name(dev));
|
||||||
|
+ return ret;
|
||||||
|
+}
|
||||||
|
+EXPORT_SYMBOL(pci_hw_unmaintained);
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
+ * pci_hw_disabled - Tell if a PCI device is disabled
|
||||||
|
+ * @ids: array of PCI device id structures to search in
|
||||||
|
+ * @dev: the PCI device structure to match against
|
||||||
|
+ *
|
||||||
|
+ * Used by a driver to check whether this device is in its list of disabled
|
||||||
|
+ * devices. Returns the matching pci_device_id structure or %NULL if there is
|
||||||
|
+ * no match.
|
||||||
|
+ *
|
||||||
|
+ * Reserved for Internal Red Hat use only.
|
||||||
|
+ */
|
||||||
|
+const struct pci_device_id *pci_hw_disabled(const struct pci_device_id *ids,
|
||||||
|
+ struct pci_dev *dev)
|
||||||
|
+{
|
||||||
|
+ const struct pci_device_id *ret = pci_match_id(ids, dev);
|
||||||
|
+
|
||||||
|
+ if (!ret)
|
||||||
|
+ return NULL;
|
||||||
|
+
|
||||||
|
+ mark_hardware_disabled(dev_driver_string(&dev->dev), "%04X:%04X @ %s",
|
||||||
|
+ dev->device, dev->vendor, pci_name(dev));
|
||||||
|
+ return ret;
|
||||||
|
+}
|
||||||
|
+EXPORT_SYMBOL(pci_hw_disabled);
|
||||||
|
+
|
||||||
|
+#endif
|
||||||
+
|
+
|
||||||
struct drv_dev_and_id {
|
struct drv_dev_and_id {
|
||||||
struct pci_driver *drv;
|
struct pci_driver *drv;
|
||||||
@ -2162,10 +2210,10 @@ index dbd39b20e034..8127dcbe5a6e 100644
|
|||||||
enum efi_secureboot_mode efi_get_secureboot_mode(efi_get_variable_t *get_var)
|
enum efi_secureboot_mode efi_get_secureboot_mode(efi_get_variable_t *get_var)
|
||||||
{
|
{
|
||||||
diff --git a/include/linux/kernel.h b/include/linux/kernel.h
|
diff --git a/include/linux/kernel.h b/include/linux/kernel.h
|
||||||
index 77755ac3e189..6234dde914b6 100644
|
index 77755ac3e189..e236de3f9073 100644
|
||||||
--- a/include/linux/kernel.h
|
--- a/include/linux/kernel.h
|
||||||
+++ b/include/linux/kernel.h
|
+++ b/include/linux/kernel.h
|
||||||
@@ -495,4 +495,21 @@ static inline void ftrace_dump(enum ftrace_dump_mode oops_dump_mode) { }
|
@@ -495,4 +495,23 @@ static inline void ftrace_dump(enum ftrace_dump_mode oops_dump_mode) { }
|
||||||
/* OTHER_WRITABLE? Generally considered a bad idea. */ \
|
/* OTHER_WRITABLE? Generally considered a bad idea. */ \
|
||||||
BUILD_BUG_ON_ZERO((perms) & 2) + \
|
BUILD_BUG_ON_ZERO((perms) & 2) + \
|
||||||
(perms))
|
(perms))
|
||||||
@ -2173,17 +2221,19 @@ index 77755ac3e189..6234dde914b6 100644
|
|||||||
+struct module;
|
+struct module;
|
||||||
+
|
+
|
||||||
+#ifdef CONFIG_RHEL_DIFFERENCES
|
+#ifdef CONFIG_RHEL_DIFFERENCES
|
||||||
+void mark_hardware_unsupported(const char *msg);
|
+void mark_hardware_unmaintained(const char *driver_name, char *fmt, ...);
|
||||||
+void mark_hardware_deprecated(const char *msg);
|
+void mark_driver_unmaintained(const char *driver_name);
|
||||||
|
+void mark_hardware_deprecated(const char *driver_name, char *fmt, ...);
|
||||||
|
+void mark_driver_deprecated(const char *driver_name);
|
||||||
|
+void mark_hardware_disabled(const char *driver_name, char *fmt, ...);
|
||||||
+void mark_tech_preview(const char *msg, struct module *mod);
|
+void mark_tech_preview(const char *msg, struct module *mod);
|
||||||
+void mark_driver_unsupported(const char *name);
|
|
||||||
+void mark_driver_deprecated(const char *name);
|
|
||||||
+#else
|
+#else
|
||||||
+static inline void mark_hardware_unsupported(const char *msg) { }
|
+static inline void mark_hardware_unsupported(const char *driver_name, char *fmt, ...) { }
|
||||||
+static inline void mark_hardware_deprecated(const char *msg) { }
|
+static inline void mark_driver_unmaintained(const char *driver_name) { }
|
||||||
|
+static inline void mark_hardware_deprecated(const char *driver_name, char *fmt, ...) { }
|
||||||
|
+static inline void mark_driver_deprecated(const char *driver_name) { }
|
||||||
|
+static inline void mark_hardware_disabled(const char *driver_name, char *fmt, ...) { }
|
||||||
+static inline void mark_tech_preview(const char *msg, struct module *mod) { }
|
+static inline void mark_tech_preview(const char *msg, struct module *mod) { }
|
||||||
+static inline void mark_driver_unsupported(const char *name) { }
|
|
||||||
+static inline void mark_driver_deprecated(const char *name) { }
|
|
||||||
+#endif
|
+#endif
|
||||||
+
|
+
|
||||||
#endif
|
#endif
|
||||||
@ -2260,17 +2310,29 @@ index f5844908a089..901d51012738 100644
|
|||||||
|
|
||||||
struct taint_flag {
|
struct taint_flag {
|
||||||
diff --git a/include/linux/pci.h b/include/linux/pci.h
|
diff --git a/include/linux/pci.h b/include/linux/pci.h
|
||||||
index 18a75c8e615c..2c34abce98bf 100644
|
index 18a75c8e615c..fb9af56f5fec 100644
|
||||||
--- a/include/linux/pci.h
|
--- a/include/linux/pci.h
|
||||||
+++ b/include/linux/pci.h
|
+++ b/include/linux/pci.h
|
||||||
@@ -1478,6 +1478,10 @@ int pci_add_dynid(struct pci_driver *drv,
|
@@ -1478,6 +1478,22 @@ int pci_add_dynid(struct pci_driver *drv,
|
||||||
unsigned long driver_data);
|
unsigned long driver_data);
|
||||||
const struct pci_device_id *pci_match_id(const struct pci_device_id *ids,
|
const struct pci_device_id *pci_match_id(const struct pci_device_id *ids,
|
||||||
struct pci_dev *dev);
|
struct pci_dev *dev);
|
||||||
+/* Reserved for Internal Red Hat use only */
|
+
|
||||||
+const struct pci_device_id *pci_hw_vendor_status(
|
+#ifdef CONFIG_RHEL_DIFFERENCES
|
||||||
+ const struct pci_device_id *ids,
|
+const struct pci_device_id *pci_hw_deprecated(const struct pci_device_id *ids,
|
||||||
|
+ struct pci_dev *dev);
|
||||||
|
+const struct pci_device_id *pci_hw_unmaintained(const struct pci_device_id *ids,
|
||||||
+ struct pci_dev *dev);
|
+ struct pci_dev *dev);
|
||||||
|
+const struct pci_device_id *pci_hw_disabled(const struct pci_device_id *ids,
|
||||||
|
+ struct pci_dev *dev);
|
||||||
|
+#else
|
||||||
|
+static inline const struct pci_device_id *pci_hw_deprecated(const struct pci_device_id *ids,
|
||||||
|
+ struct pci_dev *dev) { return NULL; }
|
||||||
|
+static inline const struct pci_device_id *pci_hw_unmaintained(const struct pci_device_id *ids,
|
||||||
|
+ struct pci_dev *dev) { return NULL; }
|
||||||
|
+const struct pci_device_id *pci_hw_disabled(const struct pci_device_id *ids,
|
||||||
|
+ struct pci_dev *dev) {return NULL; }
|
||||||
|
+#endif
|
||||||
int pci_scan_bridge(struct pci_bus *bus, struct pci_dev *dev, int max,
|
int pci_scan_bridge(struct pci_bus *bus, struct pci_dev *dev, int max,
|
||||||
int pass);
|
int pass);
|
||||||
|
|
||||||
@ -2651,14 +2713,14 @@ index 4b7bac10c72d..6c356cf804b4 100644
|
|||||||
default y
|
default y
|
||||||
help
|
help
|
||||||
diff --git a/kernel/Makefile b/kernel/Makefile
|
diff --git a/kernel/Makefile b/kernel/Makefile
|
||||||
index 186c49582f45..7bbf1c3801f9 100644
|
index 186c49582f45..aa60b06d3cf7 100644
|
||||||
--- a/kernel/Makefile
|
--- a/kernel/Makefile
|
||||||
+++ b/kernel/Makefile
|
+++ b/kernel/Makefile
|
||||||
@@ -12,6 +12,7 @@ obj-y = fork.o exec_domain.o panic.o \
|
@@ -12,6 +12,7 @@ obj-y = fork.o exec_domain.o panic.o \
|
||||||
notifier.o ksysfs.o cred.o reboot.o \
|
notifier.o ksysfs.o cred.o reboot.o \
|
||||||
async.o range.o smpboot.o ucount.o regset.o
|
async.o range.o smpboot.o ucount.o regset.o
|
||||||
|
|
||||||
+obj-$(CONFIG_RHEL_DIFFERENCES) += rh_taint.o
|
+obj-$(CONFIG_RHEL_DIFFERENCES) += rh_messages.o
|
||||||
obj-$(CONFIG_USERMODE_DRIVER) += usermode_driver.o
|
obj-$(CONFIG_USERMODE_DRIVER) += usermode_driver.o
|
||||||
obj-$(CONFIG_MODULES) += kmod.o
|
obj-$(CONFIG_MODULES) += kmod.o
|
||||||
obj-$(CONFIG_MULTIUSER) += groups.o
|
obj-$(CONFIG_MULTIUSER) += groups.o
|
||||||
@ -2764,15 +2826,16 @@ index cefd7d82366f..ad43433c7013 100644
|
|||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
diff --git a/kernel/rh_taint.c b/kernel/rh_taint.c
|
diff --git a/kernel/rh_messages.c b/kernel/rh_messages.c
|
||||||
new file mode 100644
|
new file mode 100644
|
||||||
index 000000000000..95196f56ab1e
|
index 000000000000..345a979cd0e4
|
||||||
--- /dev/null
|
--- /dev/null
|
||||||
+++ b/kernel/rh_taint.c
|
+++ b/kernel/rh_messages.c
|
||||||
@@ -0,0 +1,109 @@
|
@@ -0,0 +1,179 @@
|
||||||
+#include <linux/kernel.h>
|
+#include <linux/kernel.h>
|
||||||
+#include <linux/module.h>
|
+#include <linux/module.h>
|
||||||
+
|
+
|
||||||
|
+#define DEV_DESC_LEN 256
|
||||||
+/*
|
+/*
|
||||||
+ * The following functions are used by Red Hat to indicate to users that
|
+ * The following functions are used by Red Hat to indicate to users that
|
||||||
+ * hardware and drivers are unsupported, or have limited support in RHEL major
|
+ * hardware and drivers are unsupported, or have limited support in RHEL major
|
||||||
@ -2781,42 +2844,142 @@ index 000000000000..95196f56ab1e
|
|||||||
+ *
|
+ *
|
||||||
+ * Any use of these functions _MUST_ be documented in the RHEL Release Notes,
|
+ * Any use of these functions _MUST_ be documented in the RHEL Release Notes,
|
||||||
+ * and have approval of management.
|
+ * and have approval of management.
|
||||||
|
+ *
|
||||||
|
+ * Generally, the process of disabling a driver or device in RHEL requires the
|
||||||
|
+ * driver or device to be marked as 'deprecated' in all existing releases, and
|
||||||
|
+ * then either 'unmaintained' or 'disabled' in a future release.
|
||||||
|
+ *
|
||||||
|
+ * In general, deprecated and unmaintained drivers continue to receive security
|
||||||
|
+ * related fixes until they are disabled.
|
||||||
+ */
|
+ */
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
+ * mark_hardware_unsupported() - Mark hardware, class, or type as unsupported.
|
+ * mark_hardware_unmaintained() - Mark hardware as unmaintained.
|
||||||
+ * @msg: Hardware name, class, or type
|
+ * @driver_name: driver name
|
||||||
|
+ * @fmt: format for device description
|
||||||
|
+ * @...: args for device description
|
||||||
+ *
|
+ *
|
||||||
+ * Called to mark a device, class of devices, or types of devices as not having
|
+ * Called to notify users that the device will no longer be tested on a routine
|
||||||
+ * support in any RHEL minor release. This does not TAINT the kernel. Red Hat
|
+ * basis and driver code associated with this device is no longer being updated.
|
||||||
+ * will not fix bugs against this hardware in this minor release. Red Hat may
|
+ * Red Hat may fix security-related and critical issues. Support for this device
|
||||||
+ * declare support in a future major or minor update release. This cannot be
|
+ * will be disabled in a future major release and users deploying this device
|
||||||
+ * used to mark drivers unsupported.
|
+ * should plan to replace the device in production systems.
|
||||||
|
+ *
|
||||||
|
+ * This function should be used when the driver's usage can be tied to a
|
||||||
|
+ * specific hardware device. For example, a network device driver loading on a
|
||||||
|
+ * specific device that is no longer maintained by the manufacturer.
|
||||||
+ */
|
+ */
|
||||||
+void mark_hardware_unsupported(const char *msg)
|
+void mark_hardware_unmaintained(const char *driver_name, char *fmt, ...)
|
||||||
+{
|
+{
|
||||||
+ /* Print one single message */
|
+ char device_description[DEV_DESC_LEN];
|
||||||
+ pr_crit("Warning: %s - this hardware has not undergone testing by Red Hat and might not be certified. Please consult https://catalog.redhat.com for certified hardware.\n", msg);
|
+ va_list args;
|
||||||
|
+
|
||||||
|
+ va_start(args, fmt);
|
||||||
|
+ vsnprintf(device_description, DEV_DESC_LEN, fmt, args);
|
||||||
|
+ pr_crit("Warning: Unmaintained hardware is detected: %s:%s\n", driver_name,
|
||||||
|
+ device_description);
|
||||||
|
+ va_end(args);
|
||||||
+}
|
+}
|
||||||
+EXPORT_SYMBOL(mark_hardware_unsupported);
|
+EXPORT_SYMBOL(mark_hardware_unmaintained);
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
+ * mark_hardware_deprecated() - Mark hardware, class, or type as deprecated.
|
+ * mark_driver_unmaintained() - Mark a driver as unmaintained.
|
||||||
+ * @msg: Hardware name, class, or type
|
+ * @driver_name: driver name
|
||||||
+ *
|
+ *
|
||||||
+ * Called to minimize the support status of a previously supported device in
|
+ * Called to notify users that a driver will no longer be tested on a routine
|
||||||
+ * a minor release. This does not TAINT the kernel. Marking hardware
|
+ * basis and the driver code is no longer being updated. Red Hat may fix
|
||||||
+ * deprecated is usually done in conjunction with the hardware vendor. Future
|
+ * security-related and critical issues. Support for this driver will be
|
||||||
+ * RHEL major releases may not include this driver. Driver updates and fixes
|
+ * disabled in a future major release, and users should replace any affected
|
||||||
+ * for this device will be limited to critical issues in future minor releases.
|
+ * devices in production systems.
|
||||||
|
+ *
|
||||||
|
+ * This function should be used when a driver's usage cannot be tied to a
|
||||||
|
+ * specific hardware device. For example, a network bonding driver or a higher
|
||||||
|
+ * level storage layer driver that is no longer maintained upstream.
|
||||||
+ */
|
+ */
|
||||||
+void mark_hardware_deprecated(const char *msg)
|
+void mark_driver_unmaintained(const char *driver_name)
|
||||||
+{
|
+{
|
||||||
+ pr_crit("Warning: %s - this hardware is not recommended for new deployments. It continues to be supported in this RHEL release, but it is likely to be removed in the next major release. Driver updates and fixes for this device will be limited to critical issues. Please contact Red Hat Support or your device's hardware vendor for additional information.\n", msg);
|
+ pr_crit("Warning: Unmaintained driver is detected: %s\n", driver_name);
|
||||||
|
+}
|
||||||
|
+EXPORT_SYMBOL(mark_driver_unmaintained);
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
+ * mark_hardware_deprecated() - Mark hardware as deprecated.
|
||||||
|
+ * @driver_name: driver name
|
||||||
|
+ * @fmt: format for device description
|
||||||
|
+ * @...: args for device description
|
||||||
|
+ *
|
||||||
|
+ * Called to notify users that support for the device is planned to be
|
||||||
|
+ * unmaintained in a future major release, and will eventually be disabled in a
|
||||||
|
+ * future major release. This device should not be used in new production
|
||||||
|
+ * environments and users should replace the device in production systems.
|
||||||
|
+ *
|
||||||
|
+ * This function should be used when the driver's usage can be tied to a
|
||||||
|
+ * specific hardware device. For example, a network device driver loading on a
|
||||||
|
+ * specific device that is no longer maintained by the manufacturer.
|
||||||
|
+ */
|
||||||
|
+void mark_hardware_deprecated(const char *driver_name, char *fmt, ...)
|
||||||
|
+{
|
||||||
|
+ char device_description[DEV_DESC_LEN];
|
||||||
|
+ va_list args;
|
||||||
|
+
|
||||||
|
+ va_start(args, fmt);
|
||||||
|
+ vsnprintf(device_description, DEV_DESC_LEN, fmt, args);
|
||||||
|
+ pr_crit("Warning: Deprecated Hardware is detected: %s:%s will not be maintained in a future major release and may be disabled\n",
|
||||||
|
+ driver_name, device_description);
|
||||||
|
+ va_end(args);
|
||||||
+}
|
+}
|
||||||
+EXPORT_SYMBOL(mark_hardware_deprecated);
|
+EXPORT_SYMBOL(mark_hardware_deprecated);
|
||||||
+
|
+
|
||||||
+/**
|
+/**
|
||||||
|
+ * mark_driver_deprecated() - Mark a driver as deprecated.
|
||||||
|
+ * @driver_name: driver name
|
||||||
|
+ *
|
||||||
|
+ * Called to notify users that support for this driver is planned to be
|
||||||
|
+ * unmaintained in a future major release, and will eventually be disabled in a
|
||||||
|
+ * future major release. This driver should not be used in new production
|
||||||
|
+ * environments and users should replace any affected devices in production
|
||||||
|
+ * systems.
|
||||||
|
+ *
|
||||||
|
+ * This function should be used when a driver's usage cannot be tied to a
|
||||||
|
+ * specific hardware device. For example, a network bonding driver or a higher
|
||||||
|
+ * level storage layer driver that is no longer maintained upstream.
|
||||||
|
+ */
|
||||||
|
+void mark_driver_deprecated(const char *driver_name)
|
||||||
|
+{
|
||||||
|
+ pr_crit("Warning: Deprecated Driver is detected: %s will not be maintained in a future major release and may be disabled\n",
|
||||||
|
+ driver_name);
|
||||||
|
+}
|
||||||
|
+EXPORT_SYMBOL(mark_driver_deprecated);
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
+ * mark_hardware_disabled() - Mark a driver as removed.
|
||||||
|
+ * @driver_name: driver name
|
||||||
|
+ * @fmt: format for device description
|
||||||
|
+ * @...: args for device description
|
||||||
|
+ *
|
||||||
|
+ * Called to notify users that a device's support has been completely disabled
|
||||||
|
+ * and no future support updates will occur. This device cannot be used in new
|
||||||
|
+ * production environments, and users must replace the device in production
|
||||||
|
+ * systems.
|
||||||
|
+ *
|
||||||
|
+ * This function should be used when the driver's usage can be tied to a
|
||||||
|
+ * specific hardware device. For example, a network device driver loading on a
|
||||||
|
+ * specific device that is no longer maintained by the manufacturer.
|
||||||
|
+ */
|
||||||
|
+void mark_hardware_disabled(const char *driver_name, char *fmt, ...)
|
||||||
|
+{
|
||||||
|
+ char device_description[DEV_DESC_LEN];
|
||||||
|
+ va_list args;
|
||||||
|
+
|
||||||
|
+ va_start(args, fmt);
|
||||||
|
+ vsnprintf(device_description, DEV_DESC_LEN, fmt, args);
|
||||||
|
+ pr_crit("Warning: Disabled Hardware is detected: %s:%s is no longer enabled in this release.\n",
|
||||||
|
+ driver_name, device_description);
|
||||||
|
+ va_end(args);
|
||||||
|
+}
|
||||||
|
+EXPORT_SYMBOL(mark_hardware_disabled);
|
||||||
|
+
|
||||||
|
+/**
|
||||||
+ * mark_tech_preview() - Mark driver or kernel subsystem as 'Tech Preview'
|
+ * mark_tech_preview() - Mark driver or kernel subsystem as 'Tech Preview'
|
||||||
+ * @msg: Driver or kernel subsystem name
|
+ * @msg: Driver or kernel subsystem name
|
||||||
+ *
|
+ *
|
||||||
@ -2848,37 +3011,6 @@ index 000000000000..95196f56ab1e
|
|||||||
+#endif
|
+#endif
|
||||||
+}
|
+}
|
||||||
+EXPORT_SYMBOL(mark_tech_preview);
|
+EXPORT_SYMBOL(mark_tech_preview);
|
||||||
+
|
|
||||||
+/**
|
|
||||||
+ * mark_driver_unsupported - drivers that we know we don't want to support
|
|
||||||
+ * @name: the name of the driver
|
|
||||||
+ *
|
|
||||||
+ * In some cases Red Hat has chosen to build a driver for internal QE
|
|
||||||
+ * use. Use this function to mark those drivers as unsupported for
|
|
||||||
+ * customers.
|
|
||||||
+ */
|
|
||||||
+void mark_driver_unsupported(const char *name)
|
|
||||||
+{
|
|
||||||
+ pr_crit("Warning: %s - This driver has not undergone sufficient testing by Red Hat for this release and therefore cannot be used in production systems.\n",
|
|
||||||
+ name ? name : "kernel");
|
|
||||||
+}
|
|
||||||
+EXPORT_SYMBOL(mark_driver_unsupported);
|
|
||||||
+
|
|
||||||
+/**
|
|
||||||
+ * mark_driver_deprecated() - Mark drivers as deprecated.
|
|
||||||
+ * @name: the name of the driver
|
|
||||||
+ *
|
|
||||||
+ * Called to minimize the support status of a previously supported driver in
|
|
||||||
+ * a minor release. This does not TAINT the kernel. Future
|
|
||||||
+ * RHEL major releases may not include this driver. Driver updates and fixes
|
|
||||||
+ * will be limited to critical issues in future minor releases.
|
|
||||||
+ */
|
|
||||||
+void mark_driver_deprecated(const char *name)
|
|
||||||
+{
|
|
||||||
+ pr_crit("Warning: %s - this driver is not recommended for new deployments. It continues to be supported in this RHEL release, but it is likely to be removed in the next major release. Driver updates and fixes will be limited to critical issues. Please contact Red Hat Support for additional information.\n",
|
|
||||||
+ name ? name : "kernel");
|
|
||||||
+}
|
|
||||||
+EXPORT_SYMBOL(mark_driver_deprecated);
|
|
||||||
diff --git a/kernel/sysctl.c b/kernel/sysctl.c
|
diff --git a/kernel/sysctl.c b/kernel/sysctl.c
|
||||||
index 083be6af29d7..4f271712be5e 100644
|
index 083be6af29d7..4f271712be5e 100644
|
||||||
--- a/kernel/sysctl.c
|
--- a/kernel/sysctl.c
|
||||||
|
6
sources
6
sources
@ -1,3 +1,3 @@
|
|||||||
SHA512 (linux-5.16-rc4-12-gcd8c917a56f2.tar.xz) = fb622d715f1742fa2a1ec0ff51f621062d05f612a336829ff07d767cca725f61cd581add9b4bfc5f82e0df9e4eea251ba97ef7c1df31a46dedb17c86eb4268c2
|
SHA512 (linux-5.16-rc4-31-g2a987e65025e.tar.xz) = b787536c5ebc434c3ab3607a9fba50027cd314b955d338e24630c9f647b5806adfc15fca1ebeacf687d5ef4533f1df4e4b3c0ccab87057451d6b0a532c188592
|
||||||
SHA512 (kernel-abi-stablelists-5.16.0-0.rc4.20211207gitcd8c917a56f2.30.tar.bz2) = 02fb687a59316b882d5cc2ec6e5a31b7abf8ece47c24ad14d13fceecfe121cd17a8cb550c86c6737aa72d851e0e685ba760ebf020c5583260a378a3c349435c7
|
SHA512 (kernel-abi-stablelists-5.16.0-0.rc4.20211208git2a987e65025e.31.tar.bz2) = f382b99f167bfc12ae68d5a8695d0d425ebee5fd32467d78302feba827801ee1cb8e4b22ecf57c81988c92dc3f908a361caf6b871fd3c091e9e4f95873f35724
|
||||||
SHA512 (kernel-kabi-dw-5.16.0-0.rc4.20211207gitcd8c917a56f2.30.tar.bz2) = 77d96fd4c1c9178e86ed5bc5951f76324a57fa581343a906a93fb1ac472e17280fe52702cc0b904334130788e263b6b8f194bdbcb2a3b9b31d3936fbd193da62
|
SHA512 (kernel-kabi-dw-5.16.0-0.rc4.20211208git2a987e65025e.31.tar.bz2) = 93100527d8574e41bb102606c62382073e8c3d54a169eb4e1bb92cc4bf3c0915c1e246d25d18fe2df87860488bdbfacfbfcce5539ff71436822cbe14e4927958
|
||||||
|
Loading…
Reference in New Issue
Block a user