summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorzhengbin <zhengbin13@huawei.com>2019-08-14 15:59:09 +0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-10-11 18:18:41 +0200
commit1c8c25209dd17a7c31e6efe4d8f603f1adccc310 (patch)
treef44558381f42766b2cfffeb177139322eccfa91e
parent414755a4bf32adef628cc1f5d569f05c968de138 (diff)
downloadlinux-stable-1c8c25209dd17a7c31e6efe4d8f603f1adccc310.tar.gz
linux-stable-1c8c25209dd17a7c31e6efe4d8f603f1adccc310.tar.bz2
linux-stable-1c8c25209dd17a7c31e6efe4d8f603f1adccc310.zip
fuse: fix memleak in cuse_channel_open
[ Upstream commit 9ad09b1976c562061636ff1e01bfc3a57aebe56b ] If cuse_send_init fails, need to fuse_conn_put cc->fc. cuse_channel_open->fuse_conn_init->refcount_set(&fc->count, 1) ->fuse_dev_alloc->fuse_conn_get ->fuse_dev_free->fuse_conn_put Fixes: cc080e9e9be1 ("fuse: introduce per-instance fuse_dev structure") Reported-by: Hulk Robot <hulkci@huawei.com> Signed-off-by: zhengbin <zhengbin13@huawei.com> Signed-off-by: Miklos Szeredi <mszeredi@redhat.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
-rw-r--r--fs/fuse/cuse.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/fs/fuse/cuse.c b/fs/fuse/cuse.c
index e9e97803442a..55db06c7c587 100644
--- a/fs/fuse/cuse.c
+++ b/fs/fuse/cuse.c
@@ -513,6 +513,7 @@ static int cuse_channel_open(struct inode *inode, struct file *file)
rc = cuse_send_init(cc);
if (rc) {
fuse_dev_free(fud);
+ fuse_conn_put(&cc->fc);
return rc;
}
file->private_data = fud;