aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/base/dma-mapping.c
diff options
context:
space:
mode:
authorVladimir Murzin <vladimir.murzin@arm.com>2017-06-28 05:16:57 -0400
committerChristoph Hellwig <hch@lst.de>2017-06-30 13:03:07 -0400
commit07c75d7a6b9eae24ab72c6eb2fbd39963775b0bf (patch)
tree463fc188df21de87c3cef87b4eab54438805c86e /drivers/base/dma-mapping.c
parent93228b44c33a572cb36cec2dbed42e9bdbc88d79 (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.c4
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}