From: Vlastimil Babka Date: Wed, 3 Sep 2025 12:59:44 +0000 (+0200) Subject: slab: simplify init_kmem_cache_nodes() error handling X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=9d4e6ab865c48c70e684b176d3ee1574d092626f;p=thirdparty%2Fkernel%2Fstable.git slab: simplify init_kmem_cache_nodes() error handling We don't need to call free_kmem_cache_nodes() immediately when failing to allocate a kmem_cache_node, because when we return 0, do_kmem_cache_create() calls __kmem_cache_release() which also performs free_kmem_cache_nodes(). Reviewed-by: Harry Yoo Reviewed-by: Suren Baghdasaryan Signed-off-by: Vlastimil Babka --- diff --git a/mm/slub.c b/mm/slub.c index 30003763d224c..9f671ec76131c 100644 --- a/mm/slub.c +++ b/mm/slub.c @@ -5669,10 +5669,8 @@ static int init_kmem_cache_nodes(struct kmem_cache *s) n = kmem_cache_alloc_node(kmem_cache_node, GFP_KERNEL, node); - if (!n) { - free_kmem_cache_nodes(s); + if (!n) return 0; - } init_kmem_cache_node(n); s->node[node] = n;