aboutsummaryrefslogtreecommitdiff
path: root/sys/fs/nfsclient
diff options
context:
space:
mode:
authorRick Macklem <rmacklem@FreeBSD.org>2021-10-26 02:09:14 +0000
committerRick Macklem <rmacklem@FreeBSD.org>2021-10-26 02:11:45 +0000
commit23024f004a4c5659bfcb0b08fac2211ae925ee58 (patch)
treedc5800d4046c84604bfcee5f1b4e7c3f96ebcf92 /sys/fs/nfsclient
parentdce5f3abed7181cc533ca5ed3de44517775e78dd (diff)
downloadsrc-23024f004a4c5659bfcb0b08fac2211ae925ee58.tar.gz
src-23024f004a4c5659bfcb0b08fac2211ae925ee58.zip
nfscl: Add a missing delegation lock release
There was a case in nfscl_doiods() where the function would return without releasing the delegation shared lock, if it was aquired by the call to nfscl_getstateid(). This patch adds that release. I have never observed a failure due to this missing release, so I do not know if it ever happens in practice. However, since the pNFS client is not yet heavily used, it might be the case. Found by code inspection during a recent NFSv4 IETF working group testing event. MFC after: 2 week
Diffstat (limited to 'sys/fs/nfsclient')
-rw-r--r--sys/fs/nfsclient/nfs_clrpcops.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/sys/fs/nfsclient/nfs_clrpcops.c b/sys/fs/nfsclient/nfs_clrpcops.c
index 35ce9be88405..dec70dc2ac06 100644
--- a/sys/fs/nfsclient/nfs_clrpcops.c
+++ b/sys/fs/nfsclient/nfs_clrpcops.c
@@ -6045,6 +6045,8 @@ nfscl_doiods(vnode_t vp, struct uio *uiop, int *iomode, int *must_commit,
if (layp == NULL || rflp == NULL) {
if (recalled != 0) {
NFSFREECRED(newcred);
+ if (lckp != NULL)
+ nfscl_lockderef(lckp);
nfscl_relref(nmp);
return (EIO);
}