[PATCH 3/5] PCI: Limit config space size for Netronome NFP6000 family

Tim Gardner tim.gardner at canonical.com
Fri Sep 16 14:23:12 UTC 2016


From: "Jason S. McMullan" <jason.mcmullan at netronome.com>

BugLink: http://bugs.launchpad.net/bugs/1624267

The NFP6000 has an erratum where reading/writing to PCI config space
addresses above 0x600 can cause the NFP to generate PCIe completion
timeouts.

Limit the NFP6000's config space size to 0x600 bytes.

Signed-off-by: Jason S. McMullan <jason.mcmullan at netronome.com>
[simon: edited changelog]
Signed-off-by: Simon Horman <simon.horman at netronome.com>
Signed-off-by: Bjorn Helgaas <bhelgaas at google.com>
(cherry picked from commit 9f33a2ae59f24452c1076749deb615bccd435ca9)

Signed-off-by: Tim Gardner <tim.gardner at canonical.com>
---
 drivers/pci/quirks.c | 11 +++++++++++
 1 file changed, 11 insertions(+)

diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c
index 70f566a..1d97e24 100644
--- a/drivers/pci/quirks.c
+++ b/drivers/pci/quirks.c
@@ -303,6 +303,17 @@ static void quirk_citrine(struct pci_dev *dev)
 }
 DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_IBM,	PCI_DEVICE_ID_IBM_CITRINE,	quirk_citrine);
 
+/*
+ * This chip can cause bus lockups if config addresses above 0x600
+ * are read or written.
+ */
+static void quirk_nfp6000(struct pci_dev *dev)
+{
+	dev->cfg_size = 0x600;
+}
+DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_NETRONOME,	PCI_DEVICE_ID_NETRONOME_NFP6000,	quirk_nfp6000);
+DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_NETRONOME,	PCI_DEVICE_ID_NETRONOME_NFP6000_VF,	quirk_nfp6000);
+
 /*  On IBM Crocodile ipr SAS adapters, expand BAR to system page size */
 static void quirk_extend_bar_to_page(struct pci_dev *dev)
 {
-- 
2.7.4





More information about the kernel-team mailing list