mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-23 23:10:51 +07:00
nfsd4: Fix forced-expiry locking
[ Upstream commit f7104cc1a9159cd0d3e8526cb638ae0301de4b61 ] This should use the network-namespace-wide client_lock, not the per-client cl_lock. You shouldn't see any bugs unless you're actually using the forced-expiry interface introduced by89c905becc
. Fixes:89c905becc
"nfsd: allow forced expiration of NFSv4 clients" Signed-off-by: J. Bruce Fields <bfields@redhat.com> Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
a7883d0e67
commit
91d9b04b4f
@ -2660,9 +2660,9 @@ static void force_expire_client(struct nfs4_client *clp)
|
|||||||
struct nfsd_net *nn = net_generic(clp->net, nfsd_net_id);
|
struct nfsd_net *nn = net_generic(clp->net, nfsd_net_id);
|
||||||
bool already_expired;
|
bool already_expired;
|
||||||
|
|
||||||
spin_lock(&clp->cl_lock);
|
spin_lock(&nn->client_lock);
|
||||||
clp->cl_time = 0;
|
clp->cl_time = 0;
|
||||||
spin_unlock(&clp->cl_lock);
|
spin_unlock(&nn->client_lock);
|
||||||
|
|
||||||
wait_event(expiry_wq, atomic_read(&clp->cl_rpc_users) == 0);
|
wait_event(expiry_wq, atomic_read(&clp->cl_rpc_users) == 0);
|
||||||
spin_lock(&nn->client_lock);
|
spin_lock(&nn->client_lock);
|
||||||
|
Loading…
Reference in New Issue
Block a user