diff options
author | J. Bruce Fields <bfields@redhat.com> | 2013-04-01 16:37:12 -0400 |
---|---|---|
committer | J. Bruce Fields <bfields@redhat.com> | 2013-04-08 09:55:32 -0400 |
commit | 9411b1d4c7df26dca6bc6261b5dc87a5b4c81e5c (patch) | |
tree | 43fe6d0f9e83740f0b2e7b4691b3fb374c03fd17 /fs/nfsd/nfs4proc.c | |
parent | 41d22663cb6a4108091c050cba3c470a3e175dd9 (diff) | |
download | lwn-9411b1d4c7df26dca6bc6261b5dc87a5b4c81e5c.tar.gz lwn-9411b1d4c7df26dca6bc6261b5dc87a5b4c81e5c.zip |
nfsd4: cleanup handling of nfsv4.0 closed stateid's
Closed stateid's are kept around a little while to handle close replays
in the 4.0 case. So we stash them in the last-used stateid in the
oo_last_closed_stateid field of the open owner. We can free that in
encode_seqid_op_tail once the seqid on the open owner is next
incremented. But we don't want to do that on the close itself; so we
set NFS4_OO_PURGE_CLOSE flag set on the open owner, skip freeing it the
first time through encode_seqid_op_tail, then when we see that flag set
next time we free it.
This is unnecessarily baroque.
Instead, just move the logic that increments the seqid out of the xdr
code and into the operation code itself.
The justification given for the current placement is that we need to
wait till the last minute to be sure we know whether the status is a
sequence-id-mutating error or not, but examination of the code shows
that can't actually happen.
Reported-by: Yanchuan Nian <ycnian@gmail.com>
Tested-by: Yanchuan Nian <ycnian@gmail.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
Diffstat (limited to 'fs/nfsd/nfs4proc.c')
-rw-r--r-- | fs/nfsd/nfs4proc.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/fs/nfsd/nfs4proc.c b/fs/nfsd/nfs4proc.c index a9b707b23858..609e1e211330 100644 --- a/fs/nfsd/nfs4proc.c +++ b/fs/nfsd/nfs4proc.c @@ -415,7 +415,8 @@ out: nfsd4_cleanup_open_state(open, status); if (open->op_openowner) cstate->replay_owner = &open->op_openowner->oo_owner; - else + nfsd4_bump_seqid(cstate, status); + if (!cstate->replay_owner) nfs4_unlock_state(); return status; } |