projects
/
openwrt
/
staging
/
blogic.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
34f8be7
)
arch/hexagon: Add option to skip DMA sync as a part of mapping
author
Alexander Duyck
<
[email protected]
>
Wed, 14 Dec 2016 23:04:46 +0000
(15:04 -0800)
committer
Linus Torvalds
<
[email protected]
>
Thu, 15 Dec 2016 00:04:07 +0000
(16:04 -0800)
This change allows us to pass DMA_ATTR_SKIP_CPU_SYNC which allows us to
avoid invoking cache line invalidation if the driver will just handle it
later via a sync_for_cpu or sync_for_device call.
Link:
http://lkml.kernel.org/r/
[email protected]
Signed-off-by: Alexander Duyck <
[email protected]
>
Cc: Richard Kuo <
[email protected]
>
Signed-off-by: Andrew Morton <
[email protected]
>
Signed-off-by: Linus Torvalds <
[email protected]
>
arch/hexagon/kernel/dma.c
patch
|
blob
|
history
diff --git
a/arch/hexagon/kernel/dma.c
b/arch/hexagon/kernel/dma.c
index b9017785fb71a31ff660849d3ef0bf7178e91c2a..dbc4f1003da46e522b081b738ff2dded4e50aaf6 100644
(file)
--- a/
arch/hexagon/kernel/dma.c
+++ b/
arch/hexagon/kernel/dma.c
@@
-119,6
+119,9
@@
static int hexagon_map_sg(struct device *hwdev, struct scatterlist *sg,
s->dma_length = s->length;
+ if (attrs & DMA_ATTR_SKIP_CPU_SYNC)
+ continue;
+
flush_dcache_range(dma_addr_to_virt(s->dma_address),
dma_addr_to_virt(s->dma_address + s->length));
}
@@
-180,7
+183,8
@@
static dma_addr_t hexagon_map_page(struct device *dev, struct page *page,
if (!check_addr("map_single", dev, bus, size))
return bad_dma_address;
- dma_sync(dma_addr_to_virt(bus), size, dir);
+ if (!(attrs & DMA_ATTR_SKIP_CPU_SYNC))
+ dma_sync(dma_addr_to_virt(bus), size, dir);
return bus;
}