FSL PCI cannot directly address the whole lower 4 GiB due to
conflicts with PCICSRBAR and outbound windows.  By the time
max_direct_dma_addr is set to the precise limit, it will be too late to
alter the zone limits, but we should always have at least 2 GiB mapped
(unless RAM is smaller than that).
Signed-off-by: Scott Wood <scottwood@freescale.com>
Cc: Shaohui Xie <Shaohui.Xie@freescale.com>
 #include <asm/time.h>
 #include <asm/machdep.h>
 #include <asm/pci-bridge.h>
+#include <asm/pgtable.h>
 #include <asm/ppc-pci.h>
 #include <mm/mmu_decl.h>
 #include <asm/prom.h>
 
        swiotlb_detect_4g();
 
+#if defined(CONFIG_FSL_PCI) && defined(CONFIG_ZONE_DMA32)
+       /*
+        * Inbound windows don't cover the full lower 4 GiB
+        * due to conflicts with PCICSRBAR and outbound windows,
+        * so limit the DMA32 zone to 2 GiB, to allow consistent
+        * allocations to succeed.
+        */
+       limit_zone_pfn(ZONE_DMA32, 1UL << (31 - PAGE_SHIFT));
+#endif
+
        pr_info("%s board\n", ppc_md.name);
 
        mpc85xx_qe_init();
 
 #include <linux/kernel.h>
 #include <linux/of_fdt.h>
 #include <asm/machdep.h>
+#include <asm/pgtable.h>
 #include <asm/time.h>
 #include <asm/udbg.h>
 #include <asm/mpic.h>
 
        fsl_pci_assign_primary();
        swiotlb_detect_4g();
+#if defined(CONFIG_FSL_PCI) && defined(CONFIG_ZONE_DMA32)
+       /*
+        * Inbound windows don't cover the full lower 4 GiB
+        * due to conflicts with PCICSRBAR and outbound windows,
+        * so limit the DMA32 zone to 2 GiB, to allow consistent
+        * allocations to succeed.
+        */
+       limit_zone_pfn(ZONE_DMA32, 1UL << (31 - PAGE_SHIFT));
+#endif
        mpc85xx_smp_init();
 }