NFSv4.0 reclaim reboot state when re-establishing clientid

We should reclaim reboot state when the clientid is stale.

Signed-off-by: Andy Adamson <andros@netapp.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
This commit is contained in:
Andy Adamson 2012-10-01 20:42:32 -04:00 committed by Trond Myklebust
parent f9d640f3a4
commit 47b803c8d2
1 changed files with 6 additions and 2 deletions

View File

@ -1680,8 +1680,8 @@ out:
return nfs4_recovery_handle_error(clp, status); return nfs4_recovery_handle_error(clp, status);
} }
/* Set NFS4CLNT_LEASE_EXPIRED for all v4.0 errors and for recoverable errors /* Set NFS4CLNT_LEASE_EXPIRED and reclaim reboot state for all v4.0 errors
* on EXCHANGE_ID for v4.1 * and for recoverable errors on EXCHANGE_ID for v4.1
*/ */
static int nfs4_handle_reclaim_lease_error(struct nfs_client *clp, int status) static int nfs4_handle_reclaim_lease_error(struct nfs_client *clp, int status)
{ {
@ -1691,8 +1691,12 @@ static int nfs4_handle_reclaim_lease_error(struct nfs_client *clp, int status)
return -ESERVERFAULT; return -ESERVERFAULT;
/* Lease confirmation error: retry after purging the lease */ /* Lease confirmation error: retry after purging the lease */
ssleep(1); ssleep(1);
clear_bit(NFS4CLNT_LEASE_CONFIRM, &clp->cl_state);
break;
case -NFS4ERR_STALE_CLIENTID: case -NFS4ERR_STALE_CLIENTID:
clear_bit(NFS4CLNT_LEASE_CONFIRM, &clp->cl_state); clear_bit(NFS4CLNT_LEASE_CONFIRM, &clp->cl_state);
nfs4_state_clear_reclaim_reboot(clp);
nfs4_state_start_reclaim_reboot(clp);
break; break;
case -NFS4ERR_CLID_INUSE: case -NFS4ERR_CLID_INUSE:
pr_err("NFS: Server %s reports our clientid is in use\n", pr_err("NFS: Server %s reports our clientid is in use\n",