ARM: DMA-Mapping: print warning when atomic coherent allocation fails
authorMarek Szyprowski <m.szyprowski@samsung.com>
Wed, 22 Aug 2012 12:50:42 +0000 (14:50 +0200)
committerMarek Szyprowski <m.szyprowski@samsung.com>
Tue, 28 Aug 2012 19:01:03 +0000 (21:01 +0200)
Print a loud warning when system runs out of memory from atomic DMA
coherent pool to let users notice the potential problem.

Reported-by: Aaro Koskinen <aaro.koskinen@iki.fi>
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
arch/arm/mm/dma-mapping.c

index d1cc9c1d3566fd10680ed2fe16d6e4ab84fc152d..acced93321094eb326012010482a53be820b8adc 100644 (file)
@@ -461,6 +461,10 @@ static void *__alloc_from_pool(size_t size, struct page **ret_page)
                bitmap_set(pool->bitmap, pageno, count);
                ptr = pool->vaddr + PAGE_SIZE * pageno;
                *ret_page = pool->page + pageno;
+       } else {
+               pr_err_once("ERROR: %u KiB atomic DMA coherent pool is too small!\n"
+                           "Please increase it with coherent_pool= kernel parameter!\n",
+                           (unsigned)pool->size / 1024);
        }
        spin_unlock_irqrestore(&pool->lock, flags);