diff options
author | Trond Myklebust <Trond.Myklebust@netapp.com> | 2005-10-18 17:20:13 -0400 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2005-10-18 17:20:13 -0400 |
commit | e6dfa553cffcb9740f932311dff42f81d6ac63bb (patch) | |
tree | d5519b749b6a7fb6e25b0459385011cd69a6caaf /fs/nfs/nfs4proc.c | |
parent | 9512135df14f8293b9bc5e8fb22d4279dee5ff66 (diff) |
NFSv4: Remove obsolete state_owner and lock_owner semaphores
OPEN, CLOSE, etc no longer need these semaphores to ensure ordering of
requests.
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'fs/nfs/nfs4proc.c')
-rw-r--r-- | fs/nfs/nfs4proc.c | 18 |
1 files changed, 0 insertions, 18 deletions
diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index 5154ddf6d9a5..25bab6032dfe 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c | |||
@@ -224,7 +224,6 @@ static void update_open_stateid(struct nfs4_state *state, nfs4_stateid *stateid, | |||
224 | /* | 224 | /* |
225 | * OPEN_RECLAIM: | 225 | * OPEN_RECLAIM: |
226 | * reclaim state on the server after a reboot. | 226 | * reclaim state on the server after a reboot. |
227 | * Assumes caller is holding the sp->so_sem | ||
228 | */ | 227 | */ |
229 | static int _nfs4_open_reclaim(struct nfs4_state_owner *sp, struct nfs4_state *state) | 228 | static int _nfs4_open_reclaim(struct nfs4_state_owner *sp, struct nfs4_state *state) |
230 | { | 229 | { |
@@ -322,7 +321,6 @@ static int _nfs4_open_delegation_recall(struct dentry *dentry, struct nfs4_state | |||
322 | }; | 321 | }; |
323 | int status = 0; | 322 | int status = 0; |
324 | 323 | ||
325 | down(&sp->so_sema); | ||
326 | if (!test_bit(NFS_DELEGATED_STATE, &state->flags)) | 324 | if (!test_bit(NFS_DELEGATED_STATE, &state->flags)) |
327 | goto out; | 325 | goto out; |
328 | if (state->state == 0) | 326 | if (state->state == 0) |
@@ -342,7 +340,6 @@ static int _nfs4_open_delegation_recall(struct dentry *dentry, struct nfs4_state | |||
342 | } | 340 | } |
343 | nfs_free_seqid(arg.seqid); | 341 | nfs_free_seqid(arg.seqid); |
344 | out: | 342 | out: |
345 | up(&sp->so_sema); | ||
346 | dput(parent); | 343 | dput(parent); |
347 | return status; | 344 | return status; |
348 | } | 345 | } |
@@ -595,7 +592,6 @@ static int _nfs4_open_delegated(struct inode *inode, int flags, struct rpc_cred | |||
595 | dprintk("%s: nfs4_get_state_owner failed!\n", __FUNCTION__); | 592 | dprintk("%s: nfs4_get_state_owner failed!\n", __FUNCTION__); |
596 | goto out_err; | 593 | goto out_err; |
597 | } | 594 | } |
598 | down(&sp->so_sema); | ||
599 | state = nfs4_get_open_state(inode, sp); | 595 | state = nfs4_get_open_state(inode, sp); |
600 | if (state == NULL) | 596 | if (state == NULL) |
601 | goto out_err; | 597 | goto out_err; |
@@ -620,7 +616,6 @@ static int _nfs4_open_delegated(struct inode *inode, int flags, struct rpc_cred | |||
620 | set_bit(NFS_DELEGATED_STATE, &state->flags); | 616 | set_bit(NFS_DELEGATED_STATE, &state->flags); |
621 | update_open_stateid(state, &delegation->stateid, open_flags); | 617 | update_open_stateid(state, &delegation->stateid, open_flags); |
622 | out_ok: | 618 | out_ok: |
623 | up(&sp->so_sema); | ||
624 | nfs4_put_state_owner(sp); | 619 | nfs4_put_state_owner(sp); |
625 | up_read(&nfsi->rwsem); | 620 | up_read(&nfsi->rwsem); |
626 | up_read(&clp->cl_sem); | 621 | up_read(&clp->cl_sem); |
@@ -631,7 +626,6 @@ out_err: | |||
631 | if (sp != NULL) { | 626 | if (sp != NULL) { |
632 | if (state != NULL) | 627 | if (state != NULL) |
633 | nfs4_put_open_state(state); | 628 | nfs4_put_open_state(state); |
634 | up(&sp->so_sema); | ||
635 | nfs4_put_state_owner(sp); | 629 | nfs4_put_state_owner(sp); |
636 | } | 630 | } |
637 | up_read(&nfsi->rwsem); | 631 | up_read(&nfsi->rwsem); |
@@ -696,7 +690,6 @@ static int _nfs4_do_open(struct inode *dir, struct dentry *dentry, int flags, st | |||
696 | } else | 690 | } else |
697 | o_arg.u.attrs = sattr; | 691 | o_arg.u.attrs = sattr; |
698 | /* Serialization for the sequence id */ | 692 | /* Serialization for the sequence id */ |
699 | down(&sp->so_sema); | ||
700 | 693 | ||
701 | o_arg.seqid = nfs_alloc_seqid(&sp->so_seqid); | 694 | o_arg.seqid = nfs_alloc_seqid(&sp->so_seqid); |
702 | if (o_arg.seqid == NULL) | 695 | if (o_arg.seqid == NULL) |
@@ -716,7 +709,6 @@ static int _nfs4_do_open(struct inode *dir, struct dentry *dentry, int flags, st | |||
716 | if (o_res.delegation_type != 0) | 709 | if (o_res.delegation_type != 0) |
717 | nfs_inode_set_delegation(inode, cred, &o_res); | 710 | nfs_inode_set_delegation(inode, cred, &o_res); |
718 | nfs_free_seqid(o_arg.seqid); | 711 | nfs_free_seqid(o_arg.seqid); |
719 | up(&sp->so_sema); | ||
720 | nfs4_put_state_owner(sp); | 712 | nfs4_put_state_owner(sp); |
721 | up_read(&clp->cl_sem); | 713 | up_read(&clp->cl_sem); |
722 | *res = state; | 714 | *res = state; |
@@ -726,7 +718,6 @@ out_err: | |||
726 | if (state != NULL) | 718 | if (state != NULL) |
727 | nfs4_put_open_state(state); | 719 | nfs4_put_open_state(state); |
728 | nfs_free_seqid(o_arg.seqid); | 720 | nfs_free_seqid(o_arg.seqid); |
729 | up(&sp->so_sema); | ||
730 | nfs4_put_state_owner(sp); | 721 | nfs4_put_state_owner(sp); |
731 | } | 722 | } |
732 | /* Note: clp->cl_sem must be released before nfs4_put_open_state()! */ | 723 | /* Note: clp->cl_sem must be released before nfs4_put_open_state()! */ |
@@ -833,7 +824,6 @@ static void nfs4_free_closedata(struct nfs4_closedata *calldata) | |||
833 | 824 | ||
834 | nfs4_put_open_state(calldata->state); | 825 | nfs4_put_open_state(calldata->state); |
835 | nfs_free_seqid(calldata->arg.seqid); | 826 | nfs_free_seqid(calldata->arg.seqid); |
836 | up(&sp->so_sema); | ||
837 | nfs4_put_state_owner(sp); | 827 | nfs4_put_state_owner(sp); |
838 | up_read(&server->nfs4_state->cl_sem); | 828 | up_read(&server->nfs4_state->cl_sem); |
839 | kfree(calldata); | 829 | kfree(calldata); |
@@ -2702,7 +2692,6 @@ static int _nfs4_proc_getlk(struct nfs4_state *state, int cmd, struct file_lock | |||
2702 | 2692 | ||
2703 | down_read(&clp->cl_sem); | 2693 | down_read(&clp->cl_sem); |
2704 | nlo.clientid = clp->cl_clientid; | 2694 | nlo.clientid = clp->cl_clientid; |
2705 | down(&state->lock_sema); | ||
2706 | status = nfs4_set_lock_state(state, request); | 2695 | status = nfs4_set_lock_state(state, request); |
2707 | if (status != 0) | 2696 | if (status != 0) |
2708 | goto out; | 2697 | goto out; |
@@ -2729,7 +2718,6 @@ static int _nfs4_proc_getlk(struct nfs4_state *state, int cmd, struct file_lock | |||
2729 | status = 0; | 2718 | status = 0; |
2730 | } | 2719 | } |
2731 | out: | 2720 | out: |
2732 | up(&state->lock_sema); | ||
2733 | up_read(&clp->cl_sem); | 2721 | up_read(&clp->cl_sem); |
2734 | return status; | 2722 | return status; |
2735 | } | 2723 | } |
@@ -2791,7 +2779,6 @@ static int _nfs4_proc_unlck(struct nfs4_state *state, int cmd, struct file_lock | |||
2791 | int status; | 2779 | int status; |
2792 | 2780 | ||
2793 | down_read(&clp->cl_sem); | 2781 | down_read(&clp->cl_sem); |
2794 | down(&state->lock_sema); | ||
2795 | status = nfs4_set_lock_state(state, request); | 2782 | status = nfs4_set_lock_state(state, request); |
2796 | if (status != 0) | 2783 | if (status != 0) |
2797 | goto out; | 2784 | goto out; |
@@ -2813,7 +2800,6 @@ static int _nfs4_proc_unlck(struct nfs4_state *state, int cmd, struct file_lock | |||
2813 | sizeof(lsp->ls_stateid.data)); | 2800 | sizeof(lsp->ls_stateid.data)); |
2814 | nfs_free_seqid(luargs.seqid); | 2801 | nfs_free_seqid(luargs.seqid); |
2815 | out: | 2802 | out: |
2816 | up(&state->lock_sema); | ||
2817 | if (status == 0) | 2803 | if (status == 0) |
2818 | do_vfs_lock(request->fl_file, request); | 2804 | do_vfs_lock(request->fl_file, request); |
2819 | up_read(&clp->cl_sem); | 2805 | up_read(&clp->cl_sem); |
@@ -2877,7 +2863,6 @@ static int _nfs4_do_setlk(struct nfs4_state *state, int cmd, struct file_lock *r | |||
2877 | largs.u.open_lock = &otl; | 2863 | largs.u.open_lock = &otl; |
2878 | largs.new_lock_owner = 1; | 2864 | largs.new_lock_owner = 1; |
2879 | arg.u.lock = &largs; | 2865 | arg.u.lock = &largs; |
2880 | down(&owner->so_sema); | ||
2881 | otl.open_seqid = nfs_alloc_seqid(&owner->so_seqid); | 2866 | otl.open_seqid = nfs_alloc_seqid(&owner->so_seqid); |
2882 | if (otl.open_seqid != NULL) { | 2867 | if (otl.open_seqid != NULL) { |
2883 | status = rpc_call_sync(server->client, &msg, RPC_TASK_NOINTR); | 2868 | status = rpc_call_sync(server->client, &msg, RPC_TASK_NOINTR); |
@@ -2885,7 +2870,6 @@ static int _nfs4_do_setlk(struct nfs4_state *state, int cmd, struct file_lock *r | |||
2885 | nfs_increment_open_seqid(status, otl.open_seqid); | 2870 | nfs_increment_open_seqid(status, otl.open_seqid); |
2886 | nfs_free_seqid(otl.open_seqid); | 2871 | nfs_free_seqid(otl.open_seqid); |
2887 | } | 2872 | } |
2888 | up(&owner->so_sema); | ||
2889 | if (status == 0) | 2873 | if (status == 0) |
2890 | nfs_confirm_seqid(&lsp->ls_seqid, 0); | 2874 | nfs_confirm_seqid(&lsp->ls_seqid, 0); |
2891 | } else { | 2875 | } else { |
@@ -2944,11 +2928,9 @@ static int _nfs4_proc_setlk(struct nfs4_state *state, int cmd, struct file_lock | |||
2944 | int status; | 2928 | int status; |
2945 | 2929 | ||
2946 | down_read(&clp->cl_sem); | 2930 | down_read(&clp->cl_sem); |
2947 | down(&state->lock_sema); | ||
2948 | status = nfs4_set_lock_state(state, request); | 2931 | status = nfs4_set_lock_state(state, request); |
2949 | if (status == 0) | 2932 | if (status == 0) |
2950 | status = _nfs4_do_setlk(state, cmd, request, 0); | 2933 | status = _nfs4_do_setlk(state, cmd, request, 0); |
2951 | up(&state->lock_sema); | ||
2952 | if (status == 0) { | 2934 | if (status == 0) { |
2953 | /* Note: we always want to sleep here! */ | 2935 | /* Note: we always want to sleep here! */ |
2954 | request->fl_flags |= FL_SLEEP; | 2936 | request->fl_flags |= FL_SLEEP; |