- Rename PCIx_HEADERTYPE* to PCIx_HDRTYPE* so the constants aren't so long.
- Add a new PCIM_HDRTYPE constant for the field in PCIR_HDRTYPE that holds the header type. - Replace several magic numbers with appropriate constants for the header type register and a couple of PCI_FUNCMAX. - Merge to amd64 the fix to the i386 bridge code to skip devices with unknown header types. Requested by: imp (1, 2)
This commit is contained in:
parent
fed4d10a43
commit
51be1787c3
@ -328,10 +328,18 @@ nexus_pcib_identify(driver_t *driver, device_t parent)
|
||||
for (slot = 0; slot <= PCI_SLOTMAX; slot++) {
|
||||
func = 0;
|
||||
hdrtype = nexus_pcib_read_config(0, bus, slot, func,
|
||||
PCIR_HEADERTYPE, 1);
|
||||
PCIR_HDRTYPE, 1);
|
||||
/*
|
||||
* When enumerating bus devices, the standard says that
|
||||
* one should check the header type and ignore the slots whose
|
||||
* header types that the software doesn't know about. We use
|
||||
* this to filter out devices.
|
||||
*/
|
||||
if ((hdrtype & PCIM_HDRTYPE) > PCI_MAXHDRTYPE)
|
||||
continue;
|
||||
if ((hdrtype & PCIM_MFDEV) &&
|
||||
(!found_orion || hdrtype != 0xff))
|
||||
pcifunchigh = 7;
|
||||
pcifunchigh = PCI_FUNCMAX;
|
||||
else
|
||||
pcifunchigh = 0;
|
||||
for (func = 0; func <= pcifunchigh; func++) {
|
||||
|
@ -213,10 +213,10 @@ acpi_bus_number(ACPI_HANDLE root, ACPI_HANDLE curr, ACPI_PCI_ID *PciId)
|
||||
return (bus);
|
||||
subclass = pci_cfgregread(bus, slot, func, PCIR_SUBCLASS, 1);
|
||||
/* Find the header type, masking off the multifunction bit */
|
||||
header = pci_cfgregread(bus, slot, func, PCIR_HEADERTYPE, 1) & 0x7f;
|
||||
if (header == 1 && subclass == PCIS_BRIDGE_PCI)
|
||||
header = pci_cfgregread(bus, slot, func, PCIR_HDRTYPE, 1) & PCIM_HDRTYPE;
|
||||
if (header == PCIM_HDRTYPE_BRIDGE && subclass == PCIS_BRIDGE_PCI)
|
||||
bus = pci_cfgregread(bus, slot, func, PCIR_SECBUS_1, 1);
|
||||
if (header == 2 && subclass == PCIS_BRIDGE_CARDBUS)
|
||||
if (header == PCIM_HDRTYPE_CARDBUS && subclass == PCIS_BRIDGE_CARDBUS)
|
||||
bus = pci_cfgregread(bus, slot, func, PCIR_SECBUS_2, 1);
|
||||
return (bus);
|
||||
}
|
||||
|
@ -354,7 +354,7 @@ pci_read_device(device_t pcib, int b, int s, int f, size_t size)
|
||||
cfg->subclass = REG(PCIR_SUBCLASS, 1);
|
||||
cfg->progif = REG(PCIR_PROGIF, 1);
|
||||
cfg->revid = REG(PCIR_REVID, 1);
|
||||
cfg->hdrtype = REG(PCIR_HEADERTYPE, 1);
|
||||
cfg->hdrtype = REG(PCIR_HDRTYPE, 1);
|
||||
cfg->cachelnsz = REG(PCIR_CACHELNSZ, 1);
|
||||
cfg->lattimer = REG(PCIR_LATTIMER, 1);
|
||||
cfg->intpin = REG(PCIR_INTPIN, 1);
|
||||
@ -834,8 +834,8 @@ pci_add_children(device_t dev, int busno, size_t dinfo_size)
|
||||
for (s = 0; s <= maxslots; s++) {
|
||||
pcifunchigh = 0;
|
||||
f = 0;
|
||||
hdrtype = REG(PCIR_HEADERTYPE, 1);
|
||||
if ((hdrtype & ~PCIM_MFDEV) > PCI_MAXHDRTYPE)
|
||||
hdrtype = REG(PCIR_HDRTYPE, 1);
|
||||
if ((hdrtype & PCIM_HDRTYPE) > PCI_MAXHDRTYPE)
|
||||
continue;
|
||||
if (hdrtype & PCIM_MFDEV)
|
||||
pcifunchigh = PCI_FUNCMAX;
|
||||
|
@ -80,10 +80,11 @@
|
||||
#define PCIR_CLASS 0x0b
|
||||
#define PCIR_CACHELNSZ 0x0c
|
||||
#define PCIR_LATTIMER 0x0d
|
||||
#define PCIR_HEADERTYPE 0x0e
|
||||
#define PCIM_HEADERTYPE_NORMAL 0x00
|
||||
#define PCIM_HEADERTYPE_BRIDGE 0x01
|
||||
#define PCIM_HEADERTYPE_CARDBUS 0x02
|
||||
#define PCIR_HDRTYPE 0x0e
|
||||
#define PCIM_HDRTYPE 0x7f
|
||||
#define PCIM_HDRTYPE_NORMAL 0x00
|
||||
#define PCIM_HDRTYPE_BRIDGE 0x01
|
||||
#define PCIM_HDRTYPE_CARDBUS 0x02
|
||||
#define PCIM_MFDEV 0x80
|
||||
#define PCIR_BIST 0x0f
|
||||
|
||||
|
@ -88,7 +88,7 @@ puc_pci_probe(device_t dev)
|
||||
uint32_t v1, v2, d1, d2;
|
||||
const struct puc_device_description *desc;
|
||||
|
||||
if ((pci_read_config(dev, PCIR_HEADERTYPE, 1) & 0x7f) != 0)
|
||||
if ((pci_read_config(dev, PCIR_HDRTYPE, 1) & PCIM_HDRTYPE) != 0)
|
||||
return (ENXIO);
|
||||
|
||||
v1 = pci_read_config(dev, PCIR_VENDOR, 2);
|
||||
|
@ -322,18 +322,18 @@ legacy_pcib_identify(driver_t *driver, device_t parent)
|
||||
for (slot = 0; slot <= PCI_SLOTMAX; slot++) {
|
||||
func = 0;
|
||||
hdrtype = legacy_pcib_read_config(0, bus, slot, func,
|
||||
PCIR_HEADERTYPE, 1);
|
||||
PCIR_HDRTYPE, 1);
|
||||
/*
|
||||
* When enumerating bus devices, the standard says that
|
||||
* one should check the header type and ignore the slots whose
|
||||
* header types that the software doesn't know about. We use
|
||||
* this to filter out devices.
|
||||
*/
|
||||
if ((hdrtype & ~PCIM_MFDEV) > PCI_MAXHDRTYPE)
|
||||
if ((hdrtype & PCIM_HDRTYPE) > PCI_MAXHDRTYPE)
|
||||
continue;
|
||||
if ((hdrtype & PCIM_MFDEV) &&
|
||||
(!found_orion || hdrtype != 0xff))
|
||||
pcifunchigh = 7;
|
||||
pcifunchigh = PCI_FUNCMAX;
|
||||
else
|
||||
pcifunchigh = 0;
|
||||
for (func = 0; func <= pcifunchigh; func++) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user