PCI: designware: Fix I/O transfers by using CPU (not realio) address
authorPratyush Anand <pratyush.anand@st.com>
Wed, 11 Dec 2013 09:38:33 +0000 (15:08 +0530)
committerBjorn Helgaas <bhelgaas@google.com>
Fri, 20 Dec 2013 16:21:35 +0000 (09:21 -0700)
commitfce8591f73c6a30c231f220d1092362aae0b985c
treeeac01872fe7826851ee3b335f821a232d25584d9
parenta01ef59e131b78b0fa7af235ea958bd17e5e86ca
PCI: designware: Fix I/O transfers by using CPU (not realio) address

pp->io_base, which is the input of the outbound IO address translation
unit, should be the CPU address.  It was incorrectly programmed to the
realio address.

We should pass global_io_offset rather than sys->io_offset to
pci_ioremap_io(), so we map the new window into the first available spot in
the Linux view of the I/O space.

We must also pass CPU address instead of realio address to pci_ioremap_io().

This patch fixes above issue.  It has been tested with Lecroy PTC in AIC
mode and Pericom PI7C9X2G303EL PCIe switch, which does not work otherwise.

Tested-by: Mohit Kumar <mohit.kumar@st.com>
Tested-by: Tim Harvey <tharvey@gateworks.com>
Signed-off-by: Pratyush Anand <pratyush.anand@st.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Marek Vasut <marex@denx.de
Reviewed-by: Jagannadha Sutradharudu Teki <jagannadh.teki@gmail.com>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Acked-by: Jingoo Han <jg1.han@samsung.com>
Cc: Richard Zhu <Hong-Xing.Zhu@freescale.com>
drivers/pci/host/pcie-designware.c