arm64: Use swiotlb late initialisation
authorCatalin Marinas <catalin.marinas@arm.com>
Thu, 27 Feb 2014 12:24:57 +0000 (12:24 +0000)
committerCatalin Marinas <catalin.marinas@arm.com>
Thu, 27 Feb 2014 14:11:53 +0000 (14:11 +0000)
Since arm64 does not support ISA, there is no need for early swiotlb
initialisation. This patch switches the DMA mapping code to
swiotlb_tlb_late_init_with_default_size(). A side effect of this is that
GFP_DMA is used for the swiotlb buffer and devices with a 32-bit
coherent mask are correctly supported.

Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
arch/arm64/mm/dma-mapping.c
arch/arm64/mm/init.c

index 26b2512c1fcd1bb8aa9025797506cdb90a62f7b7..afa91a26a72b2c32c4155d70c1152cf497a3fb9c 100644 (file)
@@ -93,11 +93,17 @@ static struct dma_map_ops coherent_swiotlb_dma_ops = {
        .mapping_error = swiotlb_dma_mapping_error,
 };
 
-void __init arm64_swiotlb_init(void)
+extern int swiotlb_late_init_with_default_size(size_t default_size);
+
+static int __init swiotlb_late_init(void)
 {
+       size_t swiotlb_size = min(SZ_64M, MAX_ORDER_NR_PAGES << PAGE_SHIFT);
+
        dma_ops = &coherent_swiotlb_dma_ops;
-       swiotlb_init(1);
+
+       return swiotlb_late_init_with_default_size(swiotlb_size);
 }
+subsys_initcall(swiotlb_late_init);
 
 #define PREALLOC_DMA_DEBUG_ENTRIES     4096
 
index a61a4d560d12440ec593d92afc65fcfed1349434..88627c450a6cbd3f5cdd0eb7056eeecaac76b6f2 100644 (file)
@@ -262,8 +262,6 @@ static void __init free_unused_memmap(void)
  */
 void __init mem_init(void)
 {
-       arm64_swiotlb_init();
-
        max_mapnr   = pfn_to_page(max_pfn + PHYS_PFN_OFFSET) - mem_map;
 
 #ifndef CONFIG_SPARSEMEM_VMEMMAP