summaryrefslogtreecommitdiff
path: root/arch/nds32
diff options
context:
space:
mode:
authorMasahiro Yamada <yamada.masahiro@socionext.com>2020-02-14 10:40:19 +0300
committerPeng Fan <peng.fan@nxp.com>2020-02-19 16:27:30 +0300
commit9d86b89c590832c9bcb1c69d5ccdecdf731f97ae (patch)
treef742792fc5c973819dac194426231f05e25e4ecd /arch/nds32
parent950c5968672a22a65790534234d1106bd1303652 (diff)
downloadu-boot-9d86b89c590832c9bcb1c69d5ccdecdf731f97ae.tar.xz
dma-mapping: move dma_map_(un)single() to <linux/dma-mapping.h>
The implementation of dma_map_single() and dma_unmap_single() is exactly the same for all the architectures that support them. Factor them out to <linux/dma-mapping.h>, and make all drivers to include <linux/dma-mapping.h> instead of <asm/dma-mapping.h>. If we need to differentiate them for some architectures, we can move the generic definitions to <asm-generic/dma-mapping.h>. Add some comments to the helpers. The concept is quite similar to the DMA-API of Linux kernel. Drivers are agnostic about what is going on behind the scene. Just call dma_map_single() before the DMA, and dma_unmap_single() after it. Signed-off-by: Masahiro Yamada <yamada.masahiro@socionext.com>
Diffstat (limited to 'arch/nds32')
-rw-r--r--arch/nds32/include/asm/dma-mapping.h24
1 files changed, 0 insertions, 24 deletions
diff --git a/arch/nds32/include/asm/dma-mapping.h b/arch/nds32/include/asm/dma-mapping.h
index 784f489db5..f8668f1fe5 100644
--- a/arch/nds32/include/asm/dma-mapping.h
+++ b/arch/nds32/include/asm/dma-mapping.h
@@ -19,28 +19,4 @@ static void *dma_alloc_coherent(size_t len, unsigned long *handle)
return (void *)*handle;
}
-static inline dma_addr_t dma_map_single(void *vaddr, size_t len,
- enum dma_data_direction dir)
-{
- unsigned long addr = (unsigned long)vaddr;
-
- len = ALIGN(len, ARCH_DMA_MINALIGN);
-
- if (dir == DMA_FROM_DEVICE)
- invalidate_dcache_range(addr, addr + len);
- else
- flush_dcache_range(addr, addr + len);
-
- return addr;
-}
-
-static inline void dma_unmap_single(dma_addr_t addr, size_t len,
- enum dma_data_direction dir)
-{
- len = ALIGN(len, ARCH_DMA_MINALIGN);
-
- if (dir != DMA_TO_DEVICE)
- invalidate_dcache_range(addr, addr + len);
-}
-
#endif /* __ASM_NDS_DMA_MAPPING_H */