slub: Fix slub_lock down/up imbalance
There are two places, that do not release the slub_lock. Respective bugs were introduced by sysfs changesab4d5ed5
(slub: Enable sysfs support for !CONFIG_SLUB_DEBUG) and2bce6485
( slub: Allow removal of slab caches during boot). Acked-by: Christoph Lameter <cl@linux.com> Signed-off-by: Pavel Emelyanov <xemul@openvz.org> Signed-off-by: Pekka Enberg <penberg@kernel.org>
This commit is contained in:
parent
716ce5d4a6
commit
98072e4d97
|
@ -3289,9 +3289,9 @@ struct kmem_cache *kmem_cache_create(const char *name, size_t size,
|
|||
kfree(n);
|
||||
kfree(s);
|
||||
}
|
||||
err:
|
||||
up_write(&slub_lock);
|
||||
|
||||
err:
|
||||
if (flags & SLAB_PANIC)
|
||||
panic("Cannot create slabcache %s\n", name);
|
||||
else
|
||||
|
@ -3878,6 +3878,7 @@ static ssize_t show_slab_objects(struct kmem_cache *s,
|
|||
x += sprintf(buf + x, " N%d=%lu",
|
||||
node, nodes[node]);
|
||||
#endif
|
||||
up_read(&slub_lock);
|
||||
kfree(nodes);
|
||||
return x + sprintf(buf + x, "\n");
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue