diff options
-rw-r--r-- | arch/arm/mm/dma-mapping.c | 31 |
1 files changed, 12 insertions, 19 deletions
diff --git a/arch/arm/mm/dma-mapping.c b/arch/arm/mm/dma-mapping.c index 19357f76ce89..3a8e527c774c 100644 --- a/arch/arm/mm/dma-mapping.c +++ b/arch/arm/mm/dma-mapping.c | |||
@@ -189,18 +189,24 @@ __dma_alloc(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp, | |||
189 | struct page *page; | 189 | struct page *page; |
190 | struct arm_vmregion *c; | 190 | struct arm_vmregion *c; |
191 | 191 | ||
192 | if (!consistent_pte[0]) { | ||
193 | printk(KERN_ERR "%s: not initialised\n", __func__); | ||
194 | dump_stack(); | ||
195 | return NULL; | ||
196 | } | ||
197 | |||
198 | size = PAGE_ALIGN(size); | 192 | size = PAGE_ALIGN(size); |
199 | 193 | ||
200 | page = __dma_alloc_buffer(dev, size, gfp); | 194 | page = __dma_alloc_buffer(dev, size, gfp); |
201 | if (!page) | 195 | if (!page) |
202 | goto no_page; | 196 | goto no_page; |
203 | 197 | ||
198 | if (arch_is_coherent()) { | ||
199 | *handle = page_to_dma(dev, page); | ||
200 | return page_address(page); | ||
201 | } | ||
202 | |||
203 | if (!consistent_pte[0]) { | ||
204 | printk(KERN_ERR "%s: not initialised\n", __func__); | ||
205 | dump_stack(); | ||
206 | __dma_free_buffer(page, size); | ||
207 | return NULL; | ||
208 | } | ||
209 | |||
204 | /* | 210 | /* |
205 | * Allocate a virtual address in the consistent mapping region. | 211 | * Allocate a virtual address in the consistent mapping region. |
206 | */ | 212 | */ |
@@ -342,19 +348,6 @@ dma_alloc_coherent(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gf | |||
342 | if (dma_alloc_from_coherent(dev, size, handle, &memory)) | 348 | if (dma_alloc_from_coherent(dev, size, handle, &memory)) |
343 | return memory; | 349 | return memory; |
344 | 350 | ||
345 | if (arch_is_coherent()) { | ||
346 | struct page *page; | ||
347 | |||
348 | page = __dma_alloc_buffer(dev, PAGE_ALIGN(size), gfp); | ||
349 | if (!page) { | ||
350 | *handle = ~0; | ||
351 | return NULL; | ||
352 | } | ||
353 | |||
354 | *handle = page_to_dma(dev, page); | ||
355 | return page_address(page); | ||
356 | } | ||
357 | |||
358 | return __dma_alloc(dev, size, handle, gfp, | 351 | return __dma_alloc(dev, size, handle, gfp, |
359 | pgprot_noncached(pgprot_kernel)); | 352 | pgprot_noncached(pgprot_kernel)); |
360 | } | 353 | } |