On Sat, 4 Jun 2005, Andreas Koch wrote:
>
> While all of the USB and FireWire devices are visible using config
> space reads, they cannot be accessed correctly (all normal reads
> appear to return 0xff). After checking the dmesg logs, I find
>
> PCI: Cannot allocate resource region 7 of bridge 0000:02:00.0
> PCI: Cannot allocate resource region 8 of bridge 0000:02:00.0
Well, that would be right, because the parent of that bridge doesn't seem
to have any resources set up:
0000:00:1c.2 PCI bridge: Intel Corporation 82801FB/FBM/FR/FW/FRW (ICH6 Family) PCI Express Port 3 (rev 04) (prog-if 00 [Normal decode])
Control: I/O- Mem- BusMaster+ SpecCycle- MemWINV- VGASnoop- ParErr- Stepping- SERR- FastB2B-
Status: Cap+ 66Mhz- UDF- FastB2B- ParErr- DEVSEL=fast >TAbort- <TAbort- <MAbort- >SERR- <PERR-
Latency: 0, cache line size 08
Bus: primary=00, secondary=02, subordinate=04, sec-latency=0
I/O behind bridge: 00000000-00000fff
Memory behind bridge: 00000000-000fffff
Prefetchable memory behind bridge: 0000000000000000-0000000000000000
the "IO/memory behind bridge" things don't seem to be making a lot of
sense.
Hmm. Normally on PC's we let the BIOS worry about PCI bridge resource
setup. The hotplug code knows about the setup-bus stuff too, but the
_normal_ PCI bus resouces are usually left alone. It looks like maybe we
shouldn't do that any more for PCI Express.
Hmm.. Just a wild guess (and this may not work at _all_, so who knows..):
how about adding a
pci_assign_unassigned_resources();
call to the end of "pcibios_init()" in arch/i386/pci/common.c ?
NOTE! In order for that to even link, you need to make sure that you have
CONFIG_HOTPLUG enabled, otherwise x86 won't have even linked in the bus
resource code from drivers/pci/setup-bus.c. And even so, I won't guarantee
that it does anything sane...
(I'm really surprised that we've gone this long without havign x86 do the
bus setup, though. So I'd not be in the least surprised if we need
_something_ like this, I'm just not at all sure that just adding that
single line won't do something disastrously bad..)
Linus
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]