diff options
| -rw-r--r-- | arch/arm/Kconfig | 1 | ||||
| -rw-r--r-- | arch/arm/mm/consistent.c | 8 | ||||
| -rw-r--r-- | include/asm-arm/dma-mapping.h | 2 |
3 files changed, 11 insertions, 0 deletions
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index c7ad324ddf2c..ea8b9be02b60 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig | |||
| @@ -16,6 +16,7 @@ config ARM | |||
| 16 | select HAVE_KRETPROBES if (HAVE_KPROBES) | 16 | select HAVE_KRETPROBES if (HAVE_KPROBES) |
| 17 | select HAVE_FTRACE if (!XIP_KERNEL) | 17 | select HAVE_FTRACE if (!XIP_KERNEL) |
| 18 | select HAVE_DYNAMIC_FTRACE if (HAVE_FTRACE) | 18 | select HAVE_DYNAMIC_FTRACE if (HAVE_FTRACE) |
| 19 | select HAVE_GENERIC_DMA_COHERENT | ||
| 19 | help | 20 | help |
| 20 | The ARM series is a line of low-power-consumption RISC chip designs | 21 | The ARM series is a line of low-power-consumption RISC chip designs |
| 21 | licensed by ARM Ltd and targeted at embedded applications and | 22 | licensed by ARM Ltd and targeted at embedded applications and |
diff --git a/arch/arm/mm/consistent.c b/arch/arm/mm/consistent.c index 333a82a3717e..db7b3e38ef1d 100644 --- a/arch/arm/mm/consistent.c +++ b/arch/arm/mm/consistent.c | |||
| @@ -274,6 +274,11 @@ __dma_alloc(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp, | |||
| 274 | void * | 274 | void * |
| 275 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp) | 275 | dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp) |
| 276 | { | 276 | { |
| 277 | void *memory; | ||
| 278 | |||
| 279 | if (dma_alloc_from_coherent(dev, size, handle, &memory)) | ||
| 280 | return memory; | ||
| 281 | |||
| 277 | if (arch_is_coherent()) { | 282 | if (arch_is_coherent()) { |
| 278 | void *virt; | 283 | void *virt; |
| 279 | 284 | ||
| @@ -362,6 +367,9 @@ void dma_free_coherent(struct device *dev, size_t size, void *cpu_addr, dma_addr | |||
| 362 | 367 | ||
| 363 | WARN_ON(irqs_disabled()); | 368 | WARN_ON(irqs_disabled()); |
| 364 | 369 | ||
| 370 | if (dma_release_from_coherent(dev, get_order(size), cpu_addr)) | ||
| 371 | return; | ||
| 372 | |||
| 365 | if (arch_is_coherent()) { | 373 | if (arch_is_coherent()) { |
| 366 | kfree(cpu_addr); | 374 | kfree(cpu_addr); |
| 367 | return; | 375 | return; |
diff --git a/include/asm-arm/dma-mapping.h b/include/asm-arm/dma-mapping.h index e99406a7bece..943f23bc99a2 100644 --- a/include/asm-arm/dma-mapping.h +++ b/include/asm-arm/dma-mapping.h | |||
| @@ -7,6 +7,8 @@ | |||
| 7 | 7 | ||
| 8 | #include <linux/scatterlist.h> | 8 | #include <linux/scatterlist.h> |
| 9 | 9 | ||
| 10 | #include <asm-generic/dma-coherent.h> | ||
| 11 | |||
| 10 | /* | 12 | /* |
| 11 | * DMA-consistent mapping functions. These allocate/free a region of | 13 | * DMA-consistent mapping functions. These allocate/free a region of |
| 12 | * uncached, unwrite-buffered mapped memory space for use with DMA | 14 | * uncached, unwrite-buffered mapped memory space for use with DMA |
