aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/mm/dma-mapping.c78
1 files changed, 38 insertions, 40 deletions
diff --git a/arch/arm/mm/dma-mapping.c b/arch/arm/mm/dma-mapping.c
index 6b24e5ed85c2..19357f76ce89 100644
--- a/arch/arm/mm/dma-mapping.c
+++ b/arch/arm/mm/dma-mapping.c
@@ -144,6 +144,44 @@ static struct arm_vmregion_head consistent_head = {
144#error ARM Coherent DMA allocator does not (yet) support huge TLB 144#error ARM Coherent DMA allocator does not (yet) support huge TLB
145#endif 145#endif
146 146
147/*
148 * Initialise the consistent memory allocation.
149 */
150static int __init consistent_init(void)
151{
152 int ret = 0;
153 pgd_t *pgd;
154 pmd_t *pmd;
155 pte_t *pte;
156 int i = 0;
157 u32 base = CONSISTENT_BASE;
158
159 do {
160 pgd = pgd_offset(&init_mm, base);
161 pmd = pmd_alloc(&init_mm, pgd, base);
162 if (!pmd) {
163 printk(KERN_ERR "%s: no pmd tables\n", __func__);
164 ret = -ENOMEM;
165 break;
166 }
167 WARN_ON(!pmd_none(*pmd));
168
169 pte = pte_alloc_kernel(pmd, base);
170 if (!pte) {
171 printk(KERN_ERR "%s: no pte tables\n", __func__);
172 ret = -ENOMEM;
173 break;
174 }
175
176 consistent_pte[i++] = pte;
177 base += (1 << PGDIR_SHIFT);
178 } while (base < CONSISTENT_END);
179
180 return ret;
181}
182
183core_initcall(consistent_init);
184
147static void * 185static void *
148__dma_alloc(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp, 186__dma_alloc(struct device *dev, size_t size, dma_addr_t *handle, gfp_t gfp,
149 pgprot_t prot) 187 pgprot_t prot)
@@ -400,46 +438,6 @@ void dma_free_coherent(struct device *dev, size_t size, void *cpu_addr, dma_addr
400EXPORT_SYMBOL(dma_free_coherent); 438EXPORT_SYMBOL(dma_free_coherent);
401 439
402/* 440/*
403 * Initialise the consistent memory allocation.
404 */
405static int __init consistent_init(void)
406{
407 int ret = 0;
408#ifdef CONFIG_MMU
409 pgd_t *pgd;
410 pmd_t *pmd;
411 pte_t *pte;
412 int i = 0;
413 u32 base = CONSISTENT_BASE;
414
415 do {
416 pgd = pgd_offset(&init_mm, base);
417 pmd = pmd_alloc(&init_mm, pgd, base);
418 if (!pmd) {
419 printk(KERN_ERR "%s: no pmd tables\n", __func__);
420 ret = -ENOMEM;
421 break;
422 }
423 WARN_ON(!pmd_none(*pmd));
424
425 pte = pte_alloc_kernel(pmd, base);
426 if (!pte) {
427 printk(KERN_ERR "%s: no pte tables\n", __func__);
428 ret = -ENOMEM;
429 break;
430 }
431
432 consistent_pte[i++] = pte;
433 base += (1 << PGDIR_SHIFT);
434 } while (base < CONSISTENT_END);
435#endif /* !CONFIG_MMU */
436
437 return ret;
438}
439
440core_initcall(consistent_init);
441
442/*
443 * Make an area consistent for devices. 441 * Make an area consistent for devices.
444 * Note: Drivers should NOT use this function directly, as it will break 442 * Note: Drivers should NOT use this function directly, as it will break
445 * platforms with CONFIG_DMABOUNCE. 443 * platforms with CONFIG_DMABOUNCE.