summaryrefslogtreecommitdiff
path: root/fs/nfsd
diff options
context:
space:
mode:
authorJeff Layton <jlayton@kernel.org>2023-01-17 14:38:30 -0500
committerChuck Lever <chuck.lever@oracle.com>2023-02-20 09:20:52 -0500
commit1f0001d43d0c0ac2a19a34a914f6595ad97cbc1d (patch)
treee8a4ef1f35ffa298216f34696a012cf6da0b0abd /fs/nfsd
parentecfa3987731b1ceb7964075cdc0235da1765622a (diff)
downloadlwn-1f0001d43d0c0ac2a19a34a914f6595ad97cbc1d.tar.gz
lwn-1f0001d43d0c0ac2a19a34a914f6595ad97cbc1d.zip
nfsd: zero out pointers after putting nfsd_files on COPY setup error
At first, I thought this might be a source of nfsd_file overputs, but the current callers seem to avoid an extra put when nfsd4_verify_copy returns an error. Still, it's "bad form" to leave the pointers filled out when we don't have a reference to them anymore, and that might lead to bugs later. Zero them out as a defensive coding measure. Signed-off-by: Jeff Layton <jlayton@kernel.org> Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
Diffstat (limited to 'fs/nfsd')
-rw-r--r--fs/nfsd/nfs4proc.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/nfsd/nfs4proc.c b/fs/nfsd/nfs4proc.c
index 3b73e4d342bf..95234c8060d5 100644
--- a/fs/nfsd/nfs4proc.c
+++ b/fs/nfsd/nfs4proc.c
@@ -1214,8 +1214,10 @@ out:
return status;
out_put_dst:
nfsd_file_put(*dst);
+ *dst = NULL;
out_put_src:
nfsd_file_put(*src);
+ *src = NULL;
goto out;
}