sparc/PCI: Support arbitrary host bridge address offset
authorYinghai Lu <yinghai@kernel.org>
Fri, 21 Apr 2017 05:04:48 +0000 (22:04 -0700)
committerBjorn Helgaas <helgaas@kernel.org>
Thu, 15 Feb 2018 21:07:30 +0000 (15:07 -0600)
commitb4a304489ef95b6b921d1faa46438d9ea89cfd4b
treef6105882b0c7a6404faa37eea5c82fa90f0a030f
parent7928b2cbe55b2a410a0f5c1f154610059c57b1b2
sparc/PCI: Support arbitrary host bridge address offset

Add support for arbitrary bus address offset.  Previously we ignored the
child (PCI) address in the "ranges" property and assumed it was always
zero.  That means every host bridge window mapped to PCI bus address zero,
e.g.,

  pci_bus 0000:00: root bus resource [mem 0x2000000000000-0x200007fffffff] (bus address [0x00000000-0x7fffffff])

But some systems have host bridge windows with non-zero child addresses, so
parse the child address and compute the offset between the parent (CPU) and
child (PCI) addresses.  This allows windows like these:

  /pci@305: PCI MEM [mem 0x2000000100000-0x200007effffff] offset 2000000000000
  pci_sun4v f02ae7f8: PCI host bridge to bus 0000:00
  pci_bus 0000:00: root bus resource [mem 0x2000000100000-0x200007effffff] (bus address [0x00100000-0x7effffff])

[bhelgaas: changelog]
Tested-by: Khalid Aziz <khalid.aziz@oracle.com>
Signed-off-by: Yinghai Lu <yinghai@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Acked-by: David S. Miller <davem@davemloft.net>
Cc: sparclinux@vger.kernel.org
arch/sparc/kernel/pci.c
arch/sparc/kernel/pci_common.c
arch/sparc/kernel/pci_impl.h