- Add a new flag to the PCI-PCI driver to disable MSI on devices behind the
bridge if it doesn't pass MSI messages up correctly. We set the flag in pcib_attach() if the device ID is disabled via a PCI quirk. - Disable MSI for devices behind the AMD 8131 HT-PCIX bridge. Linux has the same quirk. Tested by: no one despite repeated calls for testers
This commit is contained in:
parent
53a8becd31
commit
22bf1c7fb0
@ -194,6 +194,12 @@ struct pci_quirk pci_quirks[] = {
|
||||
{ 0x25788086, PCI_QUIRK_DISABLE_MSI, 0, 0 },
|
||||
{ 0x35808086, PCI_QUIRK_DISABLE_MSI, 0, 0 },
|
||||
|
||||
/*
|
||||
* MSI doesn't work with devices behind the AMD 8131 HT-PCIX
|
||||
* bridge.
|
||||
*/
|
||||
{ 0x74501022, PCI_QUIRK_DISABLE_MSI, 0, 0 },
|
||||
|
||||
{ 0 }
|
||||
};
|
||||
|
||||
|
@ -240,6 +240,9 @@ pcib_attach_common(device_t dev)
|
||||
}
|
||||
}
|
||||
|
||||
if (pci_msi_device_blacklisted(dev))
|
||||
sc->flags |= PCIB_DISABLE_MSI;
|
||||
|
||||
/*
|
||||
* Intel 815, 845 and other chipsets say they are PCI-PCI bridges,
|
||||
* but have a ProgIF of 0x80. The 82801 family (AA, AB, BAM/CAM,
|
||||
@ -547,8 +550,11 @@ pcib_route_interrupt(device_t pcib, device_t dev, int pin)
|
||||
int
|
||||
pcib_alloc_msi(device_t pcib, device_t dev, int count, int maxcount, int *irqs)
|
||||
{
|
||||
struct pcib_softc *sc = device_get_softc(dev);
|
||||
device_t bus;
|
||||
|
||||
if (sc->flags & PCIB_DISABLE_MSI)
|
||||
return (ENXIO);
|
||||
bus = device_get_parent(pcib);
|
||||
return (PCIB_ALLOC_MSI(device_get_parent(bus), dev, count, maxcount,
|
||||
irqs));
|
||||
@ -568,8 +574,11 @@ pcib_release_msi(device_t pcib, device_t dev, int count, int *irqs)
|
||||
int
|
||||
pcib_alloc_msix(device_t pcib, device_t dev, int index, int *irq)
|
||||
{
|
||||
struct pcib_softc *sc = device_get_softc(dev);
|
||||
device_t bus;
|
||||
|
||||
if (sc->flags & PCIB_DISABLE_MSI)
|
||||
return (ENXIO);
|
||||
bus = device_get_parent(pcib);
|
||||
return (PCIB_ALLOC_MSIX(device_get_parent(bus), dev, index, irq));
|
||||
}
|
||||
|
@ -46,6 +46,7 @@ struct pcib_softc
|
||||
device_t dev;
|
||||
uint32_t flags; /* flags */
|
||||
#define PCIB_SUBTRACTIVE 0x1
|
||||
#define PCIB_DISABLE_MSI 0x2
|
||||
uint16_t command; /* command register */
|
||||
uint8_t secbus; /* secondary bus number */
|
||||
uint8_t subbus; /* subordinate bus number */
|
||||
|
Loading…
x
Reference in New Issue
Block a user