[POWERPC] Hide resources on Axon PCIE root complex nodes
The PCI bridge representing the PCIE root complex on Axon, contains device BARs for a memory range and ROM that define inbound accesses. This confuses the kernel resource management code -- the resources need to be hidden when Axon is a host bridge. Signed-off-by: Michael Ellerman <michael@ellerman.id.au> Acked-by: Benjamin Herrenschmidt <benh@kernel.crashing.org> Signed-off-by: Paul Mackerras <paulus@samba.org>
This commit is contained in:
parent
3a4295d101
commit
ebf3a65092
1 changed files with 36 additions and 0 deletions
|
@ -81,6 +81,42 @@ static void cell_progress(char *s, unsigned short hex)
|
|||
printk("*** %04x : %s\n", hex, s ? s : "");
|
||||
}
|
||||
|
||||
static void cell_fixup_pcie_rootcomplex(struct pci_dev *dev)
|
||||
{
|
||||
struct pci_controller *hose;
|
||||
const char *s;
|
||||
int i;
|
||||
|
||||
if (!machine_is(cell))
|
||||
return;
|
||||
|
||||
/* We're searching for a direct child of the PHB */
|
||||
if (dev->bus->self != NULL || dev->devfn != 0)
|
||||
return;
|
||||
|
||||
hose = pci_bus_to_host(dev->bus);
|
||||
if (hose == NULL)
|
||||
return;
|
||||
|
||||
/* Only on PCIE */
|
||||
if (!of_device_is_compatible(hose->dn, "pciex"))
|
||||
return;
|
||||
|
||||
/* And only on axon */
|
||||
s = of_get_property(hose->dn, "model", NULL);
|
||||
if (!s || strcmp(s, "Axon") != 0)
|
||||
return;
|
||||
|
||||
for (i = 0; i < PCI_BRIDGE_RESOURCES; i++) {
|
||||
dev->resource[i].start = dev->resource[i].end = 0;
|
||||
dev->resource[i].flags = 0;
|
||||
}
|
||||
|
||||
printk(KERN_DEBUG "PCI: Hiding resources on Axon PCIE RC %s\n",
|
||||
pci_name(dev));
|
||||
}
|
||||
DECLARE_PCI_FIXUP_HEADER(PCI_ANY_ID, PCI_ANY_ID, cell_fixup_pcie_rootcomplex);
|
||||
|
||||
static int __init cell_publish_devices(void)
|
||||
{
|
||||
int node;
|
||||
|
|
Loading…
Reference in a new issue