From: Al Viro Date: Tue, 13 Dec 2011 17:25:27 +0000 (-0500) Subject: fuse: register_filesystem() called too early X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=988f032567eaba3c5896c5de05270b9ff71b2a9d;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git fuse: register_filesystem() called too early same story as with ubifs Signed-off-by: Al Viro --- diff --git a/fs/fuse/inode.c b/fs/fuse/inode.c index 3e6d72756479..aa83109b9431 100644 --- a/fs/fuse/inode.c +++ b/fs/fuse/inode.c @@ -1138,28 +1138,28 @@ static int __init fuse_fs_init(void) { int err; - err = register_filesystem(&fuse_fs_type); - if (err) - goto out; - - err = register_fuseblk(); - if (err) - goto out_unreg; - fuse_inode_cachep = kmem_cache_create("fuse_inode", sizeof(struct fuse_inode), 0, SLAB_HWCACHE_ALIGN, fuse_inode_init_once); err = -ENOMEM; if (!fuse_inode_cachep) - goto out_unreg2; + goto out; + + err = register_fuseblk(); + if (err) + goto out2; + + err = register_filesystem(&fuse_fs_type); + if (err) + goto out3; return 0; - out_unreg2: + out3: unregister_fuseblk(); - out_unreg: - unregister_filesystem(&fuse_fs_type); + out2: + kmem_cache_destroy(fuse_inode_cachep); out: return err; }