diff options
author | Trond Myklebust <trond.myklebust@primarydata.com> | 2014-10-17 22:02:52 +0200 |
---|---|---|
committer | Trond Myklebust <trond.myklebust@primarydata.com> | 2014-11-12 23:19:04 +0100 |
commit | f8ebf7a8ca35dde321f0cd385fee6f1950609367 (patch) | |
tree | e46ece4ad85c0a818247aa29a0a4849a8e168583 | |
parent | NFSv4: Ensure that we call FREE_STATEID when NFSv4.x stateids are revoked (diff) | |
download | linux-f8ebf7a8ca35dde321f0cd385fee6f1950609367.tar.xz linux-f8ebf7a8ca35dde321f0cd385fee6f1950609367.zip |
NFS: Don't try to reclaim delegation open state if recovery failed
If state recovery failed, then we should not attempt to reclaim delegated
state.
http://lkml.kernel.org/r/CAN-5tyHwG=Cn2Q9KsHWadewjpTTy_K26ee+UnSvHvG4192p-Xw@mail.gmail.com
Cc: stable@vger.kernel.org
Signed-off-by: Trond Myklebust <trond.myklebust@primarydata.com>
-rw-r--r-- | fs/nfs/delegation.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/fs/nfs/delegation.c b/fs/nfs/delegation.c index e5f473d13e24..7f3f60641344 100644 --- a/fs/nfs/delegation.c +++ b/fs/nfs/delegation.c @@ -125,6 +125,8 @@ again: continue; if (!test_bit(NFS_DELEGATED_STATE, &state->flags)) continue; + if (!nfs4_valid_open_stateid(state)) + continue; if (!nfs4_stateid_match(&state->stateid, stateid)) continue; get_nfs_open_context(ctx); |