Skip to content

Commit faef877

Browse files
Christoph Hellwigpaulburton
authored andcommitted
dma-noncoherent: add a arch_sync_dma_for_cpu_all hook
The MIPS bmips platform needs a global flush when transferring ownership back to the CPU. Add a hook for that to the dma-noncoherent implementation. Signed-off-by: Christoph Hellwig <hch@lst.de> Patchwork: https://patchwork.linux-mips.org/patch/19549/ Signed-off-by: Paul Burton <paul.burton@mips.com> Cc: Florian Fainelli <f.fainelli@gmail.com> Cc: David Daney <david.daney@cavium.com> Cc: Kevin Cernekee <cernekee@gmail.com> Cc: Jiaxun Yang <jiaxun.yang@flygoat.com> Cc: Tom Bogendoerfer <tsbogend@alpha.franken.de> Cc: Huacai Chen <chenhc@lemote.com> Cc: iommu@lists.linux-foundation.org Cc: linux-mips@linux-mips.org
1 parent c5e2bbb commit faef877

File tree

2 files changed

+14
-2
lines changed

2 files changed

+14
-2
lines changed

include/linux/dma-noncoherent.h

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -44,4 +44,12 @@ static inline void arch_sync_dma_for_cpu(struct device *dev,
4444
}
4545
#endif /* ARCH_HAS_SYNC_DMA_FOR_CPU */
4646

47+
#ifdef CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU_ALL
48+
void arch_sync_dma_for_cpu_all(struct device *dev);
49+
#else
50+
static inline void arch_sync_dma_for_cpu_all(struct device *dev)
51+
{
52+
}
53+
#endif /* CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU_ALL */
54+
4755
#endif /* _LINUX_DMA_NONCOHERENT_H */

kernel/dma/noncoherent.c

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -49,11 +49,13 @@ static int dma_noncoherent_map_sg(struct device *dev, struct scatterlist *sgl,
4949
return nents;
5050
}
5151

52-
#ifdef CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU
52+
#if defined(CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU) || \
53+
defined(CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU_ALL)
5354
static void dma_noncoherent_sync_single_for_cpu(struct device *dev,
5455
dma_addr_t addr, size_t size, enum dma_data_direction dir)
5556
{
5657
arch_sync_dma_for_cpu(dev, dma_to_phys(dev, addr), size, dir);
58+
arch_sync_dma_for_cpu_all(dev);
5759
}
5860

5961
static void dma_noncoherent_sync_sg_for_cpu(struct device *dev,
@@ -64,6 +66,7 @@ static void dma_noncoherent_sync_sg_for_cpu(struct device *dev,
6466

6567
for_each_sg(sgl, sg, nents, i)
6668
arch_sync_dma_for_cpu(dev, sg_phys(sg), sg->length, dir);
69+
arch_sync_dma_for_cpu_all(dev);
6770
}
6871

6972
static void dma_noncoherent_unmap_page(struct device *dev, dma_addr_t addr,
@@ -89,7 +92,8 @@ const struct dma_map_ops dma_noncoherent_ops = {
8992
.sync_sg_for_device = dma_noncoherent_sync_sg_for_device,
9093
.map_page = dma_noncoherent_map_page,
9194
.map_sg = dma_noncoherent_map_sg,
92-
#ifdef CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU
95+
#if defined(CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU) || \
96+
defined(CONFIG_ARCH_HAS_SYNC_DMA_FOR_CPU_ALL)
9397
.sync_single_for_cpu = dma_noncoherent_sync_single_for_cpu,
9498
.sync_sg_for_cpu = dma_noncoherent_sync_sg_for_cpu,
9599
.unmap_page = dma_noncoherent_unmap_page,

0 commit comments

Comments
 (0)