Rename xlp_enable_pci_bswap() to xlp_config_pci_bswap(), and add '#ifdef __BIG_ENDIAN' to its contents so that it is an empty function when compiled in little-endian mode. On Netlogic XLP, the PCIe initialization code to enable byteswap is needed only in big-endian mode. Signed-off-by: Jayachandran C <jchandra@xxxxxxxxxxxx> --- [Update comments to reflect changes in updated patch. The changes are based on a suggestion on #ifdef usage by sshtylyov@xxxxxxxxxx ] arch/mips/pci/pci-xlp.c | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/arch/mips/pci/pci-xlp.c b/arch/mips/pci/pci-xlp.c index 140557a..d201efa 100644 --- a/arch/mips/pci/pci-xlp.c +++ b/arch/mips/pci/pci-xlp.c @@ -191,8 +191,14 @@ int pcibios_plat_dev_init(struct pci_dev *dev) return 0; } -static int xlp_enable_pci_bswap(void) +/* + * If big-endian, enable hardware byteswap on the PCIe bridges. + * This will make both the SoC and PCIe devices behave consistently with + * readl/writel. + */ +static void xlp_config_pci_bswap(void) { +#ifdef __BIG_ENDIAN uint64_t pciebase, sysbase; int node, i; u32 reg; @@ -222,7 +228,7 @@ static int xlp_enable_pci_bswap(void) reg = nlm_read_bridge_reg(sysbase, BRIDGE_PCIEIO_LIMIT0 + i); nlm_write_pci_reg(pciebase, PCIE_BYTE_SWAP_IO_LIM, reg | 0xfff); } - return 0; +#endif } static int __init pcibios_init(void) @@ -235,7 +241,7 @@ static int __init pcibios_init(void) ioport_resource.start = 0; ioport_resource.end = ~0; - xlp_enable_pci_bswap(); + xlp_config_pci_bswap(); set_io_port_base(CKSEG1); nlm_pci_controller.io_map_base = CKSEG1; -- 1.7.9.5