mirror of
https://github.com/torvalds/linux.git
synced 2024-11-22 12:11:40 +00:00
[PATCH] freevxfs: fix leak on error path
If register_filesystem() fails, vxfs_inode cache must be destroyed. Signed-off-by: Alexey Dobriyan <adobriyan@gmail.com> Acked-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
parent
50d44ed009
commit
a4376e13ce
@ -260,12 +260,17 @@ static struct file_system_type vxfs_fs_type = {
|
||||
static int __init
|
||||
vxfs_init(void)
|
||||
{
|
||||
int rv;
|
||||
|
||||
vxfs_inode_cachep = kmem_cache_create("vxfs_inode",
|
||||
sizeof(struct vxfs_inode_info), 0,
|
||||
SLAB_RECLAIM_ACCOUNT|SLAB_MEM_SPREAD, NULL, NULL);
|
||||
if (vxfs_inode_cachep)
|
||||
return register_filesystem(&vxfs_fs_type);
|
||||
return -ENOMEM;
|
||||
if (!vxfs_inode_cachep)
|
||||
return -ENOMEM;
|
||||
rv = register_filesystem(&vxfs_fs_type);
|
||||
if (rv < 0)
|
||||
kmem_cache_destroy(vxfs_inode_cachep);
|
||||
return rv;
|
||||
}
|
||||
|
||||
static void __exit
|
||||
|
Loading…
Reference in New Issue
Block a user