summaryrefslogtreecommitdiffstats
path: root/arch/nios2/mm
diff options
context:
space:
mode:
Diffstat (limited to 'arch/nios2/mm')
-rw-r--r--arch/nios2/mm/dma-mapping.c34
1 files changed, 15 insertions, 19 deletions
diff --git a/arch/nios2/mm/dma-mapping.c b/arch/nios2/mm/dma-mapping.c
index 4af9e5b5ba1c..9cb238664584 100644
--- a/arch/nios2/mm/dma-mapping.c
+++ b/arch/nios2/mm/dma-mapping.c
@@ -60,32 +60,28 @@ void arch_sync_dma_for_cpu(struct device *dev, phys_addr_t paddr,
60 } 60 }
61} 61}
62 62
63void *arch_dma_alloc(struct device *dev, size_t size, dma_addr_t *dma_handle, 63void arch_dma_prep_coherent(struct page *page, size_t size)
64 gfp_t gfp, unsigned long attrs)
65{ 64{
66 void *ret; 65 unsigned long start = (unsigned long)page_address(page);
67 66
68 /* optimized page clearing */ 67 flush_dcache_range(start, start + size);
69 gfp |= __GFP_ZERO; 68}
70 69
71 if (dev == NULL || (dev->coherent_dma_mask < 0xffffffff)) 70void *uncached_kernel_address(void *ptr)
72 gfp |= GFP_DMA; 71{
72 unsigned long addr = (unsigned long)ptr;
73 73
74 ret = (void *) __get_free_pages(gfp, get_order(size)); 74 addr |= CONFIG_NIOS2_IO_REGION_BASE;
75 if (ret != NULL) {
76 *dma_handle = virt_to_phys(ret);
77 flush_dcache_range((unsigned long) ret,
78 (unsigned long) ret + size);
79 ret = UNCAC_ADDR(ret);
80 }
81 75
82 return ret; 76 return (void *)ptr;
83} 77}
84 78
85void arch_dma_free(struct device *dev, size_t size, void *vaddr, 79void *cached_kernel_address(void *ptr)
86 dma_addr_t dma_handle, unsigned long attrs)
87{ 80{
88 unsigned long addr = (unsigned long) CAC_ADDR((unsigned long) vaddr); 81 unsigned long addr = (unsigned long)ptr;
82
83 addr &= ~CONFIG_NIOS2_IO_REGION_BASE;
84 addr |= CONFIG_NIOS2_KERNEL_REGION_BASE;
89 85
90 free_pages(addr, get_order(size)); 86 return (void *)ptr;
91} 87}