summaryrefslogtreecommitdiffstats
path: root/arch/x86
diff options
context:
space:
mode:
authorMasahiro Yamada <yamada.masahiro@socionext.com>2020-02-14 16:40:19 +0900
committerPeng Fan <peng.fan@nxp.com>2020-02-19 21:27:30 +0800
commit9d86b89c590832c9bcb1c69d5ccdecdf731f97ae (patch)
treef742792fc5c973819dac194426231f05e25e4ecd /arch/x86
parent950c5968672a22a65790534234d1106bd1303652 (diff)
downloadu-boot-9d86b89c590832c9bcb1c69d5ccdecdf731f97ae.tar.gz
u-boot-9d86b89c590832c9bcb1c69d5ccdecdf731f97ae.tar.xz
u-boot-9d86b89c590832c9bcb1c69d5ccdecdf731f97ae.zip
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/x86')
-rw-r--r--arch/x86/include/asm/dma-mapping.h26
1 files changed, 0 insertions, 26 deletions
diff --git a/arch/x86/include/asm/dma-mapping.h b/arch/x86/include/asm/dma-mapping.h
index 37704da5dd..8be1003e6b 100644
--- a/arch/x86/include/asm/dma-mapping.h
+++ b/arch/x86/include/asm/dma-mapping.h
@@ -14,8 +14,6 @@
#include <linux/types.h>
#include <malloc.h>
-#define dma_mapping_error(x, y) 0
-
static inline void *dma_alloc_coherent(size_t len, unsigned long *handle)
{
*handle = (unsigned long)memalign(ARCH_DMA_MINALIGN, len);
@@ -27,28 +25,4 @@ static inline void dma_free_coherent(void *addr)
free(addr);
}
-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_X86_DMA_MAPPING_H */