diff options
author | J. Bruce Fields <bfields@redhat.com> | 2011-08-25 18:17:52 -0400 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2011-09-01 07:29:01 -0400 |
commit | fff6ca9cc46857e5814cf687e5fb1b8a876766a4 (patch) | |
tree | b96032c84f885c5be6a2efd8326873f80150419c /fs/nfsd | |
parent | 5ec094c1096ab3bb795651855d53f18daa26afde (diff) |
nfsd4: eliminate impossible open replay case
If open fails with any error other than nfserr_replay_me, then the main
nfsd4_proc_compound() loop continues unconditionally to
nfsd4_encode_operation(), which will always call encode_seqid_op_tail.
Thus the condition we check for here does not occur.
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'fs/nfsd')
-rw-r--r-- | fs/nfsd/nfs4state.c | 14 |
1 files changed, 2 insertions, 12 deletions
diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c index 6cf729a096c..26b0c75aa93 100644 --- a/fs/nfsd/nfs4state.c +++ b/fs/nfsd/nfs4state.c | |||
@@ -2495,18 +2495,8 @@ nfsd4_process_open1(struct nfsd4_compound_state *cstate, | |||
2495 | open->op_stateowner = NULL; | 2495 | open->op_stateowner = NULL; |
2496 | goto renew; | 2496 | goto renew; |
2497 | } | 2497 | } |
2498 | if (open->op_seqid == sop->so_seqid - 1) { | 2498 | if (open->op_seqid == sop->so_seqid - 1) |
2499 | if (sop->so_replay.rp_buflen) | 2499 | return nfserr_replay_me; |
2500 | return nfserr_replay_me; | ||
2501 | /* The original OPEN failed so spectacularly | ||
2502 | * that we don't even have replay data saved! | ||
2503 | * Therefore, we have no choice but to continue | ||
2504 | * processing this OPEN; presumably, we'll | ||
2505 | * fail again for the same reason. | ||
2506 | */ | ||
2507 | dprintk("nfsd4_process_open1: replay with no replay cache\n"); | ||
2508 | goto renew; | ||
2509 | } | ||
2510 | if (open->op_seqid != sop->so_seqid) | 2500 | if (open->op_seqid != sop->so_seqid) |
2511 | return nfserr_bad_seqid; | 2501 | return nfserr_bad_seqid; |
2512 | renew: | 2502 | renew: |