bcma: enable support for PCIe Gen 2 host devices
Signed-off-by: Rafał Miłecki <zajec5@gmail.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
804e27dee4
commit
9b6cc9a807
@ -26,6 +26,7 @@ bool bcma_wait_value(struct bcma_device *core, u16 reg, u32 mask, u32 value,
|
|||||||
int timeout);
|
int timeout);
|
||||||
void bcma_prepare_core(struct bcma_bus *bus, struct bcma_device *core);
|
void bcma_prepare_core(struct bcma_bus *bus, struct bcma_device *core);
|
||||||
void bcma_init_bus(struct bcma_bus *bus);
|
void bcma_init_bus(struct bcma_bus *bus);
|
||||||
|
void bcma_unregister_cores(struct bcma_bus *bus);
|
||||||
int bcma_bus_register(struct bcma_bus *bus);
|
int bcma_bus_register(struct bcma_bus *bus);
|
||||||
void bcma_bus_unregister(struct bcma_bus *bus);
|
void bcma_bus_unregister(struct bcma_bus *bus);
|
||||||
int __init bcma_bus_early_register(struct bcma_bus *bus);
|
int __init bcma_bus_early_register(struct bcma_bus *bus);
|
||||||
|
@ -213,16 +213,26 @@ static int bcma_host_pci_probe(struct pci_dev *dev,
|
|||||||
/* Initialize struct, detect chip */
|
/* Initialize struct, detect chip */
|
||||||
bcma_init_bus(bus);
|
bcma_init_bus(bus);
|
||||||
|
|
||||||
|
/* Scan bus to find out generation of PCIe core */
|
||||||
|
err = bcma_bus_scan(bus);
|
||||||
|
if (err)
|
||||||
|
goto err_pci_unmap_mmio;
|
||||||
|
|
||||||
|
if (bcma_find_core(bus, BCMA_CORE_PCIE2))
|
||||||
|
bus->host_is_pcie2 = true;
|
||||||
|
|
||||||
/* Register */
|
/* Register */
|
||||||
err = bcma_bus_register(bus);
|
err = bcma_bus_register(bus);
|
||||||
if (err)
|
if (err)
|
||||||
goto err_pci_unmap_mmio;
|
goto err_unregister_cores;
|
||||||
|
|
||||||
pci_set_drvdata(dev, bus);
|
pci_set_drvdata(dev, bus);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
return err;
|
return err;
|
||||||
|
|
||||||
|
err_unregister_cores:
|
||||||
|
bcma_unregister_cores(bus);
|
||||||
err_pci_unmap_mmio:
|
err_pci_unmap_mmio:
|
||||||
pci_iounmap(dev, bus->mmio);
|
pci_iounmap(dev, bus->mmio);
|
||||||
err_pci_release_regions:
|
err_pci_release_regions:
|
||||||
@ -283,9 +293,12 @@ static const struct pci_device_id bcma_pci_bridge_tbl[] = {
|
|||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4357) },
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4357) },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4358) },
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4358) },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4359) },
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4359) },
|
||||||
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4360) },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4365) },
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4365) },
|
||||||
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x43a0) },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x43a9) },
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x43a9) },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x43aa) },
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x43aa) },
|
||||||
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x43b1) },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4727) },
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 0x4727) },
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 43227) }, /* 0xa8db, BCM43217 (sic!) */
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 43227) }, /* 0xa8db, BCM43217 (sic!) */
|
||||||
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 43228) }, /* 0xa8dc */
|
{ PCI_DEVICE(PCI_VENDOR_ID_BROADCOM, 43228) }, /* 0xa8dc */
|
||||||
|
@ -363,7 +363,7 @@ static int bcma_register_devices(struct bcma_bus *bus)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void bcma_unregister_cores(struct bcma_bus *bus)
|
void bcma_unregister_cores(struct bcma_bus *bus)
|
||||||
{
|
{
|
||||||
struct bcma_device *core, *tmp;
|
struct bcma_device *core, *tmp;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user