aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorBernhard Kaindl <bk@suse.de>2006-02-18 04:36:55 -0500
committerGreg Kroah-Hartman <gregkh@suse.de>2006-03-23 17:35:14 -0500
commit8c4b2cf9af9b4ecc29d4f0ec4ecc8e94dc4432d7 (patch)
tree4f8e56e9012847aa4dfe4ec2c59f4d8b2714f2b2 /drivers
parenta0454b40ee8fac03194bb71f01730266506e75e1 (diff)
[PATCH] PCI: PCI/Cardbus cards hidden, needs pci=assign-busses to fix
"In some cases, especially on modern laptops with a lot of PCI and cardbus bridges, we're unable to assign correct secondary/subordinate bus numbers to all cardbus bridges due to BIOS limitations unless we are using "pci=assign-busses" boot option." -- Ivan Kokshaysky (from a patch comment) Without it, Cardbus cards inserted are never seen by PCI because the parent PCI-PCI Bridge of the Cardbus bridge will not pass and translate Type 1 PCI configuration cycles correctly and the system will fail to find and initialise the PCI devices in the system. Reference: PCI-PCI Bridges: PCI Configuration Cycles and PCI Bus Numbering: http://www.science.unitn.it/~fiorella/guidelinux/tlk/node72.html The reason for this is that: ``All PCI busses located behind a PCI-PCI bridge must reside between the secondary bus number and the subordinate bus number (inclusive).'' "pci=assign-busses" makes pcibios_assign_all_busses return 1 and this turns on PCI renumbering during PCI probing. Alan suggested to use DMI automatically set assign-busses on problem systems. The only question for me was where to put it. I put it directly before scanning PCI bus into pcibios_scan_root() because it's called from legacy, acpi and numa and so it can be one place for all systems and configurations which may need it. AMD64 Laptops are also affected and fixed by assign-busses, and the code is also incuded from arch/x86_64/pci/ that place will also work for x86_64 kernels, I only ifdef'-ed the x86-only Laptop in this example. Affected and known or assumed to be fixed with it are (found by googling): * ASUS Z71V and L3s * Samsung X20 * Compaq R3140us and all Compaq R3000 series laptops with TI1620 Controller, also Compaq R4000 series (from a kernel.org bugreport) * HP zv5000z (AMD64 3700+, known that fixup_parent_subordinate_busnr fixes it) * HP zv5200z * IBM ThinkPad 240 * An IBM ThinkPad (1.8 GHz Pentium M) debugged by Pavel Machek gives the correspondig message which detects the possible problem. * MSI S260 / Medion SIM 2100 MD 95600 The patch also expands the "try pci=assign-busses" warning so testers will help us to update the DMI table. Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru> Cc: Alan Cox <alan@lxorguk.ukuu.org.uk> Cc: Dominik Brodowski <linux@dominikbrodowski.net> Cc: Russell King <rmk@arm.linux.org.uk> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/pci/probe.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/pci/probe.c b/drivers/pci/probe.c
index 542e7dfb371b..e3dc3063e05b 100644
--- a/drivers/pci/probe.c
+++ b/drivers/pci/probe.c
@@ -589,13 +589,15 @@ int __devinit pci_scan_bridge(struct pci_bus *bus, struct pci_dev * dev, int max
589 (child->number > bus->subordinate) || 589 (child->number > bus->subordinate) ||
590 (child->number < bus->number) || 590 (child->number < bus->number) ||
591 (child->subordinate < bus->number)) { 591 (child->subordinate < bus->number)) {
592 printk(KERN_WARNING "PCI: Bus #%02x (-#%02x) may be " 592 printk(KERN_WARNING "PCI: Bus #%02x (-#%02x) is "
593 "hidden behind%s bridge #%02x (-#%02x)%s\n", 593 "hidden behind%s bridge #%02x (-#%02x)%s\n",
594 child->number, child->subordinate, 594 child->number, child->subordinate,
595 bus->self->transparent ? " transparent" : " ", 595 bus->self->transparent ? " transparent" : " ",
596 bus->number, bus->subordinate, 596 bus->number, bus->subordinate,
597 pcibios_assign_all_busses() ? " " : 597 pcibios_assign_all_busses() ? " " :
598 " (try 'pci=assign-busses')"); 598 " (try 'pci=assign-busses')");
599 printk(KERN_WARNING "Please report the result to "
600 "linux-kernel to fix this permanently\n");
599 } 601 }
600 bus = bus->parent; 602 bus = bus->parent;
601 } 603 }