diff options
author | J. Bruce Fields <bfields@citi.umich.edu> | 2006-01-18 20:43:19 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-01-18 22:20:24 -0500 |
commit | 3a65588adc4401622b204caa897123e16a4a0318 (patch) | |
tree | a96a8d4a28608b49440062273c70565c1129165d /fs/nfsd | |
parent | 8a280510852959c0d51b1d625e90c0491c238368 (diff) |
[PATCH] nfsd4: rename lk_stateowner
One of the things that's confusing about nfsd4_lock is that the lk_stateowner
field could be set to either of two different lockowners: the open owner or
the lock owner. Rename to lk_replay_owner and add a comment to make it clear
that it's used for whichever stateowner has its sequence id bumped for replay
detection.
Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
Signed-off-by: Neil Brown <neilb@suse.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'fs/nfsd')
-rw-r--r-- | fs/nfsd/nfs4state.c | 16 | ||||
-rw-r--r-- | fs/nfsd/nfs4xdr.c | 5 |
2 files changed, 10 insertions, 11 deletions
diff --git a/fs/nfsd/nfs4state.c b/fs/nfsd/nfs4state.c index 5bf7fd3947ce..578ea521c827 100644 --- a/fs/nfsd/nfs4state.c +++ b/fs/nfsd/nfs4state.c | |||
@@ -2725,11 +2725,11 @@ nfsd4_lock(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nfsd4_lock | |||
2725 | lock->lk_new_open_seqid, | 2725 | lock->lk_new_open_seqid, |
2726 | &lock->lk_new_open_stateid, | 2726 | &lock->lk_new_open_stateid, |
2727 | CHECK_FH | OPEN_STATE, | 2727 | CHECK_FH | OPEN_STATE, |
2728 | &lock->lk_stateowner, &open_stp, | 2728 | &lock->lk_replay_owner, &open_stp, |
2729 | lock); | 2729 | lock); |
2730 | if (status) | 2730 | if (status) |
2731 | goto out; | 2731 | goto out; |
2732 | open_sop = lock->lk_stateowner; | 2732 | open_sop = lock->lk_replay_owner; |
2733 | /* create lockowner and lock stateid */ | 2733 | /* create lockowner and lock stateid */ |
2734 | fp = open_stp->st_file; | 2734 | fp = open_stp->st_file; |
2735 | strhashval = lock_ownerstr_hashval(fp->fi_inode, | 2735 | strhashval = lock_ownerstr_hashval(fp->fi_inode, |
@@ -2752,12 +2752,12 @@ nfsd4_lock(struct svc_rqst *rqstp, struct svc_fh *current_fh, struct nfsd4_lock | |||
2752 | lock->lk_old_lock_seqid, | 2752 | lock->lk_old_lock_seqid, |
2753 | &lock->lk_old_lock_stateid, | 2753 | &lock->lk_old_lock_stateid, |
2754 | CHECK_FH | LOCK_STATE, | 2754 | CHECK_FH | LOCK_STATE, |
2755 | &lock->lk_stateowner, &lock_stp, lock); | 2755 | &lock->lk_replay_owner, &lock_stp, lock); |
2756 | if (status) | 2756 | if (status) |
2757 | goto out; | 2757 | goto out; |
2758 | lock_sop = lock->lk_stateowner; | 2758 | lock_sop = lock->lk_replay_owner; |
2759 | } | 2759 | } |
2760 | /* lock->lk_stateowner and lock_stp have been created or found */ | 2760 | /* lock->lk_replay_owner and lock_stp have been created or found */ |
2761 | filp = lock_stp->st_vfs_file; | 2761 | filp = lock_stp->st_vfs_file; |
2762 | 2762 | ||
2763 | status = nfserr_grace; | 2763 | status = nfserr_grace; |
@@ -2830,9 +2830,9 @@ conflicting_lock: | |||
2830 | out: | 2830 | out: |
2831 | if (status && lock->lk_is_new && lock_sop) | 2831 | if (status && lock->lk_is_new && lock_sop) |
2832 | release_stateowner(lock_sop); | 2832 | release_stateowner(lock_sop); |
2833 | if (lock->lk_stateowner) { | 2833 | if (lock->lk_replay_owner) { |
2834 | nfs4_get_stateowner(lock->lk_stateowner); | 2834 | nfs4_get_stateowner(lock->lk_replay_owner); |
2835 | *replay_owner = lock->lk_stateowner; | 2835 | *replay_owner = lock->lk_replay_owner; |
2836 | } | 2836 | } |
2837 | nfs4_unlock_state(); | 2837 | nfs4_unlock_state(); |
2838 | return status; | 2838 | return status; |
diff --git a/fs/nfsd/nfs4xdr.c b/fs/nfsd/nfs4xdr.c index dcd673186944..6b743327686c 100644 --- a/fs/nfsd/nfs4xdr.c +++ b/fs/nfsd/nfs4xdr.c | |||
@@ -528,7 +528,7 @@ nfsd4_decode_lock(struct nfsd4_compoundargs *argp, struct nfsd4_lock *lock) | |||
528 | { | 528 | { |
529 | DECODE_HEAD; | 529 | DECODE_HEAD; |
530 | 530 | ||
531 | lock->lk_stateowner = NULL; | 531 | lock->lk_replay_owner = NULL; |
532 | /* | 532 | /* |
533 | * type, reclaim(boolean), offset, length, new_lock_owner(boolean) | 533 | * type, reclaim(boolean), offset, length, new_lock_owner(boolean) |
534 | */ | 534 | */ |
@@ -1895,7 +1895,6 @@ nfsd4_encode_lock_denied(struct nfsd4_compoundres *resp, struct nfsd4_lock_denie | |||
1895 | static void | 1895 | static void |
1896 | nfsd4_encode_lock(struct nfsd4_compoundres *resp, int nfserr, struct nfsd4_lock *lock) | 1896 | nfsd4_encode_lock(struct nfsd4_compoundres *resp, int nfserr, struct nfsd4_lock *lock) |
1897 | { | 1897 | { |
1898 | |||
1899 | ENCODE_SEQID_OP_HEAD; | 1898 | ENCODE_SEQID_OP_HEAD; |
1900 | 1899 | ||
1901 | if (!nfserr) { | 1900 | if (!nfserr) { |
@@ -1906,7 +1905,7 @@ nfsd4_encode_lock(struct nfsd4_compoundres *resp, int nfserr, struct nfsd4_lock | |||
1906 | } else if (nfserr == nfserr_denied) | 1905 | } else if (nfserr == nfserr_denied) |
1907 | nfsd4_encode_lock_denied(resp, &lock->lk_denied); | 1906 | nfsd4_encode_lock_denied(resp, &lock->lk_denied); |
1908 | 1907 | ||
1909 | ENCODE_SEQID_OP_TAIL(lock->lk_stateowner); | 1908 | ENCODE_SEQID_OP_TAIL(lock->lk_replay_owner); |
1910 | } | 1909 | } |
1911 | 1910 | ||
1912 | static void | 1911 | static void |