aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfs/nfs4state.c
diff options
context:
space:
mode:
authorAndy Adamson <andros@netapp.com>2009-12-04 15:52:24 -0500
committerTrond Myklebust <Trond.Myklebust@netapp.com>2009-12-04 15:52:24 -0500
commit4d643d1dfa9349164fe928e255f68020d91dbfe0 (patch)
tree1dde84268d81698e3f84cc3f20d90ddc234ba33f /fs/nfs/nfs4state.c
parent7285f2d2ffd4b7ab4ffb70a47759ee209c30017b (diff)
nfs41: add create session into establish_clid
Reported-by: Trond Myklebust <trond.myklebust@netapp.com> Resetting the clientid from the state manager could result in not confirming the clientid due to create session not being called. Move the create session call from the NFS4CLNT_SESSION_SETUP state manager initialize session case into the NFS4CLNT_LEASE_EXPIRED case establish_clid call. Signed-off-by: Andy Adamson <andros@netapp.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/nfs/nfs4state.c')
-rw-r--r--fs/nfs/nfs4state.c35
1 files changed, 14 insertions, 21 deletions
diff --git a/fs/nfs/nfs4state.c b/fs/nfs/nfs4state.c
index 2eb0059bd693..967fc76a2463 100644
--- a/fs/nfs/nfs4state.c
+++ b/fs/nfs/nfs4state.c
@@ -116,6 +116,19 @@ struct rpc_cred *nfs4_get_renew_cred_locked(struct nfs_client *clp)
116 116
117#if defined(CONFIG_NFS_V4_1) 117#if defined(CONFIG_NFS_V4_1)
118 118
119int nfs41_init_clientid(struct nfs_client *clp, struct rpc_cred *cred)
120{
121 int status;
122
123 status = nfs4_proc_exchange_id(clp, cred);
124 if (status == 0)
125 /* create session schedules state renewal upon success */
126 status = nfs4_proc_create_session(clp, 0);
127 if (status == 0)
128 nfs_mark_client_ready(clp, NFS_CS_READY);
129 return status;
130}
131
119struct rpc_cred *nfs4_get_exchange_id_cred(struct nfs_client *clp) 132struct rpc_cred *nfs4_get_exchange_id_cred(struct nfs_client *clp)
120{ 133{
121 struct rpc_cred *cred; 134 struct rpc_cred *cred;
@@ -1162,7 +1175,6 @@ static void nfs4_session_recovery_handle_error(struct nfs_client *clp, int err)
1162 switch (err) { 1175 switch (err) {
1163 case -NFS4ERR_STALE_CLIENTID: 1176 case -NFS4ERR_STALE_CLIENTID:
1164 set_bit(NFS4CLNT_LEASE_EXPIRED, &clp->cl_state); 1177 set_bit(NFS4CLNT_LEASE_EXPIRED, &clp->cl_state);
1165 set_bit(NFS4CLNT_SESSION_SETUP, &clp->cl_state);
1166 } 1178 }
1167} 1179}
1168 1180
@@ -1188,24 +1200,8 @@ out:
1188 return status; 1200 return status;
1189} 1201}
1190 1202
1191static int nfs4_initialize_session(struct nfs_client *clp)
1192{
1193 int status;
1194
1195 status = nfs4_proc_create_session(clp, 0);
1196 if (!status) {
1197 nfs_mark_client_ready(clp, NFS_CS_READY);
1198 } else if (status == -NFS4ERR_STALE_CLIENTID) {
1199 set_bit(NFS4CLNT_LEASE_EXPIRED, &clp->cl_state);
1200 set_bit(NFS4CLNT_SESSION_SETUP, &clp->cl_state);
1201 } else {
1202 nfs_mark_client_ready(clp, status);
1203 }
1204 return status;
1205}
1206#else /* CONFIG_NFS_V4_1 */ 1203#else /* CONFIG_NFS_V4_1 */
1207static int nfs4_reset_session(struct nfs_client *clp) { return 0; } 1204static int nfs4_reset_session(struct nfs_client *clp) { return 0; }
1208static int nfs4_initialize_session(struct nfs_client *clp) { return 0; }
1209#endif /* CONFIG_NFS_V4_1 */ 1205#endif /* CONFIG_NFS_V4_1 */
1210 1206
1211/* Set NFS4CLNT_LEASE_EXPIRED for all v4.0 errors and for recoverable errors 1207/* Set NFS4CLNT_LEASE_EXPIRED for all v4.0 errors and for recoverable errors
@@ -1262,10 +1258,7 @@ static void nfs4_state_manager(struct nfs_client *clp)
1262 /* Initialize or reset the session */ 1258 /* Initialize or reset the session */
1263 if (test_and_clear_bit(NFS4CLNT_SESSION_SETUP, &clp->cl_state) 1259 if (test_and_clear_bit(NFS4CLNT_SESSION_SETUP, &clp->cl_state)
1264 && nfs4_has_session(clp)) { 1260 && nfs4_has_session(clp)) {
1265 if (clp->cl_cons_state == NFS_CS_SESSION_INITING) 1261 status = nfs4_reset_session(clp);
1266 status = nfs4_initialize_session(clp);
1267 else
1268 status = nfs4_reset_session(clp);
1269 if (test_bit(NFS4CLNT_LEASE_EXPIRED, &clp->cl_state)) 1262 if (test_bit(NFS4CLNT_LEASE_EXPIRED, &clp->cl_state))
1270 continue; 1263 continue;
1271 if (status < 0) 1264 if (status < 0)