|
@@ -626,3 +626,34 @@ DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_AMD, PCI_DEVICE_ID_AMD_16H_NB_F3,
|
|
|
amd_disable_seq_and_redirect_scrub);
|
|
|
|
|
|
#endif
|
|
|
+
|
|
|
+#if defined(CONFIG_X86_64) && defined(CONFIG_X86_MCE)
|
|
|
+#include <linux/jump_label.h>
|
|
|
+#include <asm/string_64.h>
|
|
|
+
|
|
|
+/* Ivy Bridge, Haswell, Broadwell */
|
|
|
+static void quirk_intel_brickland_xeon_ras_cap(struct pci_dev *pdev)
|
|
|
+{
|
|
|
+ u32 capid0;
|
|
|
+
|
|
|
+ pci_read_config_dword(pdev, 0x84, &capid0);
|
|
|
+
|
|
|
+ if (capid0 & 0x10)
|
|
|
+ static_branch_inc(&mcsafe_key);
|
|
|
+}
|
|
|
+
|
|
|
+/* Skylake */
|
|
|
+static void quirk_intel_purley_xeon_ras_cap(struct pci_dev *pdev)
|
|
|
+{
|
|
|
+ u32 capid0;
|
|
|
+
|
|
|
+ pci_read_config_dword(pdev, 0x84, &capid0);
|
|
|
+
|
|
|
+ if ((capid0 & 0xc0) == 0xc0)
|
|
|
+ static_branch_inc(&mcsafe_key);
|
|
|
+}
|
|
|
+DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_INTEL, 0x0ec3, quirk_intel_brickland_xeon_ras_cap);
|
|
|
+DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_INTEL, 0x2fc0, quirk_intel_brickland_xeon_ras_cap);
|
|
|
+DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_INTEL, 0x6fc0, quirk_intel_brickland_xeon_ras_cap);
|
|
|
+DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_INTEL, 0x2083, quirk_intel_purley_xeon_ras_cap);
|
|
|
+#endif
|