Commit 71cdec4f authored by David Rientjes's avatar David Rientjes Committed by Christoph Hellwig

dma-mapping: warn when coherent pool is depleted

When a DMA coherent pool is depleted, allocation failures may or may not
get reported in the kernel log depending on the allocator.

The admin does have a workaround, however, by using coherent_pool= on the
kernel command line.

Provide some guidance on the failure and a recommended minimum size for
the pools (double the size).
Signed-off-by: default avatarDavid Rientjes <rientjes@google.com>
Tested-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
parent 9ebcfadb
...@@ -239,12 +239,16 @@ void *dma_alloc_from_pool(struct device *dev, size_t size, ...@@ -239,12 +239,16 @@ void *dma_alloc_from_pool(struct device *dev, size_t size,
} }
val = gen_pool_alloc(pool, size); val = gen_pool_alloc(pool, size);
if (val) { if (likely(val)) {
phys_addr_t phys = gen_pool_virt_to_phys(pool, val); phys_addr_t phys = gen_pool_virt_to_phys(pool, val);
*ret_page = pfn_to_page(__phys_to_pfn(phys)); *ret_page = pfn_to_page(__phys_to_pfn(phys));
ptr = (void *)val; ptr = (void *)val;
memset(ptr, 0, size); memset(ptr, 0, size);
} else {
WARN_ONCE(1, "DMA coherent pool depleted, increase size "
"(recommended min coherent_pool=%zuK)\n",
gen_pool_size(pool) >> 9);
} }
if (gen_pool_avail(pool) < atomic_pool_size) if (gen_pool_avail(pool) < atomic_pool_size)
schedule_work(&atomic_pool_work); schedule_work(&atomic_pool_work);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment