The Octeon family of SOCs support physical memory outside of the 32-bit addressing range. To support 32-bit devices, we need to use the swiotlb bounce buffer mechanism. There are several parts to the patch set. 1 - Set the proper dma_masks for the octeon_mgmt platform device so that it continues to function with the rewritten dma mapping code to follow. 2,3,4 - Establish a properly constrained DMA32 zone for Octeon. 5 - Convert MIPS to use dma-mapping-common.h 6,7 - Trivial swiotlb changes. 8 - Get MIPS ready to use swiotlb. 9 - Rewrite Octeon dma mapping code. Since the only non-MIPS parts of this patch set are trivial changes to swiotlb, I would suggest that they could all be merged via Ralf's tree if deemed acceptable. David Daney (9): MIPS: Octeon: Set dma_masks for octeon_mgmt device. MIPS: Allow MAX_DMA32_PFN to be overridden. MIPS: Octeon: Adjust top of DMA32 zone. MIPS: Octeon: Select ZONE_DMA32 MIPS: Convert DMA to use dma-mapping-common.h swiotlb: Declare swiotlb_init_with_default_size() swiotlb: Make bounce buffer bounds non-static. MIPS: Add a platform hook for swiotlb setup. MIPS: Octeon: Rewrite DMA mapping functions. arch/mips/Kconfig | 3 + arch/mips/cavium-octeon/Kconfig | 12 + arch/mips/cavium-octeon/dma-octeon.c | 529 +++++++++----------- arch/mips/cavium-octeon/octeon-platform.c | 5 + arch/mips/include/asm/bootinfo.h | 5 + arch/mips/include/asm/device.h | 15 +- arch/mips/include/asm/dma-mapping.h | 125 ++++-- arch/mips/include/asm/dma.h | 3 + .../asm/mach-cavium-octeon/cpu-feature-overrides.h | 6 + .../include/asm/mach-cavium-octeon/dma-coherence.h | 19 +- arch/mips/include/asm/octeon/pci-octeon.h | 10 + arch/mips/kernel/setup.c | 5 + arch/mips/mm/dma-default.c | 179 +++---- arch/mips/pci/pci-octeon.c | 60 ++- arch/mips/pci/pcie-octeon.c | 5 + include/linux/swiotlb.h | 7 + lib/swiotlb.c | 62 ++-- 17 files changed, 571 insertions(+), 479 deletions(-) -- 1.7.2.2