[PATCH 1/3 v3] ARM Realview PCIX map include file changes

Russell King - ARM Linux linux at arm.linux.org.uk
Thu Oct 6 10:23:50 EDT 2011


On Thu, Oct 06, 2011 at 03:00:50PM +0100, Colin Tuckley wrote:
> > pcibios_min_io should be 0x1000 as a constant, in order to get the
> > ISA addresses out of the way, but there is no need to make it
> > board dependent.
> 
> REALVIEW_PB_PCI_IO_BASE is currently 0x90050000, which works, so
> why would I change pcibios_min_io to 0x1000 ?

All the points in this email all go together.

This is how it works:

1. The PCI IO window is _supposed_ to be 64K in size.
2. "pcibios_min_io" sets the minimum offset into the PCI IO window which
   PCI IO BARs should be assigned.  It is assumed that a PCI IO BAR value
   of 0 corresponds with the virtual base address of this window.
3. inb() et.al. take the PCI IO offset and _not_ the physical address nor
   the virtual address of the desired access.

This is so that existing drivers - including VGA card drivers - can work.
There are many PCI cards which require accesses to specific IO locations
not listed in their BARs for initialization etc.

Moreover, we're trying to work towards having a single fixed 64k PCI IO
virtual mapping across all platforms (so that this shows up at the same
virtual address no matter what platform.)  Not having this is a blocker
to the multi-platform activity which Linaro is tasked with.



More information about the linux-arm-kernel mailing list