diff options
author | Vladimir Murzin <vladimir.murzin@arm.com> | 2017-06-28 05:16:57 -0400 |
---|---|---|
committer | Christoph Hellwig <hch@lst.de> | 2017-06-30 13:03:07 -0400 |
commit | 07c75d7a6b9eae24ab72c6eb2fbd39963775b0bf (patch) | |
tree | 463fc188df21de87c3cef87b4eab54438805c86e /drivers/base/dma-mapping.c | |
parent | 93228b44c33a572cb36cec2dbed42e9bdbc88d79 (diff) |
drivers: dma-mapping: allow dma_common_mmap() for NOMMU
Currently, internals of dma_common_mmap() is compiled out if build is
done for either NOMMU or target which explicitly says it does not
have/want coherent DMA mmap. It turned out that dma_common_mmap() can
be handy in NOMMU setup (at least for ARM).
This patch converts exitent NOMMU targets to use ARCH_NO_COHERENT_DMA_MMAP,
thus when CONFIG_MMU is gone from dma_common_mmap() their behaviour stays
unchanged.
ARM is not converted to ARCH_NO_COHERENT_DMA_MMAP because it 1)
already has mmap callback which can handle (at some extent) NOMMU 2)
already defines dummy pgprot_noncached() for NOMMU build.
c6x and frv stay untouched since they already have ARCH_NO_COHERENT_DMA_MMAP.
Cc: Steven Miao <realmz6@gmail.com>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Michal Simek <monstr@monstr.eu>
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Cc: Rich Felker <dalias@libc.org>
Cc: Chris Zankel <chris@zankel.net>
Cc: Max Filippov <jcmvbkbc@gmail.com>
Suggested-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Vladimir Murzin <vladimir.murzin@arm.com>
Tested-by: Benjamin Gaignard <benjamin.gaignard@linaro.org>
Diffstat (limited to 'drivers/base/dma-mapping.c')
-rw-r--r-- | drivers/base/dma-mapping.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/base/dma-mapping.c b/drivers/base/dma-mapping.c index 10e7c022e8cf..ce1e02b567c3 100644 --- a/drivers/base/dma-mapping.c +++ b/drivers/base/dma-mapping.c | |||
@@ -227,7 +227,7 @@ int dma_common_mmap(struct device *dev, struct vm_area_struct *vma, | |||
227 | void *cpu_addr, dma_addr_t dma_addr, size_t size) | 227 | void *cpu_addr, dma_addr_t dma_addr, size_t size) |
228 | { | 228 | { |
229 | int ret = -ENXIO; | 229 | int ret = -ENXIO; |
230 | #if defined(CONFIG_MMU) && !defined(CONFIG_ARCH_NO_COHERENT_DMA_MMAP) | 230 | #ifndef CONFIG_ARCH_NO_COHERENT_DMA_MMAP |
231 | unsigned long user_count = vma_pages(vma); | 231 | unsigned long user_count = vma_pages(vma); |
232 | unsigned long count = PAGE_ALIGN(size) >> PAGE_SHIFT; | 232 | unsigned long count = PAGE_ALIGN(size) >> PAGE_SHIFT; |
233 | unsigned long pfn = page_to_pfn(virt_to_page(cpu_addr)); | 233 | unsigned long pfn = page_to_pfn(virt_to_page(cpu_addr)); |
@@ -244,7 +244,7 @@ int dma_common_mmap(struct device *dev, struct vm_area_struct *vma, | |||
244 | user_count << PAGE_SHIFT, | 244 | user_count << PAGE_SHIFT, |
245 | vma->vm_page_prot); | 245 | vma->vm_page_prot); |
246 | } | 246 | } |
247 | #endif /* CONFIG_MMU && !CONFIG_ARCH_NO_COHERENT_DMA_MMAP */ | 247 | #endif /* !CONFIG_ARCH_NO_COHERENT_DMA_MMAP */ |
248 | 248 | ||
249 | return ret; | 249 | return ret; |
250 | } | 250 | } |