aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfsd
diff options
context:
space:
mode:
authorStanislav Kinsbursky <skinsbursky@parallels.com>2012-07-25 08:57:45 -0400
committerJ. Bruce Fields <bfields@redhat.com>2012-07-27 16:49:22 -0400
commit2c142baa7b237584bae7dc28630851701497e1ef (patch)
tree6c86fcd0b7fa47e8040fab51aecd306fe2f01174 /fs/nfsd
parenta51c84ed502c25fed996afb7696fd7db2fa32fe2 (diff)
NFSd: make boot_time variable per network namespace
NFSd's boot_time represents grace period start point in time. Signed-off-by: Stanislav Kinsbursky <skinsbursky@parallels.com> Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'fs/nfsd')
-rw-r--r--fs/nfsd/netns.h1
-rw-r--r--fs/nfsd/nfs4state.c39
-rw-r--r--fs/nfsd/state.h1
3 files changed, 25 insertions, 16 deletions
diff --git a/fs/nfsd/netns.h b/fs/nfsd/netns.h
index b6deebd08ef2..65c2431ea32f 100644
--- a/fs/nfsd/netns.h
+++ b/fs/nfsd/netns.h
@@ -37,6 +37,7 @@ struct nfsd_net {
37 37
38 struct lock_manager nfsd4_manager; 38 struct lock_manager nfsd4_manager;
39 bool grace_ended; 39 bool grace_ended;
40 time_t boot_time;
40}; 41};
41 42
42extern int nfsd_net_id; 43extern int nfsd_net_id;
diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c
index aebb58d3ac4a..cc894eda385a 100644
--- a/fs/nfsd/nfs4state.c
+++ b/fs/nfsd/nfs4state.c
@@ -53,7 +53,6 @@
53/* Globals */ 53/* Globals */
54time_t nfsd4_lease = 90; /* default lease time */ 54time_t nfsd4_lease = 90; /* default lease time */
55time_t nfsd4_grace = 90; 55time_t nfsd4_grace = 90;
56static time_t boot_time;
57 56
58#define all_ones {{~0,~0},~0} 57#define all_ones {{~0,~0},~0}
59static const stateid_t one_stateid = { 58static const stateid_t one_stateid = {
@@ -1056,12 +1055,12 @@ renew_client(struct nfs4_client *clp)
1056 1055
1057/* SETCLIENTID and SETCLIENTID_CONFIRM Helper functions */ 1056/* SETCLIENTID and SETCLIENTID_CONFIRM Helper functions */
1058static int 1057static int
1059STALE_CLIENTID(clientid_t *clid) 1058STALE_CLIENTID(clientid_t *clid, struct nfsd_net *nn)
1060{ 1059{
1061 if (clid->cl_boot == boot_time) 1060 if (clid->cl_boot == nn->boot_time)
1062 return 0; 1061 return 0;
1063 dprintk("NFSD stale clientid (%08x/%08x) boot_time %08lx\n", 1062 dprintk("NFSD stale clientid (%08x/%08x) boot_time %08lx\n",
1064 clid->cl_boot, clid->cl_id, boot_time); 1063 clid->cl_boot, clid->cl_id, nn->boot_time);
1065 return 1; 1064 return 1;
1066} 1065}
1067 1066
@@ -1242,8 +1241,9 @@ same_creds(struct svc_cred *cr1, struct svc_cred *cr2)
1242static void gen_clid(struct nfs4_client *clp) 1241static void gen_clid(struct nfs4_client *clp)
1243{ 1242{
1244 static u32 current_clientid = 1; 1243 static u32 current_clientid = 1;
1244 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
1245 1245
1246 clp->cl_clientid.cl_boot = boot_time; 1246 clp->cl_clientid.cl_boot = nn->boot_time;
1247 clp->cl_clientid.cl_id = current_clientid++; 1247 clp->cl_clientid.cl_id = current_clientid++;
1248} 1248}
1249 1249
@@ -2226,8 +2226,9 @@ nfsd4_setclientid_confirm(struct svc_rqst *rqstp,
2226 nfs4_verifier confirm = setclientid_confirm->sc_confirm; 2226 nfs4_verifier confirm = setclientid_confirm->sc_confirm;
2227 clientid_t * clid = &setclientid_confirm->sc_clientid; 2227 clientid_t * clid = &setclientid_confirm->sc_clientid;
2228 __be32 status; 2228 __be32 status;
2229 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
2229 2230
2230 if (STALE_CLIENTID(clid)) 2231 if (STALE_CLIENTID(clid, nn))
2231 return nfserr_stale_clientid; 2232 return nfserr_stale_clientid;
2232 nfs4_lock_state(); 2233 nfs4_lock_state();
2233 2234
@@ -2586,8 +2587,9 @@ nfsd4_process_open1(struct nfsd4_compound_state *cstate,
2586 unsigned int strhashval; 2587 unsigned int strhashval;
2587 struct nfs4_openowner *oo = NULL; 2588 struct nfs4_openowner *oo = NULL;
2588 __be32 status; 2589 __be32 status;
2590 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
2589 2591
2590 if (STALE_CLIENTID(&open->op_clientid)) 2592 if (STALE_CLIENTID(&open->op_clientid, nn))
2591 return nfserr_stale_clientid; 2593 return nfserr_stale_clientid;
2592 /* 2594 /*
2593 * In case we need it later, after we've already created the 2595 * In case we need it later, after we've already created the
@@ -3095,12 +3097,13 @@ nfsd4_renew(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
3095{ 3097{
3096 struct nfs4_client *clp; 3098 struct nfs4_client *clp;
3097 __be32 status; 3099 __be32 status;
3100 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
3098 3101
3099 nfs4_lock_state(); 3102 nfs4_lock_state();
3100 dprintk("process_renew(%08x/%08x): starting\n", 3103 dprintk("process_renew(%08x/%08x): starting\n",
3101 clid->cl_boot, clid->cl_id); 3104 clid->cl_boot, clid->cl_id);
3102 status = nfserr_stale_clientid; 3105 status = nfserr_stale_clientid;
3103 if (STALE_CLIENTID(clid)) 3106 if (STALE_CLIENTID(clid, nn))
3104 goto out; 3107 goto out;
3105 clp = find_confirmed_client(clid); 3108 clp = find_confirmed_client(clid);
3106 status = nfserr_expired; 3109 status = nfserr_expired;
@@ -3130,7 +3133,7 @@ nfsd4_end_grace(struct net *net)
3130 3133
3131 dprintk("NFSD: end of grace period\n"); 3134 dprintk("NFSD: end of grace period\n");
3132 nn->grace_ended = true; 3135 nn->grace_ended = true;
3133 nfsd4_record_grace_done(net, boot_time); 3136 nfsd4_record_grace_done(net, nn->boot_time);
3134 locks_end_grace(&nn->nfsd4_manager); 3137 locks_end_grace(&nn->nfsd4_manager);
3135 /* 3138 /*
3136 * Now that every NFSv4 client has had the chance to recover and 3139 * Now that every NFSv4 client has had the chance to recover and
@@ -3236,9 +3239,9 @@ static inline __be32 nfs4_check_fh(struct svc_fh *fhp, struct nfs4_ol_stateid *s
3236} 3239}
3237 3240
3238static int 3241static int
3239STALE_STATEID(stateid_t *stateid) 3242STALE_STATEID(stateid_t *stateid, struct nfsd_net *nn)
3240{ 3243{
3241 if (stateid->si_opaque.so_clid.cl_boot == boot_time) 3244 if (stateid->si_opaque.so_clid.cl_boot == nn->boot_time)
3242 return 0; 3245 return 0;
3243 dprintk("NFSD: stale stateid " STATEID_FMT "!\n", 3246 dprintk("NFSD: stale stateid " STATEID_FMT "!\n",
3244 STATEID_VAL(stateid)); 3247 STATEID_VAL(stateid));
@@ -3373,10 +3376,11 @@ static __be32 nfsd4_validate_stateid(struct nfs4_client *cl, stateid_t *stateid)
3373static __be32 nfsd4_lookup_stateid(stateid_t *stateid, unsigned char typemask, struct nfs4_stid **s) 3376static __be32 nfsd4_lookup_stateid(stateid_t *stateid, unsigned char typemask, struct nfs4_stid **s)
3374{ 3377{
3375 struct nfs4_client *cl; 3378 struct nfs4_client *cl;
3379 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
3376 3380
3377 if (ZERO_STATEID(stateid) || ONE_STATEID(stateid)) 3381 if (ZERO_STATEID(stateid) || ONE_STATEID(stateid))
3378 return nfserr_bad_stateid; 3382 return nfserr_bad_stateid;
3379 if (STALE_STATEID(stateid)) 3383 if (STALE_STATEID(stateid, nn))
3380 return nfserr_stale_stateid; 3384 return nfserr_stale_stateid;
3381 cl = find_confirmed_client(&stateid->si_opaque.so_clid); 3385 cl = find_confirmed_client(&stateid->si_opaque.so_clid);
3382 if (!cl) 3386 if (!cl)
@@ -4048,6 +4052,7 @@ nfsd4_lock(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
4048 bool new_state = false; 4052 bool new_state = false;
4049 int lkflg; 4053 int lkflg;
4050 int err; 4054 int err;
4055 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
4051 4056
4052 dprintk("NFSD: nfsd4_lock: start=%Ld length=%Ld\n", 4057 dprintk("NFSD: nfsd4_lock: start=%Ld length=%Ld\n",
4053 (long long) lock->lk_offset, 4058 (long long) lock->lk_offset,
@@ -4074,7 +4079,7 @@ nfsd4_lock(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
4074 sizeof(clientid_t)); 4079 sizeof(clientid_t));
4075 4080
4076 status = nfserr_stale_clientid; 4081 status = nfserr_stale_clientid;
4077 if (STALE_CLIENTID(&lock->lk_new_clientid)) 4082 if (STALE_CLIENTID(&lock->lk_new_clientid, nn))
4078 goto out; 4083 goto out;
4079 4084
4080 /* validate and update open stateid and open seqid */ 4085 /* validate and update open stateid and open seqid */
@@ -4208,6 +4213,7 @@ nfsd4_lockt(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
4208 struct file_lock file_lock; 4213 struct file_lock file_lock;
4209 struct nfs4_lockowner *lo; 4214 struct nfs4_lockowner *lo;
4210 __be32 status; 4215 __be32 status;
4216 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
4211 4217
4212 if (locks_in_grace(SVC_NET(rqstp))) 4218 if (locks_in_grace(SVC_NET(rqstp)))
4213 return nfserr_grace; 4219 return nfserr_grace;
@@ -4218,7 +4224,7 @@ nfsd4_lockt(struct svc_rqst *rqstp, struct nfsd4_compound_state *cstate,
4218 nfs4_lock_state(); 4224 nfs4_lock_state();
4219 4225
4220 status = nfserr_stale_clientid; 4226 status = nfserr_stale_clientid;
4221 if (!nfsd4_has_session(cstate) && STALE_CLIENTID(&lockt->lt_clientid)) 4227 if (!nfsd4_has_session(cstate) && STALE_CLIENTID(&lockt->lt_clientid, nn))
4222 goto out; 4228 goto out;
4223 4229
4224 if ((status = fh_verify(rqstp, &cstate->current_fh, S_IFREG, 0))) 4230 if ((status = fh_verify(rqstp, &cstate->current_fh, S_IFREG, 0)))
@@ -4367,6 +4373,7 @@ nfsd4_release_lockowner(struct svc_rqst *rqstp,
4367 struct list_head matches; 4373 struct list_head matches;
4368 unsigned int hashval = ownerstr_hashval(clid->cl_id, owner); 4374 unsigned int hashval = ownerstr_hashval(clid->cl_id, owner);
4369 __be32 status; 4375 __be32 status;
4376 struct nfsd_net *nn = net_generic(&init_net, nfsd_net_id);
4370 4377
4371 dprintk("nfsd4_release_lockowner clientid: (%08x/%08x):\n", 4378 dprintk("nfsd4_release_lockowner clientid: (%08x/%08x):\n",
4372 clid->cl_boot, clid->cl_id); 4379 clid->cl_boot, clid->cl_id);
@@ -4374,7 +4381,7 @@ nfsd4_release_lockowner(struct svc_rqst *rqstp,
4374 /* XXX check for lease expiration */ 4381 /* XXX check for lease expiration */
4375 4382
4376 status = nfserr_stale_clientid; 4383 status = nfserr_stale_clientid;
4377 if (STALE_CLIENTID(clid)) 4384 if (STALE_CLIENTID(clid, nn))
4378 return status; 4385 return status;
4379 4386
4380 nfs4_lock_state(); 4387 nfs4_lock_state();
@@ -4701,7 +4708,7 @@ nfs4_state_start(void)
4701 */ 4708 */
4702 get_net(net); 4709 get_net(net);
4703 nfsd4_client_tracking_init(net); 4710 nfsd4_client_tracking_init(net);
4704 boot_time = get_seconds(); 4711 nn->boot_time = get_seconds();
4705 locks_start_grace(net, &nn->nfsd4_manager); 4712 locks_start_grace(net, &nn->nfsd4_manager);
4706 nn->grace_ended = false; 4713 nn->grace_ended = false;
4707 printk(KERN_INFO "NFSD: starting %ld-second grace period\n", 4714 printk(KERN_INFO "NFSD: starting %ld-second grace period\n",
diff --git a/fs/nfsd/state.h b/fs/nfsd/state.h
index 981ef10141b3..e6173147f982 100644
--- a/fs/nfsd/state.h
+++ b/fs/nfsd/state.h
@@ -450,6 +450,7 @@ static inline struct nfs4_ol_stateid *openlockstateid(struct nfs4_stid *s)
450#define WR_STATE 0x00000020 450#define WR_STATE 0x00000020
451 451
452struct nfsd4_compound_state; 452struct nfsd4_compound_state;
453struct nfsd_net;
453 454
454extern __be32 nfs4_preprocess_stateid_op(struct net *net, 455extern __be32 nfs4_preprocess_stateid_op(struct net *net,
455 struct nfsd4_compound_state *cstate, 456 struct nfsd4_compound_state *cstate,