Commit 2958d2ee authored by Chuck Lever's avatar Chuck Lever Committed by J. Bruce Fields

NFSD: Add a couple more nfsd_clid_expired call sites

Improve observation of NFSv4 lease expiry.
Signed-off-by: default avatarChuck Lever <chuck.lever@oracle.com>
Signed-off-by: default avatarJ. Bruce Fields <bfields@redhat.com>
parent c41a9b7a
...@@ -2665,6 +2665,8 @@ static void force_expire_client(struct nfs4_client *clp) ...@@ -2665,6 +2665,8 @@ 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;
trace_nfsd_clid_admin_expired(&clp->cl_clientid);
spin_lock(&clp->cl_lock); spin_lock(&clp->cl_lock);
clp->cl_time = 0; clp->cl_time = 0;
spin_unlock(&clp->cl_lock); spin_unlock(&clp->cl_lock);
...@@ -3211,6 +3213,7 @@ nfsd4_exchange_id(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate, ...@@ -3211,6 +3213,7 @@ nfsd4_exchange_id(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
status = mark_client_expired_locked(conf); status = mark_client_expired_locked(conf);
if (status) if (status)
goto out; goto out;
trace_nfsd_clid_replaced(&conf->cl_clientid);
} }
new->cl_minorversion = cstate->minorversion; new->cl_minorversion = cstate->minorversion;
new->cl_spo_must_allow.u.words[0] = exid->spo_must_allow[0]; new->cl_spo_must_allow.u.words[0] = exid->spo_must_allow[0];
...@@ -3450,6 +3453,7 @@ nfsd4_create_session(struct svc_rqst *rqstp, ...@@ -3450,6 +3453,7 @@ nfsd4_create_session(struct svc_rqst *rqstp,
old = NULL; old = NULL;
goto out_free_conn; goto out_free_conn;
} }
trace_nfsd_clid_replaced(&old->cl_clientid);
} }
move_to_confirmed(unconf); move_to_confirmed(unconf);
conf = unconf; conf = unconf;
...@@ -4078,6 +4082,7 @@ nfsd4_setclientid_confirm(struct svc_rqst *rqstp, ...@@ -4078,6 +4082,7 @@ nfsd4_setclientid_confirm(struct svc_rqst *rqstp,
old = NULL; old = NULL;
goto out; goto out;
} }
trace_nfsd_clid_replaced(&old->cl_clientid);
} }
move_to_confirmed(unconf); move_to_confirmed(unconf);
conf = unconf; conf = unconf;
...@@ -5508,10 +5513,8 @@ nfs4_laundromat(struct nfsd_net *nn) ...@@ -5508,10 +5513,8 @@ nfs4_laundromat(struct nfsd_net *nn)
clp = list_entry(pos, struct nfs4_client, cl_lru); clp = list_entry(pos, struct nfs4_client, cl_lru);
if (!state_expired(&lt, clp->cl_time)) if (!state_expired(&lt, clp->cl_time))
break; break;
if (mark_client_expired_locked(clp)) { if (mark_client_expired_locked(clp))
trace_nfsd_clid_expired(&clp->cl_clientid);
continue; continue;
}
list_add(&clp->cl_lru, &reaplist); list_add(&clp->cl_lru, &reaplist);
} }
spin_unlock(&nn->client_lock); spin_unlock(&nn->client_lock);
......
...@@ -514,7 +514,8 @@ DEFINE_EVENT(nfsd_clientid_class, nfsd_clid_##name, \ ...@@ -514,7 +514,8 @@ DEFINE_EVENT(nfsd_clientid_class, nfsd_clid_##name, \
DEFINE_CLIENTID_EVENT(reclaim_complete); DEFINE_CLIENTID_EVENT(reclaim_complete);
DEFINE_CLIENTID_EVENT(confirmed); DEFINE_CLIENTID_EVENT(confirmed);
DEFINE_CLIENTID_EVENT(destroyed); DEFINE_CLIENTID_EVENT(destroyed);
DEFINE_CLIENTID_EVENT(expired); DEFINE_CLIENTID_EVENT(admin_expired);
DEFINE_CLIENTID_EVENT(replaced);
DEFINE_CLIENTID_EVENT(purged); DEFINE_CLIENTID_EVENT(purged);
DEFINE_CLIENTID_EVENT(renew); DEFINE_CLIENTID_EVENT(renew);
DEFINE_CLIENTID_EVENT(stale); DEFINE_CLIENTID_EVENT(stale);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment