diff options
author | Trond Myklebust <Trond.Myklebust@netapp.com> | 2012-03-04 18:13:56 -0500 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2012-03-06 10:32:46 -0500 |
commit | f597c53790f662662281b82b7692a22d2a4d4afa (patch) | |
tree | 3567e1c7e232973fee14b7ddffa3545cd88392d0 | |
parent | 1e3987c3052a48fbfc8f5d30214c825eff41192d (diff) |
NFSv4: Add helpers for basic copying of stateids
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
-rw-r--r-- | fs/nfs/delegation.c | 14 | ||||
-rw-r--r-- | fs/nfs/nfs4_fs.h | 10 | ||||
-rw-r--r-- | fs/nfs/nfs4proc.c | 34 | ||||
-rw-r--r-- | fs/nfs/nfs4state.c | 6 | ||||
-rw-r--r-- | fs/nfs/pnfs.c | 10 |
5 files changed, 38 insertions, 36 deletions
diff --git a/fs/nfs/delegation.c b/fs/nfs/delegation.c index c7249e26e2e9..87f7544f3dce 100644 --- a/fs/nfs/delegation.c +++ b/fs/nfs/delegation.c | |||
@@ -105,7 +105,7 @@ again: | |||
105 | continue; | 105 | continue; |
106 | if (!test_bit(NFS_DELEGATED_STATE, &state->flags)) | 106 | if (!test_bit(NFS_DELEGATED_STATE, &state->flags)) |
107 | continue; | 107 | continue; |
108 | if (memcmp(state->stateid.data, stateid->data, sizeof(state->stateid.data)) != 0) | 108 | if (!nfs4_stateid_match(&state->stateid, stateid)) |
109 | continue; | 109 | continue; |
110 | get_nfs_open_context(ctx); | 110 | get_nfs_open_context(ctx); |
111 | spin_unlock(&inode->i_lock); | 111 | spin_unlock(&inode->i_lock); |
@@ -139,8 +139,7 @@ void nfs_inode_reclaim_delegation(struct inode *inode, struct rpc_cred *cred, | |||
139 | if (delegation != NULL) { | 139 | if (delegation != NULL) { |
140 | spin_lock(&delegation->lock); | 140 | spin_lock(&delegation->lock); |
141 | if (delegation->inode != NULL) { | 141 | if (delegation->inode != NULL) { |
142 | memcpy(delegation->stateid.data, res->delegation.data, | 142 | nfs4_stateid_copy(&delegation->stateid, &res->delegation); |
143 | sizeof(delegation->stateid.data)); | ||
144 | delegation->type = res->delegation_type; | 143 | delegation->type = res->delegation_type; |
145 | delegation->maxsize = res->maxsize; | 144 | delegation->maxsize = res->maxsize; |
146 | oldcred = delegation->cred; | 145 | oldcred = delegation->cred; |
@@ -236,8 +235,7 @@ int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct | |||
236 | delegation = kmalloc(sizeof(*delegation), GFP_NOFS); | 235 | delegation = kmalloc(sizeof(*delegation), GFP_NOFS); |
237 | if (delegation == NULL) | 236 | if (delegation == NULL) |
238 | return -ENOMEM; | 237 | return -ENOMEM; |
239 | memcpy(delegation->stateid.data, res->delegation.data, | 238 | nfs4_stateid_copy(&delegation->stateid, &res->delegation); |
240 | sizeof(delegation->stateid.data)); | ||
241 | delegation->type = res->delegation_type; | 239 | delegation->type = res->delegation_type; |
242 | delegation->maxsize = res->maxsize; | 240 | delegation->maxsize = res->maxsize; |
243 | delegation->change_attr = inode->i_version; | 241 | delegation->change_attr = inode->i_version; |
@@ -250,8 +248,8 @@ int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct | |||
250 | old_delegation = rcu_dereference_protected(nfsi->delegation, | 248 | old_delegation = rcu_dereference_protected(nfsi->delegation, |
251 | lockdep_is_held(&clp->cl_lock)); | 249 | lockdep_is_held(&clp->cl_lock)); |
252 | if (old_delegation != NULL) { | 250 | if (old_delegation != NULL) { |
253 | if (memcmp(&delegation->stateid, &old_delegation->stateid, | 251 | if (nfs4_stateid_match(&delegation->stateid, |
254 | sizeof(old_delegation->stateid)) == 0 && | 252 | &old_delegation->stateid) && |
255 | delegation->type == old_delegation->type) { | 253 | delegation->type == old_delegation->type) { |
256 | goto out; | 254 | goto out; |
257 | } | 255 | } |
@@ -708,7 +706,7 @@ int nfs4_copy_delegation_stateid(nfs4_stateid *dst, struct inode *inode) | |||
708 | rcu_read_lock(); | 706 | rcu_read_lock(); |
709 | delegation = rcu_dereference(nfsi->delegation); | 707 | delegation = rcu_dereference(nfsi->delegation); |
710 | if (delegation != NULL) { | 708 | if (delegation != NULL) { |
711 | memcpy(dst->data, delegation->stateid.data, sizeof(dst->data)); | 709 | nfs4_stateid_copy(dst, &delegation->stateid); |
712 | ret = 1; | 710 | ret = 1; |
713 | } | 711 | } |
714 | rcu_read_unlock(); | 712 | rcu_read_unlock(); |
diff --git a/fs/nfs/nfs4_fs.h b/fs/nfs/nfs4_fs.h index 308d2f999c3d..1c54ef3146d4 100644 --- a/fs/nfs/nfs4_fs.h +++ b/fs/nfs/nfs4_fs.h | |||
@@ -349,6 +349,16 @@ struct nfs4_mount_data; | |||
349 | extern struct svc_version nfs4_callback_version1; | 349 | extern struct svc_version nfs4_callback_version1; |
350 | extern struct svc_version nfs4_callback_version4; | 350 | extern struct svc_version nfs4_callback_version4; |
351 | 351 | ||
352 | static inline void nfs4_stateid_copy(nfs4_stateid *dst, const nfs4_stateid *src) | ||
353 | { | ||
354 | memcpy(dst->data, src->data, sizeof(dst->data)); | ||
355 | } | ||
356 | |||
357 | static inline bool nfs4_stateid_match(const nfs4_stateid *dst, const nfs4_stateid *src) | ||
358 | { | ||
359 | return memcmp(dst->data, src->data, sizeof(dst->data)) == 0; | ||
360 | } | ||
361 | |||
352 | #else | 362 | #else |
353 | 363 | ||
354 | #define nfs4_close_state(a, b) do { } while (0) | 364 | #define nfs4_close_state(a, b) do { } while (0) |
diff --git a/fs/nfs/nfs4proc.c b/fs/nfs/nfs4proc.c index f181c70ea933..ce0ad81dd466 100644 --- a/fs/nfs/nfs4proc.c +++ b/fs/nfs/nfs4proc.c | |||
@@ -941,8 +941,8 @@ static void update_open_stateflags(struct nfs4_state *state, fmode_t fmode) | |||
941 | static void nfs_set_open_stateid_locked(struct nfs4_state *state, nfs4_stateid *stateid, fmode_t fmode) | 941 | static void nfs_set_open_stateid_locked(struct nfs4_state *state, nfs4_stateid *stateid, fmode_t fmode) |
942 | { | 942 | { |
943 | if (test_bit(NFS_DELEGATED_STATE, &state->flags) == 0) | 943 | if (test_bit(NFS_DELEGATED_STATE, &state->flags) == 0) |
944 | memcpy(state->stateid.data, stateid->data, sizeof(state->stateid.data)); | 944 | nfs4_stateid_copy(&state->stateid, stateid); |
945 | memcpy(state->open_stateid.data, stateid->data, sizeof(state->open_stateid.data)); | 945 | nfs4_stateid_copy(&state->open_stateid, stateid); |
946 | switch (fmode) { | 946 | switch (fmode) { |
947 | case FMODE_READ: | 947 | case FMODE_READ: |
948 | set_bit(NFS_O_RDONLY_STATE, &state->flags); | 948 | set_bit(NFS_O_RDONLY_STATE, &state->flags); |
@@ -970,7 +970,7 @@ static void __update_open_stateid(struct nfs4_state *state, nfs4_stateid *open_s | |||
970 | */ | 970 | */ |
971 | write_seqlock(&state->seqlock); | 971 | write_seqlock(&state->seqlock); |
972 | if (deleg_stateid != NULL) { | 972 | if (deleg_stateid != NULL) { |
973 | memcpy(state->stateid.data, deleg_stateid->data, sizeof(state->stateid.data)); | 973 | nfs4_stateid_copy(&state->stateid, deleg_stateid); |
974 | set_bit(NFS_DELEGATED_STATE, &state->flags); | 974 | set_bit(NFS_DELEGATED_STATE, &state->flags); |
975 | } | 975 | } |
976 | if (open_stateid != NULL) | 976 | if (open_stateid != NULL) |
@@ -1001,7 +1001,7 @@ static int update_open_stateid(struct nfs4_state *state, nfs4_stateid *open_stat | |||
1001 | 1001 | ||
1002 | if (delegation == NULL) | 1002 | if (delegation == NULL) |
1003 | delegation = &deleg_cur->stateid; | 1003 | delegation = &deleg_cur->stateid; |
1004 | else if (memcmp(deleg_cur->stateid.data, delegation->data, NFS4_STATEID_SIZE) != 0) | 1004 | else if (!nfs4_stateid_match(&deleg_cur->stateid, delegation)) |
1005 | goto no_delegation_unlock; | 1005 | goto no_delegation_unlock; |
1006 | 1006 | ||
1007 | nfs_mark_delegation_referenced(deleg_cur); | 1007 | nfs_mark_delegation_referenced(deleg_cur); |
@@ -1062,7 +1062,7 @@ static struct nfs4_state *nfs4_try_open_cached(struct nfs4_opendata *opendata) | |||
1062 | break; | 1062 | break; |
1063 | } | 1063 | } |
1064 | /* Save the delegation */ | 1064 | /* Save the delegation */ |
1065 | memcpy(stateid.data, delegation->stateid.data, sizeof(stateid.data)); | 1065 | nfs4_stateid_copy(&stateid, &delegation->stateid); |
1066 | rcu_read_unlock(); | 1066 | rcu_read_unlock(); |
1067 | ret = nfs_may_open(state->inode, state->owner->so_cred, open_mode); | 1067 | ret = nfs_may_open(state->inode, state->owner->so_cred, open_mode); |
1068 | if (ret != 0) | 1068 | if (ret != 0) |
@@ -1225,10 +1225,10 @@ static int nfs4_open_recover(struct nfs4_opendata *opendata, struct nfs4_state * | |||
1225 | * Check if we need to update the current stateid. | 1225 | * Check if we need to update the current stateid. |
1226 | */ | 1226 | */ |
1227 | if (test_bit(NFS_DELEGATED_STATE, &state->flags) == 0 && | 1227 | if (test_bit(NFS_DELEGATED_STATE, &state->flags) == 0 && |
1228 | memcmp(state->stateid.data, state->open_stateid.data, sizeof(state->stateid.data)) != 0) { | 1228 | !nfs4_stateid_match(&state->stateid, &state->open_stateid)) { |
1229 | write_seqlock(&state->seqlock); | 1229 | write_seqlock(&state->seqlock); |
1230 | if (test_bit(NFS_DELEGATED_STATE, &state->flags) == 0) | 1230 | if (test_bit(NFS_DELEGATED_STATE, &state->flags) == 0) |
1231 | memcpy(state->stateid.data, state->open_stateid.data, sizeof(state->stateid.data)); | 1231 | nfs4_stateid_copy(&state->stateid, &state->open_stateid); |
1232 | write_sequnlock(&state->seqlock); | 1232 | write_sequnlock(&state->seqlock); |
1233 | } | 1233 | } |
1234 | return 0; | 1234 | return 0; |
@@ -1297,8 +1297,7 @@ static int _nfs4_open_delegation_recall(struct nfs_open_context *ctx, struct nfs | |||
1297 | if (IS_ERR(opendata)) | 1297 | if (IS_ERR(opendata)) |
1298 | return PTR_ERR(opendata); | 1298 | return PTR_ERR(opendata); |
1299 | opendata->o_arg.claim = NFS4_OPEN_CLAIM_DELEGATE_CUR; | 1299 | opendata->o_arg.claim = NFS4_OPEN_CLAIM_DELEGATE_CUR; |
1300 | memcpy(opendata->o_arg.u.delegation.data, stateid->data, | 1300 | nfs4_stateid_copy(&opendata->o_arg.u.delegation, stateid); |
1301 | sizeof(opendata->o_arg.u.delegation.data)); | ||
1302 | ret = nfs4_open_recover(opendata, state); | 1301 | ret = nfs4_open_recover(opendata, state); |
1303 | nfs4_opendata_put(opendata); | 1302 | nfs4_opendata_put(opendata); |
1304 | return ret; | 1303 | return ret; |
@@ -1363,8 +1362,7 @@ static void nfs4_open_confirm_done(struct rpc_task *task, void *calldata) | |||
1363 | 1362 | ||
1364 | data->rpc_status = task->tk_status; | 1363 | data->rpc_status = task->tk_status; |
1365 | if (data->rpc_status == 0) { | 1364 | if (data->rpc_status == 0) { |
1366 | memcpy(data->o_res.stateid.data, data->c_res.stateid.data, | 1365 | nfs4_stateid_copy(&data->o_res.stateid, &data->c_res.stateid); |
1367 | sizeof(data->o_res.stateid.data)); | ||
1368 | nfs_confirm_seqid(&data->owner->so_seqid, 0); | 1366 | nfs_confirm_seqid(&data->owner->so_seqid, 0); |
1369 | renew_lease(data->o_res.server, data->timestamp); | 1367 | renew_lease(data->o_res.server, data->timestamp); |
1370 | data->rpc_done = 1; | 1368 | data->rpc_done = 1; |
@@ -1924,7 +1922,7 @@ static int _nfs4_do_setattr(struct inode *inode, struct rpc_cred *cred, | |||
1924 | } else if (state != NULL) { | 1922 | } else if (state != NULL) { |
1925 | nfs4_select_rw_stateid(&arg.stateid, state, current->files, current->tgid); | 1923 | nfs4_select_rw_stateid(&arg.stateid, state, current->files, current->tgid); |
1926 | } else | 1924 | } else |
1927 | memcpy(&arg.stateid, &zero_stateid, sizeof(arg.stateid)); | 1925 | nfs4_stateid_copy(&arg.stateid, &zero_stateid); |
1928 | 1926 | ||
1929 | status = nfs4_call_sync(server->client, server, &msg, &arg.seq_args, &res.seq_res, 1); | 1927 | status = nfs4_call_sync(server->client, server, &msg, &arg.seq_args, &res.seq_res, 1); |
1930 | if (status == 0 && state != NULL) | 1928 | if (status == 0 && state != NULL) |
@@ -3989,7 +3987,7 @@ static int _nfs4_proc_delegreturn(struct inode *inode, struct rpc_cred *cred, co | |||
3989 | data->args.stateid = &data->stateid; | 3987 | data->args.stateid = &data->stateid; |
3990 | data->args.bitmask = server->attr_bitmask; | 3988 | data->args.bitmask = server->attr_bitmask; |
3991 | nfs_copy_fh(&data->fh, NFS_FH(inode)); | 3989 | nfs_copy_fh(&data->fh, NFS_FH(inode)); |
3992 | memcpy(&data->stateid, stateid, sizeof(data->stateid)); | 3990 | nfs4_stateid_copy(&data->stateid, stateid); |
3993 | data->res.fattr = &data->fattr; | 3991 | data->res.fattr = &data->fattr; |
3994 | data->res.server = server; | 3992 | data->res.server = server; |
3995 | nfs_fattr_init(data->res.fattr); | 3993 | nfs_fattr_init(data->res.fattr); |
@@ -4172,9 +4170,8 @@ static void nfs4_locku_done(struct rpc_task *task, void *data) | |||
4172 | return; | 4170 | return; |
4173 | switch (task->tk_status) { | 4171 | switch (task->tk_status) { |
4174 | case 0: | 4172 | case 0: |
4175 | memcpy(calldata->lsp->ls_stateid.data, | 4173 | nfs4_stateid_copy(&calldata->lsp->ls_stateid, |
4176 | calldata->res.stateid.data, | 4174 | &calldata->res.stateid); |
4177 | sizeof(calldata->lsp->ls_stateid.data)); | ||
4178 | renew_lease(calldata->server, calldata->timestamp); | 4175 | renew_lease(calldata->server, calldata->timestamp); |
4179 | break; | 4176 | break; |
4180 | case -NFS4ERR_BAD_STATEID: | 4177 | case -NFS4ERR_BAD_STATEID: |
@@ -4387,8 +4384,7 @@ static void nfs4_lock_done(struct rpc_task *task, void *calldata) | |||
4387 | goto out; | 4384 | goto out; |
4388 | } | 4385 | } |
4389 | if (data->rpc_status == 0) { | 4386 | if (data->rpc_status == 0) { |
4390 | memcpy(data->lsp->ls_stateid.data, data->res.stateid.data, | 4387 | nfs4_stateid_copy(&data->lsp->ls_stateid, &data->res.stateid); |
4391 | sizeof(data->lsp->ls_stateid.data)); | ||
4392 | data->lsp->ls_flags |= NFS_LOCK_INITIALIZED; | 4388 | data->lsp->ls_flags |= NFS_LOCK_INITIALIZED; |
4393 | renew_lease(NFS_SERVER(data->ctx->dentry->d_inode), data->timestamp); | 4389 | renew_lease(NFS_SERVER(data->ctx->dentry->d_inode), data->timestamp); |
4394 | } | 4390 | } |
@@ -6292,7 +6288,7 @@ static bool nfs41_match_stateid(const nfs4_stateid *s1, | |||
6292 | static bool nfs4_match_stateid(const nfs4_stateid *s1, | 6288 | static bool nfs4_match_stateid(const nfs4_stateid *s1, |
6293 | const nfs4_stateid *s2) | 6289 | const nfs4_stateid *s2) |
6294 | { | 6290 | { |
6295 | return memcmp(s1->data, s2->data, sizeof(s1->data)) == 0; | 6291 | return nfs4_stateid_match(s1, s2); |
6296 | } | 6292 | } |
6297 | 6293 | ||
6298 | 6294 | ||
diff --git a/fs/nfs/nfs4state.c b/fs/nfs/nfs4state.c index 6ba82271c868..55c8a81cd6fb 100644 --- a/fs/nfs/nfs4state.c +++ b/fs/nfs/nfs4state.c | |||
@@ -895,7 +895,7 @@ void nfs4_select_rw_stateid(nfs4_stateid *dst, struct nfs4_state *state, fl_owne | |||
895 | 895 | ||
896 | do { | 896 | do { |
897 | seq = read_seqbegin(&state->seqlock); | 897 | seq = read_seqbegin(&state->seqlock); |
898 | memcpy(dst, &state->stateid, sizeof(*dst)); | 898 | nfs4_stateid_copy(dst, &state->stateid); |
899 | } while (read_seqretry(&state->seqlock, seq)); | 899 | } while (read_seqretry(&state->seqlock, seq)); |
900 | if (test_bit(LK_STATE_IN_USE, &state->flags) == 0) | 900 | if (test_bit(LK_STATE_IN_USE, &state->flags) == 0) |
901 | return; | 901 | return; |
@@ -903,7 +903,7 @@ void nfs4_select_rw_stateid(nfs4_stateid *dst, struct nfs4_state *state, fl_owne | |||
903 | spin_lock(&state->state_lock); | 903 | spin_lock(&state->state_lock); |
904 | lsp = __nfs4_find_lock_state(state, fl_owner, fl_pid, NFS4_ANY_LOCK_TYPE); | 904 | lsp = __nfs4_find_lock_state(state, fl_owner, fl_pid, NFS4_ANY_LOCK_TYPE); |
905 | if (lsp != NULL && (lsp->ls_flags & NFS_LOCK_INITIALIZED) != 0) | 905 | if (lsp != NULL && (lsp->ls_flags & NFS_LOCK_INITIALIZED) != 0) |
906 | memcpy(dst, &lsp->ls_stateid, sizeof(*dst)); | 906 | nfs4_stateid_copy(dst, &lsp->ls_stateid); |
907 | spin_unlock(&state->state_lock); | 907 | spin_unlock(&state->state_lock); |
908 | nfs4_put_lock_state(lsp); | 908 | nfs4_put_lock_state(lsp); |
909 | } | 909 | } |
@@ -1126,7 +1126,7 @@ void nfs_inode_find_state_and_recover(struct inode *inode, | |||
1126 | continue; | 1126 | continue; |
1127 | if (!test_bit(NFS_DELEGATED_STATE, &state->flags)) | 1127 | if (!test_bit(NFS_DELEGATED_STATE, &state->flags)) |
1128 | continue; | 1128 | continue; |
1129 | if (memcmp(state->stateid.data, stateid->data, sizeof(state->stateid.data)) != 0) | 1129 | if (!nfs4_stateid_match(&state->stateid, stateid)) |
1130 | continue; | 1130 | continue; |
1131 | nfs4_state_mark_reclaim_nograce(clp, state); | 1131 | nfs4_state_mark_reclaim_nograce(clp, state); |
1132 | found = true; | 1132 | found = true; |
diff --git a/fs/nfs/pnfs.c b/fs/nfs/pnfs.c index 402efc2f5b70..c190e9c2e3d2 100644 --- a/fs/nfs/pnfs.c +++ b/fs/nfs/pnfs.c | |||
@@ -499,7 +499,7 @@ pnfs_set_layout_stateid(struct pnfs_layout_hdr *lo, const nfs4_stateid *new, | |||
499 | oldseq = be32_to_cpu(lo->plh_stateid.stateid.seqid); | 499 | oldseq = be32_to_cpu(lo->plh_stateid.stateid.seqid); |
500 | newseq = be32_to_cpu(new->stateid.seqid); | 500 | newseq = be32_to_cpu(new->stateid.seqid); |
501 | if ((int)(newseq - oldseq) > 0) { | 501 | if ((int)(newseq - oldseq) > 0) { |
502 | memcpy(&lo->plh_stateid, &new->stateid, sizeof(new->stateid)); | 502 | nfs4_stateid_copy(&lo->plh_stateid, new); |
503 | if (update_barrier) { | 503 | if (update_barrier) { |
504 | u32 new_barrier = be32_to_cpu(new->stateid.seqid); | 504 | u32 new_barrier = be32_to_cpu(new->stateid.seqid); |
505 | 505 | ||
@@ -549,11 +549,10 @@ pnfs_choose_layoutget_stateid(nfs4_stateid *dst, struct pnfs_layout_hdr *lo, | |||
549 | 549 | ||
550 | do { | 550 | do { |
551 | seq = read_seqbegin(&open_state->seqlock); | 551 | seq = read_seqbegin(&open_state->seqlock); |
552 | memcpy(dst->data, open_state->stateid.data, | 552 | nfs4_stateid_copy(dst, &open_state->stateid); |
553 | sizeof(open_state->stateid.data)); | ||
554 | } while (read_seqretry(&open_state->seqlock, seq)); | 553 | } while (read_seqretry(&open_state->seqlock, seq)); |
555 | } else | 554 | } else |
556 | memcpy(dst->data, lo->plh_stateid.data, sizeof(lo->plh_stateid.data)); | 555 | nfs4_stateid_copy(dst, &lo->plh_stateid); |
557 | spin_unlock(&lo->plh_inode->i_lock); | 556 | spin_unlock(&lo->plh_inode->i_lock); |
558 | dprintk("<-- %s\n", __func__); | 557 | dprintk("<-- %s\n", __func__); |
559 | return status; | 558 | return status; |
@@ -1527,8 +1526,7 @@ pnfs_layoutcommit_inode(struct inode *inode, bool sync) | |||
1527 | end_pos = nfsi->layout->plh_lwb; | 1526 | end_pos = nfsi->layout->plh_lwb; |
1528 | nfsi->layout->plh_lwb = 0; | 1527 | nfsi->layout->plh_lwb = 0; |
1529 | 1528 | ||
1530 | memcpy(&data->args.stateid.data, nfsi->layout->plh_stateid.data, | 1529 | nfs4_stateid_copy(&data->args.stateid, &nfsi->layout->plh_stateid); |
1531 | sizeof(nfsi->layout->plh_stateid.data)); | ||
1532 | spin_unlock(&inode->i_lock); | 1530 | spin_unlock(&inode->i_lock); |
1533 | 1531 | ||
1534 | data->args.inode = inode; | 1532 | data->args.inode = inode; |