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:
parent
f9d640f3a4
commit
47b803c8d2
|
@ -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",
|
||||||
|
|
Loading…
Reference in New Issue