Greg KH <[EMAIL PROTECTED]> writes: > On Tue, Mar 20, 2007 at 12:18:24PM -0400, Daniel Yeisley wrote: >> It has been mentioned before that large systems with a lot of PCI buses >> have issues with the 64k I/O space limit. The ES7000 has a BIOS option >> to either assign I/O space to all adapters, or only to those that need >> it. A list of supported adapters that don't need it is kept in the >> BIOS. When this option is used, the kernel sees the BARs on the >> adapters and still tries to assign I/O space (until it runs out). I've >> written a patch to implement a boot parameter that tells the kernel not >> to assign I/O space if the BIOS hasn't. > > How prelevant are machines like this? And why are the BARs on these > devices wrong?
It is a machine scaling issue, and largely caused because we have only one PCI-IO space on x86. Since devices are increasingly moving to mmaped I/O it becomes less of an issue but there are still legacy bits and pieces. The bridges should be able to correctly have a no pci io region, by setting base > than limit. Having bridges that can map pci io but don't have anything behind them is common. The concept of having devices that have I/O bars that we should not assign I/O space to I find a little weird. I guess we can detect this case by simply looking to see if the bridge maps the address assigned to the bar. Ideally the way to handle this case is to not that the BAR is not valid (but it could be) and not attempt to fix this until the driver tries to use the BAR. The approach where we don't allocate a bar if the BIOS doesn't sounds like a hack, and we still need code in the kernel to detect that the BAR has an invalid value and that we can't use it. I have seen so many different api's for mapping the region behind a bar that I'm a little fuzzy. Is my recollection correct that we have enough flexibility in the current API that we can detect an invalid address and allocate a valid one if needed? I do know we have a semi common case that is related to this where the BIOS does not allocate a resource because it knows we don't need it, and the kernel being more generic decides to allocate it just in case. At which point the kernel reprograms the hardware to allocate the resource and then we have problems because the kernel didn't have enough knowledge to reprogram the root complex (northbridge) correctly. So if we can delay our fixups to when we really need them the changes of linux working on a machine where peculiar things are happening are greater. Eric - 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/