[PARISC] Fix infinite loop in /proc/iomem
pcibios_link_hba_resources() could corrupt the resource tree by inserting resources in the wrong place. Fix this by calling pci_claim_resource() for PCI-PCI bridges. Delete pcibios_link_hba_resources as we shouldn't need it any more. Also get rid of lba_claim_dev_resources() and just call pci_claim_resource() directly. Signed-off-by: Matthew Wilcox <willy@linux.intel.com> Signed-off-by: Kyle McMartin <kyle@mcmartin.ca>
This commit is contained in:
committed by
Kyle McMartin
parent
26f0324922
commit
9611f61eb5
@ -194,31 +194,6 @@ void __init pcibios_init_bus(struct pci_bus *bus)
|
||||
pci_write_config_word(dev, PCI_BRIDGE_CONTROL, bridge_ctl);
|
||||
}
|
||||
|
||||
|
||||
/* KLUGE: Link the child and parent resources - generic PCI didn't */
|
||||
static void
|
||||
pcibios_link_hba_resources( struct resource *hba_res, struct resource *r)
|
||||
{
|
||||
if (!r->parent) {
|
||||
printk(KERN_EMERG "PCI: resource not parented! [%p-%p]\n",
|
||||
(void*) r->start, (void*) r->end);
|
||||
r->parent = hba_res;
|
||||
|
||||
/* reverse link is harder *sigh* */
|
||||
if (r->parent->child) {
|
||||
if (r->parent->sibling) {
|
||||
struct resource *next = r->parent->sibling;
|
||||
while (next->sibling)
|
||||
next = next->sibling;
|
||||
next->sibling = r;
|
||||
} else {
|
||||
r->parent->sibling = r;
|
||||
}
|
||||
} else
|
||||
r->parent->child = r;
|
||||
}
|
||||
}
|
||||
|
||||
/* called by drivers/pci/setup-bus.c:pci_setup_bridge(). */
|
||||
void __devinit pcibios_resource_to_bus(struct pci_dev *dev,
|
||||
struct pci_bus_region *region, struct resource *res)
|
||||
@ -245,13 +220,6 @@ void __devinit pcibios_resource_to_bus(struct pci_dev *dev,
|
||||
DBG_RES("pcibios_resource_to_bus(%02x %s [%lx,%lx])\n",
|
||||
bus->number, res->flags & IORESOURCE_IO ? "IO" : "MEM",
|
||||
region->start, region->end);
|
||||
|
||||
/* KLUGE ALERT
|
||||
** if this resource isn't linked to a "parent", then it seems
|
||||
** to be a child of the HBA - lets link it in.
|
||||
*/
|
||||
pcibios_link_hba_resources(&hba->io_space, bus->resource[0]);
|
||||
pcibios_link_hba_resources(&hba->lmmio_space, bus->resource[1]);
|
||||
}
|
||||
|
||||
void pcibios_bus_to_resource(struct pci_dev *dev, struct resource *res,
|
||||
|
Reference in New Issue
Block a user