Commit b1352905 authored by Trond Myklebust's avatar Trond Myklebust

NFSv4.1: Handle SEQ4_STATUS_BACKCHANNEL_FAULT correctly

RFC5661 states:

      The server has encountered an unrecoverable fault with the
      backchannel (e.g., it has lost track of the sequence ID for a slot
      in the backchannel).  The client MUST stop sending more requests
      on the session's fore channel, wait for all outstanding requests
      to complete on the fore and back channel, and then destroy the
      session.

Ensure we do so...
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@primarydata.com>
parent 4099287f
...@@ -2217,9 +2217,9 @@ static void nfs41_handle_recallable_state_revoked(struct nfs_client *clp) ...@@ -2217,9 +2217,9 @@ static void nfs41_handle_recallable_state_revoked(struct nfs_client *clp)
static void nfs41_handle_backchannel_fault(struct nfs_client *clp) static void nfs41_handle_backchannel_fault(struct nfs_client *clp)
{ {
nfs_expire_all_delegations(clp); set_bit(NFS4CLNT_SESSION_RESET, &clp->cl_state);
if (test_and_set_bit(NFS4CLNT_SESSION_RESET, &clp->cl_state) == 0) nfs4_schedule_state_manager(clp);
nfs4_schedule_state_manager(clp);
dprintk("%s: server %s declared a backchannel fault\n", __func__, dprintk("%s: server %s declared a backchannel fault\n", __func__,
clp->cl_hostname); clp->cl_hostname);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment