From mboxrd@z Thu Jan 1 00:00:00 1970 From: Akinobu Mita Subject: [PATCH v3 0/5] enhance DMA CMA on x86 Date: Tue, 15 Apr 2014 22:08:44 +0900 Message-ID: <1397567329-3771-1-git-send-email-akinobu.mita@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: iommu-bounces-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org Errors-To: iommu-bounces-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org To: linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org Cc: Andi Kleen , x86-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org, Akinobu Mita , iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org, Ingo Molnar , "H. Peter Anvin" , Thomas Gleixner , David Woodhouse List-Id: iommu@lists.linux-foundation.org This patch set enhances the DMA Contiguous Memory Allocator on x86. Currently the DMA CMA is only supported with pci-nommu dma_map_ops and furthermore it can't be enabled on x86_64. But I would like to allocate big contiguous memory with dma_alloc_coherent() and tell it to the device that requires it, regardless of which dma mapping implementation is actually used in the system. So this makes it work with swiotlb and intel-iommu dma_map_ops, too. And this also extends "cma=" kernel parameter to specify placement constraint by the physical address range of memory allocations. For example, CMA allocates memory below 4GB by "cma=64M@0-4G", it is required for the devices only supporting 32-bit addressing on 64-bit systems without iommu. * Changes from v2 - Rebased on current Linus tree - Add Acked-by line - Fix gfp flags check for __GFP_ATOMIC, reported by Marek Szyprowski - Avoid CMA area on highmem with cma= option, reported by Marek Szyprowski * Changes from v1 - fix dma_alloc_coherent() with __GFP_ZERO - add placement specifier for "cma=" kernel parameter Akinobu Mita (5): x86: make dma_alloc_coherent() return zeroed memory if CMA is enabled x86: enable DMA CMA with swiotlb intel-iommu: integrate DMA CMA memblock: introduce memblock_alloc_range() cma: add placement specifier for "cma=" kernel parameter Documentation/kernel-parameters.txt | 7 +++++-- arch/x86/Kconfig | 2 +- arch/x86/include/asm/swiotlb.h | 7 +++++++ arch/x86/kernel/amd_gart_64.c | 2 +- arch/x86/kernel/pci-dma.c | 3 +-- arch/x86/kernel/pci-swiotlb.c | 9 +++++--- arch/x86/kernel/setup.c | 2 +- arch/x86/pci/sta2x11-fixup.c | 6 ++---- drivers/base/dma-contiguous.c | 42 ++++++++++++++++++++++++++++--------- drivers/iommu/intel-iommu.c | 32 +++++++++++++++++++++------- include/linux/dma-contiguous.h | 9 +++++--- include/linux/memblock.h | 2 ++ include/linux/swiotlb.h | 2 ++ lib/swiotlb.c | 2 +- mm/memblock.c | 21 +++++++++++++++---- 15 files changed, 108 insertions(+), 40 deletions(-) Cc: Marek Szyprowski Cc: Konrad Rzeszutek Wilk Cc: David Woodhouse Cc: Don Dutile Cc: Thomas Gleixner Cc: Ingo Molnar Cc: "H. Peter Anvin" Cc: Andi Kleen Cc: x86-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org Cc: iommu-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org -- 1.8.3.2