Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

Unicore32: adapt for dma_map_ops changes

Adapt core Unicore32 architecture code for dma_map_ops changes: replace
alloc/free_coherent with generic alloc/free methods.

Signed-off-by: Andrzej Pietrasiewicz <andrzej.p@samsung.com>
Acked-by: Kyungmin Park <kyungmin.park@samsung.com>
[added swiotlb_alloc/free_coherent wrappers]
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
Reviewed-by: Arnd Bergmann <arnd@arndb.de>

authored by

Andrzej Pietrasiewicz and committed by
Marek Szyprowski
ffc4a3fa 988624ec

+28 -8
+12 -6
arch/unicore32/include/asm/dma-mapping.h
··· 82 82 return 0; 83 83 } 84 84 85 - static inline void *dma_alloc_coherent(struct device *dev, size_t size, 86 - dma_addr_t *dma_handle, gfp_t flag) 85 + #define dma_alloc_coherent(d,s,h,f) dma_alloc_attrs(d,s,h,f,NULL) 86 + 87 + static inline void *dma_alloc_attrs(struct device *dev, size_t size, 88 + dma_addr_t *dma_handle, gfp_t flag, 89 + struct dma_attrs *attrs) 87 90 { 88 91 struct dma_map_ops *dma_ops = get_dma_ops(dev); 89 92 90 - return dma_ops->alloc_coherent(dev, size, dma_handle, flag); 93 + return dma_ops->alloc(dev, size, dma_handle, flag, attrs); 91 94 } 92 95 93 - static inline void dma_free_coherent(struct device *dev, size_t size, 94 - void *cpu_addr, dma_addr_t dma_handle) 96 + #define dma_free_coherent(d,s,c,h) dma_free_attrs(d,s,c,h,NULL) 97 + 98 + static inline void dma_free_attrs(struct device *dev, size_t size, 99 + void *cpu_addr, dma_addr_t dma_handle, 100 + struct dma_attrs *attrs) 95 101 { 96 102 struct dma_map_ops *dma_ops = get_dma_ops(dev); 97 103 98 - dma_ops->free_coherent(dev, size, cpu_addr, dma_handle); 104 + dma_ops->free(dev, size, cpu_addr, dma_handle, attrs); 99 105 } 100 106 101 107 #define dma_alloc_noncoherent(d, s, h, f) dma_alloc_coherent(d, s, h, f)
+16 -2
arch/unicore32/mm/dma-swiotlb.c
··· 17 17 18 18 #include <asm/dma.h> 19 19 20 + static void *unicore_swiotlb_alloc_coherent(struct device *dev, size_t size, 21 + dma_addr_t *dma_handle, gfp_t flags, 22 + struct dma_attrs *attrs) 23 + { 24 + return swiotlb_alloc_coherent(dev, size, dma_handle, flags); 25 + } 26 + 27 + static void unicore_swiotlb_free_coherent(struct device *dev, size_t size, 28 + void *vaddr, dma_addr_t dma_addr, 29 + struct dma_attrs *attrs) 30 + { 31 + swiotlb_free_coherent(dev, size, vaddr, dma_addr); 32 + } 33 + 20 34 struct dma_map_ops swiotlb_dma_map_ops = { 21 - .alloc_coherent = swiotlb_alloc_coherent, 22 - .free_coherent = swiotlb_free_coherent, 35 + .alloc = unicore_swiotlb_alloc_coherent, 36 + .free = unicore_swiotlb_free_coherent, 23 37 .map_sg = swiotlb_map_sg_attrs, 24 38 .unmap_sg = swiotlb_unmap_sg_attrs, 25 39 .dma_supported = swiotlb_dma_supported,