On Sun, Sep 9, 2012 at 2:27 AM, <bugzilla-daemon@xxxxxxxxxxxxxxxxxxx> wrote: > https://bugzilla.kernel.org/show_bug.cgi?id=18412 > > --- Comment #14 from VL <vl.homutov@xxxxxxxxx> 2012-09-09 08:27:17 --- >> Given the [bus 20-08] range, I suspect that the patch in comment #9 may fix it, >> and that's something we could apply. Can you try just that patch on top of a >> 3.5 or 3.6-rc4 kernel? > > yes, this patch fixes the problem. Yinghai, you put the following (whitespace damaged) patch in the bugzilla, and VL says it fixes his sytem. He has a P2P bridge with secondary > subordinate: pci 0000:00:1e.0: PCI bridge to [bus 20-08] (subtractive decode) The current kernel doesn't probe behind this bridge, so it doesn't find a couple devices. With the patch below, we reassign the secondary bus number from 20 to 08, so we do find those devices. I'm slightly concerned that if we apply a patch like this, it removes one way a BIOS could hide devices from the OS. But maybe we don't need to worry about that. We have to configure hot-added P2P bridges from scratch, so maybe we should be aggressive about fixing bridges like this, too. Are you comfortable enough with this patch to post it with a Signed-off-by? diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c index 3cdba8b..a8f1bf6 100644 --- a/drivers/pci/probe.c +++ b/drivers/pci/probe.c @@ -729,7 +729,8 @@ int __devinit pci_scan_bridge(struct pci_bus *bus, struct pci_dev *dev, int max, /* Check if setup is sensible at all */ if (!pass && - (primary != bus->number || secondary <= bus->number)) { + (primary != bus->number || secondary <= bus->number || + secondary > subordinate)) { dev_dbg(&dev->dev, "bus configuration invalid, reconfiguring\n"); broken = 1; } -- To unsubscribe from this list: send the line "unsubscribe linux-pci" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html