The commit introducing pcibios_io_space_offset() was ignoring 32-bit to
64-bit sign extention, which is the case on ppc32 with 64-bit resource
addresses. This only seems to have shown up while running under QEMU for
e500mc target. It may or may be suboptimal that QEMU has an IO base
address > 32-bits for the e500-pci implementation, but 1) it's still a
regression and 2) it's more correct to handle things this way.

Signed-off-by: Ben Collins <bcoll...@ubuntu.com>
Cc: Benjamin Herrenschmidt <b...@kernel.crashing.org>
---
 arch/powerpc/kernel/pci-common.c |    8 +++++++-
 1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/arch/powerpc/kernel/pci-common.c b/arch/powerpc/kernel/pci-common.c
index 8e78e93..be9ced7 100644
--- a/arch/powerpc/kernel/pci-common.c
+++ b/arch/powerpc/kernel/pci-common.c
@@ -1477,9 +1477,15 @@ int pcibios_enable_device(struct pci_dev *dev, int mask)
        return pci_enable_resources(dev, mask);
 }
 
+/* Before assuming too much here, take care to realize that we need sign
+ * extension from 32-bit pointers to 64-bit resource addresses to work.
+ */
 resource_size_t pcibios_io_space_offset(struct pci_controller *hose)
 {
-       return (unsigned long) hose->io_base_virt - _IO_BASE;
+       long vbase = (long)hose->io_base_virt;
+       long io_base = _IO_BASE;
+
+       return (resource_size_t)(vbase - io_base);
 }
 
 static void __devinit pcibios_setup_phb_resources(struct pci_controller *hose, 
struct list_head *resources)
-- 
1.7.9.5

--
Ben Collins
Servergy, Inc.
(757) 243-7557

CONFIDENTIALITY NOTICE: This communication contains privileged and/or 
confidential information; and should be maintained with the strictest 
confidence. It is intended solely for the use of the person or entity in which 
it is addressed. If you are not the intended recipient, you are STRICTLY 
PROHIBITED from disclosing, copying, distributing or using any of this 
information. If you received this communication in error, please contact the 
sender immediately and destroy the material in its entirety, whether electronic 
or hard copy.

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to