NFSv4.2: fix reference count leaks in _nfs42_proc_copy_notify()
[ Upstream commit b7f114edd54326f730a754547e7cfb197b5bc132 ] [You don't often get email from xiongx18@fudan.edu.cn. Learn why this is important at http://aka.ms/LearnAboutSenderIdentification.] The reference counting issue happens in two error paths in the function _nfs42_proc_copy_notify(). In both error paths, the function simply returns the error code and forgets to balance the refcount of object `ctx`, bumped by get_nfs_open_context() earlier, which may cause refcount leaks. Fix it by balancing refcount of the `ctx` object before the function returns in both error paths. Signed-off-by: Xin Xiong <xiongx18@fudan.edu.cn> Signed-off-by: Xiyu Yang <xiyuyang19@fudan.edu.cn> Signed-off-by: Xin Tan <tanxin.ctf@gmail.com> Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
2e16895d06
commit
9b9feec97c
@@ -567,8 +567,10 @@ static int _nfs42_proc_copy_notify(struct file *src, struct file *dst,
|
|||||||
|
|
||||||
ctx = get_nfs_open_context(nfs_file_open_context(src));
|
ctx = get_nfs_open_context(nfs_file_open_context(src));
|
||||||
l_ctx = nfs_get_lock_context(ctx);
|
l_ctx = nfs_get_lock_context(ctx);
|
||||||
if (IS_ERR(l_ctx))
|
if (IS_ERR(l_ctx)) {
|
||||||
return PTR_ERR(l_ctx);
|
status = PTR_ERR(l_ctx);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
status = nfs4_set_rw_stateid(&args->cna_src_stateid, ctx, l_ctx,
|
status = nfs4_set_rw_stateid(&args->cna_src_stateid, ctx, l_ctx,
|
||||||
FMODE_READ);
|
FMODE_READ);
|
||||||
@@ -576,7 +578,7 @@ static int _nfs42_proc_copy_notify(struct file *src, struct file *dst,
|
|||||||
if (status) {
|
if (status) {
|
||||||
if (status == -EAGAIN)
|
if (status == -EAGAIN)
|
||||||
status = -NFS4ERR_BAD_STATEID;
|
status = -NFS4ERR_BAD_STATEID;
|
||||||
return status;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
status = nfs4_call_sync(src_server->client, src_server, &msg,
|
status = nfs4_call_sync(src_server->client, src_server, &msg,
|
||||||
@@ -584,6 +586,7 @@ static int _nfs42_proc_copy_notify(struct file *src, struct file *dst,
|
|||||||
if (status == -ENOTSUPP)
|
if (status == -ENOTSUPP)
|
||||||
src_server->caps &= ~NFS_CAP_COPY_NOTIFY;
|
src_server->caps &= ~NFS_CAP_COPY_NOTIFY;
|
||||||
|
|
||||||
|
out:
|
||||||
put_nfs_open_context(nfs_file_open_context(src));
|
put_nfs_open_context(nfs_file_open_context(src));
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user