1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Copyright (C) 2009-2010 PetaLogix
4 * Copyright (C) 2006 Benjamin Herrenschmidt, IBM Corporation
5 *
6 * Provide default implementations of the DMA mapping callbacks for
7 * directly mapped busses.
8 */
9
10 #include <linux/device.h>
11 #include <linux/dma-map-ops.h>
12 #include <linux/gfp.h>
13 #include <linux/export.h>
14 #include <linux/bug.h>
15 #include <asm/cacheflush.h>
16
__dma_sync(phys_addr_t paddr,size_t size,enum dma_data_direction direction)17 static void __dma_sync(phys_addr_t paddr, size_t size,
18 enum dma_data_direction direction)
19 {
20 switch (direction) {
21 case DMA_TO_DEVICE:
22 case DMA_BIDIRECTIONAL:
23 flush_dcache_range(paddr, paddr + size);
24 break;
25 case DMA_FROM_DEVICE:
26 invalidate_dcache_range(paddr, paddr + size);
27 break;
28 default:
29 BUG();
30 }
31 }
32
arch_sync_dma_for_device(phys_addr_t paddr,size_t size,enum dma_data_direction dir)33 void arch_sync_dma_for_device(phys_addr_t paddr, size_t size,
34 enum dma_data_direction dir)
35 {
36 __dma_sync(paddr, size, dir);
37 }
38
arch_sync_dma_for_cpu(phys_addr_t paddr,size_t size,enum dma_data_direction dir)39 void arch_sync_dma_for_cpu(phys_addr_t paddr, size_t size,
40 enum dma_data_direction dir)
41 {
42 __dma_sync(paddr, size, dir);
43 }
44