summaryrefslogtreecommitdiffstats
path: root/mm
diff options
context:
space:
mode:
authorKeith Busch <kbusch@kernel.org>2023-01-26 22:51:20 +0100
committerAndrew Morton <akpm@linux-foundation.org>2023-04-06 04:42:40 +0200
commit36d1a28921a4012288e17ef5ac98329ce440d410 (patch)
tree56eedfac5911d5db6dc4619f8c83104728923ca7 /mm
parentdmapool: move debug code to own functions (diff)
downloadlinux-36d1a28921a4012288e17ef5ac98329ce440d410.tar.xz
linux-36d1a28921a4012288e17ef5ac98329ce440d410.zip
dmapool: rearrange page alloc failure handling
Handle the error in a condition so the good path can be in the normal flow. Link: https://lkml.kernel.org/r/20230126215125.4069751-8-kbusch@meta.com Signed-off-by: Keith Busch <kbusch@kernel.org> Reviewed-by: Christoph Hellwig <hch@lst.de> Cc: Matthew Wilcox <willy@infradead.org> Cc: Tony Battersby <tonyb@cybernetics.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r--mm/dmapool.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/mm/dmapool.c b/mm/dmapool.c
index 30b069e99996..900f2afa363a 100644
--- a/mm/dmapool.c
+++ b/mm/dmapool.c
@@ -292,17 +292,19 @@ static struct dma_page *pool_alloc_page(struct dma_pool *pool, gfp_t mem_flags)
page = kmalloc(sizeof(*page), mem_flags);
if (!page)
return NULL;
+
page->vaddr = dma_alloc_coherent(pool->dev, pool->allocation,
&page->dma, mem_flags);
- if (page->vaddr) {
- pool_init_page(pool, page);
- pool_initialise_page(pool, page);
- page->in_use = 0;
- page->offset = 0;
- } else {
+ if (!page->vaddr) {
kfree(page);
- page = NULL;
+ return NULL;
}
+
+ pool_init_page(pool, page);
+ pool_initialise_page(pool, page);
+ page->in_use = 0;
+ page->offset = 0;
+
return page;
}