forked from luck/tmp_suning_uos_patched
fuse: fix missing fput on error
Fix the leaking file reference if allocation or initialization of fuse_conn failed. Signed-off-by: Miklos Szeredi <mszeredi@suse.cz> CC: stable@kernel.org
This commit is contained in:
parent
bb875b38dc
commit
3ddf1e7f57
|
@ -829,15 +829,20 @@ static int fuse_fill_super(struct super_block *sb, void *data, int silent)
|
||||||
if (!file)
|
if (!file)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (file->f_op != &fuse_dev_operations)
|
if (file->f_op != &fuse_dev_operations) {
|
||||||
|
fput(file);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
fc = kmalloc(sizeof(*fc), GFP_KERNEL);
|
fc = kmalloc(sizeof(*fc), GFP_KERNEL);
|
||||||
if (!fc)
|
if (!fc) {
|
||||||
|
fput(file);
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
err = fuse_conn_init(fc, sb);
|
err = fuse_conn_init(fc, sb);
|
||||||
if (err) {
|
if (err) {
|
||||||
|
fput(file);
|
||||||
kfree(fc);
|
kfree(fc);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user