diff options
Diffstat (limited to 'drivers/pci/quirks.c')
| -rw-r--r-- | drivers/pci/quirks.c | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index bc0aa0849e72..e65eec0644a7 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -3145,6 +3145,18 @@ static void quirk_no_bus_reset(struct pci_dev *dev)  }  /* + * Some NVIDIA GPU devices do not work with bus reset, SBR needs to be + * prevented for those affected devices. + */ +static void quirk_nvidia_no_bus_reset(struct pci_dev *dev) +{ +	if ((dev->device & 0xffc0) == 0x2340) +		quirk_no_bus_reset(dev); +} +DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, +			 quirk_nvidia_no_bus_reset); + +/*   * Some Atheros AR9xxx and QCA988x chips do not behave after a bus reset.   * The device will throw a Link Down error on AER-capable systems and   * regardless of AER, config space of the device is never accessible again @@ -3157,6 +3169,16 @@ DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_ATHEROS, 0x003c, quirk_no_bus_reset);  DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_ATHEROS, 0x0033, quirk_no_bus_reset);  DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_ATHEROS, 0x0034, quirk_no_bus_reset); +/* + * Some TI KeyStone C667X devices do not support bus/hot reset.  The PCIESS + * automatically disables LTSSM when Secondary Bus Reset is received and + * the device stops working.  Prevent bus reset for these devices.  With + * this change, the device can be assigned to VMs with VFIO, but it will + * leak state between VMs.  Reference + * https://e2e.ti.com/support/processors/f/791/t/954382 + */ +DECLARE_PCI_FIXUP_HEADER(PCI_VENDOR_ID_TI, 0xb005, quirk_no_bus_reset); +  static void quirk_no_pm_reset(struct pci_dev *dev)  {  	/* | 
