linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
* I/O and multiple PCI buses
@ 2013-04-18 15:27 Andrew Murray
  2013-04-18 16:35 ` Bjorn Helgaas
  2013-04-18 17:41 ` Jason Gunthorpe
  0 siblings, 2 replies; 3+ messages in thread
From: Andrew Murray @ 2013-04-18 15:27 UTC (permalink / raw)
  To: linux-arm-kernel

I'm trying to understand PCI I/O addressing in the kernel... (again)

I understand that ideally you want to give PCI bus addresses to PCI devices in
the range of 0K to 64K. This seems to be achieved in pcibios_init_resources in
arm's kernel/bios32.c implementation.

What happens if you want to add another root bus? In this implementation the
start address of the io_res is now 64K and as sys->io_offset is set to 0 the
bus addresses under this second root bus will be 64K-128K - which I assume may
break some things.

Am I correct that for ARM there are no implementations where subsequent root
buses allocate I/O starting from 0?

And to allow subsequent busses to use I/O starting from 0, you'd have to set
sys->io_offset to 64K*nr and adapt functions such as pci_iomap to use the
offset?

Are there any other archiectures that do give I/O ranges starting from 0 in
subsequent root busses? Or am I missing something here?

Andrew Murray

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2013-04-18 17:41 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-04-18 15:27 I/O and multiple PCI buses Andrew Murray
2013-04-18 16:35 ` Bjorn Helgaas
2013-04-18 17:41 ` Jason Gunthorpe

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).