Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit e37da04e authored by Alexandros Batsakis's avatar Alexandros Batsakis Committed by J. Bruce Fields
Browse files

nfsd: lock state around put client and delegation in nfsd4_cb_recall



not having the state locked before putting the client/delegation causes a bug.
Also removed the comment from the function header about the state being already locked

Signed-off-by: default avatarAlexandros Batsakis <batsakis@netapp.com>
Signed-off-by: default avatarBenny Halevy <bhalevy@panasas.com>
Signed-off-by: default avatarJ. Bruce Fields <bfields@citi.umich.edu>
parent 6c02eaa1
Loading
Loading
Loading
Loading
+2 −1
Original line number Diff line number Diff line
@@ -451,7 +451,6 @@ nfsd4_probe_callback(struct nfs4_client *clp)

/*
 * called with dp->dl_count inc'ed.
 * nfs4_lock_state() may or may not have been called.
 */
void
nfsd4_cb_recall(struct nfs4_delegation *dp)
@@ -491,7 +490,9 @@ nfsd4_cb_recall(struct nfs4_delegation *dp)
	 * Success or failure, now we're either waiting for lease expiration
	 * or deleg_return.
	 */
	nfs4_lock_state();
	put_nfs4_client(clp);
	nfs4_put_delegation(dp);
	nfs4_unlock_state();
	return;
}