|
@@ -3937,13 +3937,14 @@ struct kmem_cache *kmem_cache_create(const char *name, size_t size,
|
|
|
if (kmem_cache_open(s, n,
|
|
|
size, align, flags, ctor)) {
|
|
|
list_add(&s->list, &slab_caches);
|
|
|
+ up_write(&slub_lock);
|
|
|
if (sysfs_slab_add(s)) {
|
|
|
+ down_write(&slub_lock);
|
|
|
list_del(&s->list);
|
|
|
kfree(n);
|
|
|
kfree(s);
|
|
|
goto err;
|
|
|
}
|
|
|
- up_write(&slub_lock);
|
|
|
return s;
|
|
|
}
|
|
|
kfree(n);
|