1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41#include <linux/mm.h>
42#include <linux/pagemap.h>
43#include <linux/sunrpc/sched.h>
44#include <linux/sunrpc/clnt.h>
45
46#include <linux/nfs.h>
47#include <linux/nfs4.h>
48#include <linux/nfs_fs.h>
49#include "nfs4_fs.h"
50#include "delegation.h"
51
52#define NFSDBG_FACILITY NFSDBG_STATE
53
54void
55nfs4_renew_state(struct work_struct *work)
56{
57 const struct nfs4_state_maintenance_ops *ops;
58 struct nfs_client *clp =
59 container_of(work, struct nfs_client, cl_renewd.work);
60 struct rpc_cred *cred;
61 long lease;
62 unsigned long last, now;
63 unsigned renew_flags = 0;
64
65 ops = clp->cl_mvops->state_renewal_ops;
66 dprintk("%s: start\n", __func__);
67
68 if (test_bit(NFS_CS_STOP_RENEW, &clp->cl_res_state))
69 goto out;
70
71 spin_lock(&clp->cl_lock);
72 lease = clp->cl_lease_time;
73 last = clp->cl_last_renewal;
74 now = jiffies;
75
76 if (time_after(now, last + lease/3))
77 renew_flags |= NFS4_RENEW_TIMEOUT;
78 if (nfs_delegations_present(clp))
79 renew_flags |= NFS4_RENEW_DELEGATION_CB;
80
81 if (renew_flags != 0) {
82 cred = ops->get_state_renewal_cred_locked(clp);
83 spin_unlock(&clp->cl_lock);
84 if (cred == NULL) {
85 if (!(renew_flags & NFS4_RENEW_DELEGATION_CB)) {
86 set_bit(NFS4CLNT_LEASE_EXPIRED, &clp->cl_state);
87 goto out;
88 }
89 nfs_expire_all_delegations(clp);
90 } else {
91
92 ops->sched_state_renewal(clp, cred, renew_flags);
93 put_rpccred(cred);
94 goto out_exp;
95 }
96 } else {
97 dprintk("%s: failed to call renewd. Reason: lease not expired \n",
98 __func__);
99 spin_unlock(&clp->cl_lock);
100 }
101 nfs4_schedule_state_renewal(clp);
102out_exp:
103 nfs_expire_unreferenced_delegations(clp);
104out:
105 dprintk("%s: done\n", __func__);
106}
107
108void
109nfs4_schedule_state_renewal(struct nfs_client *clp)
110{
111 long timeout;
112
113 spin_lock(&clp->cl_lock);
114 timeout = (2 * clp->cl_lease_time) / 3 + (long)clp->cl_last_renewal
115 - (long)jiffies;
116 if (timeout < 5 * HZ)
117 timeout = 5 * HZ;
118 dprintk("%s: requeueing work. Lease period = %ld\n",
119 __func__, (timeout + HZ - 1) / HZ);
120 mod_delayed_work(system_wq, &clp->cl_renewd, timeout);
121 set_bit(NFS_CS_RENEWD, &clp->cl_res_state);
122 spin_unlock(&clp->cl_lock);
123}
124
125void
126nfs4_kill_renewd(struct nfs_client *clp)
127{
128 cancel_delayed_work_sync(&clp->cl_renewd);
129}
130
131
132
133
134
135
136