diff options
author | Thierry Reding <treding@nvidia.com> | 2014-06-27 05:56:58 -0400 |
---|---|---|
committer | Marek Szyprowski <m.szyprowski@samsung.com> | 2014-08-26 01:39:13 -0400 |
commit | b4bbb107d73bbc0d92c9ae7fd8e69580aa9381e7 (patch) | |
tree | c631cccdc40abe3d44fc980a739fb20ec4354d3f | |
parent | 90114d65feea716eeae0ab51e92c95b140b2e6fc (diff) |
dma-mapping: Provide write-combine allocations
Provide an implementation for dma_{alloc,free,mmap}_writecombine() when
the architecture supports DMA attributes.
Signed-off-by: Thierry Reding <treding@nvidia.com>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
-rw-r--r-- | arch/arm/include/asm/dma-mapping.h | 16 | ||||
-rw-r--r-- | include/asm-generic/dma-mapping-common.h | 8 | ||||
-rw-r--r-- | include/linux/dma-mapping.h | 26 |
3 files changed, 26 insertions, 24 deletions
diff --git a/arch/arm/include/asm/dma-mapping.h b/arch/arm/include/asm/dma-mapping.h index c45b61a4b4a5..85738b200023 100644 --- a/arch/arm/include/asm/dma-mapping.h +++ b/arch/arm/include/asm/dma-mapping.h | |||
@@ -265,22 +265,6 @@ extern int arm_dma_mmap(struct device *dev, struct vm_area_struct *vma, | |||
265 | void *cpu_addr, dma_addr_t dma_addr, size_t size, | 265 | void *cpu_addr, dma_addr_t dma_addr, size_t size, |
266 | struct dma_attrs *attrs); | 266 | struct dma_attrs *attrs); |
267 | 267 | ||
268 | static inline void *dma_alloc_writecombine(struct device *dev, size_t size, | ||
269 | dma_addr_t *dma_handle, gfp_t flag) | ||
270 | { | ||
271 | DEFINE_DMA_ATTRS(attrs); | ||
272 | dma_set_attr(DMA_ATTR_WRITE_COMBINE, &attrs); | ||
273 | return dma_alloc_attrs(dev, size, dma_handle, flag, &attrs); | ||
274 | } | ||
275 | |||
276 | static inline void dma_free_writecombine(struct device *dev, size_t size, | ||
277 | void *cpu_addr, dma_addr_t dma_handle) | ||
278 | { | ||
279 | DEFINE_DMA_ATTRS(attrs); | ||
280 | dma_set_attr(DMA_ATTR_WRITE_COMBINE, &attrs); | ||
281 | return dma_free_attrs(dev, size, cpu_addr, dma_handle, &attrs); | ||
282 | } | ||
283 | |||
284 | /* | 268 | /* |
285 | * This can be called during early boot to increase the size of the atomic | 269 | * This can be called during early boot to increase the size of the atomic |
286 | * coherent DMA pool above the default value of 256KiB. It must be called | 270 | * coherent DMA pool above the default value of 256KiB. It must be called |
diff --git a/include/asm-generic/dma-mapping-common.h b/include/asm-generic/dma-mapping-common.h index de8bf89940f8..d137431bf26f 100644 --- a/include/asm-generic/dma-mapping-common.h +++ b/include/asm-generic/dma-mapping-common.h | |||
@@ -205,14 +205,6 @@ dma_mmap_attrs(struct device *dev, struct vm_area_struct *vma, void *cpu_addr, | |||
205 | 205 | ||
206 | #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) | 206 | #define dma_mmap_coherent(d, v, c, h, s) dma_mmap_attrs(d, v, c, h, s, NULL) |
207 | 207 | ||
208 | static inline int dma_mmap_writecombine(struct device *dev, struct vm_area_struct *vma, | ||
209 | void *cpu_addr, dma_addr_t dma_addr, size_t size) | ||
210 | { | ||
211 | DEFINE_DMA_ATTRS(attrs); | ||
212 | dma_set_attr(DMA_ATTR_WRITE_COMBINE, &attrs); | ||
213 | return dma_mmap_attrs(dev, vma, cpu_addr, dma_addr, size, &attrs); | ||
214 | } | ||
215 | |||
216 | int | 208 | int |
217 | dma_common_get_sgtable(struct device *dev, struct sg_table *sgt, | 209 | dma_common_get_sgtable(struct device *dev, struct sg_table *sgt, |
218 | void *cpu_addr, dma_addr_t dma_addr, size_t size); | 210 | void *cpu_addr, dma_addr_t dma_addr, size_t size); |
diff --git a/include/linux/dma-mapping.h b/include/linux/dma-mapping.h index 931b70986272..d5d388160f42 100644 --- a/include/linux/dma-mapping.h +++ b/include/linux/dma-mapping.h | |||
@@ -263,6 +263,32 @@ struct dma_attrs; | |||
263 | #define dma_unmap_sg_attrs(dev, sgl, nents, dir, attrs) \ | 263 | #define dma_unmap_sg_attrs(dev, sgl, nents, dir, attrs) \ |
264 | dma_unmap_sg(dev, sgl, nents, dir) | 264 | dma_unmap_sg(dev, sgl, nents, dir) |
265 | 265 | ||
266 | #else | ||
267 | static inline void *dma_alloc_writecombine(struct device *dev, size_t size, | ||
268 | dma_addr_t *dma_addr, gfp_t gfp) | ||
269 | { | ||
270 | DEFINE_DMA_ATTRS(attrs); | ||
271 | dma_set_attr(DMA_ATTR_WRITE_COMBINE, &attrs); | ||
272 | return dma_alloc_attrs(dev, size, dma_addr, gfp, &attrs); | ||
273 | } | ||
274 | |||
275 | static inline void dma_free_writecombine(struct device *dev, size_t size, | ||
276 | void *cpu_addr, dma_addr_t dma_addr) | ||
277 | { | ||
278 | DEFINE_DMA_ATTRS(attrs); | ||
279 | dma_set_attr(DMA_ATTR_WRITE_COMBINE, &attrs); | ||
280 | return dma_free_attrs(dev, size, cpu_addr, dma_addr, &attrs); | ||
281 | } | ||
282 | |||
283 | static inline int dma_mmap_writecombine(struct device *dev, | ||
284 | struct vm_area_struct *vma, | ||
285 | void *cpu_addr, dma_addr_t dma_addr, | ||
286 | size_t size) | ||
287 | { | ||
288 | DEFINE_DMA_ATTRS(attrs); | ||
289 | dma_set_attr(DMA_ATTR_WRITE_COMBINE, &attrs); | ||
290 | return dma_mmap_attrs(dev, vma, cpu_addr, dma_addr, size, &attrs); | ||
291 | } | ||
266 | #endif /* CONFIG_HAVE_DMA_ATTRS */ | 292 | #endif /* CONFIG_HAVE_DMA_ATTRS */ |
267 | 293 | ||
268 | #ifdef CONFIG_NEED_DMA_MAP_STATE | 294 | #ifdef CONFIG_NEED_DMA_MAP_STATE |