Lines Matching refs:opendata
1872 static struct nfs4_state *nfs4_try_open_cached(struct nfs4_opendata *opendata) in nfs4_try_open_cached() argument
1874 struct nfs4_state *state = opendata->state; in nfs4_try_open_cached()
1876 int open_mode = opendata->o_arg.open_flags; in nfs4_try_open_cached()
1877 fmode_t fmode = opendata->o_arg.fmode; in nfs4_try_open_cached()
1878 enum open_claim_type4 claim = opendata->o_arg.claim; in nfs4_try_open_cached()
1899 nfs_release_seqid(opendata->o_arg.seqid); in nfs4_try_open_cached()
1900 if (!opendata->is_recover) { in nfs4_try_open_cached()
2112 struct nfs4_opendata *opendata; in nfs4_open_recoverdata_alloc() local
2114 opendata = nfs4_opendata_alloc(ctx->dentry, state->owner, 0, 0, in nfs4_open_recoverdata_alloc()
2116 if (opendata == NULL) in nfs4_open_recoverdata_alloc()
2118 opendata->state = state; in nfs4_open_recoverdata_alloc()
2120 return opendata; in nfs4_open_recoverdata_alloc()
2123 static int nfs4_open_recover_helper(struct nfs4_opendata *opendata, in nfs4_open_recover_helper() argument
2129 if (!nfs4_mode_match_open_stateid(opendata->state, fmode)) in nfs4_open_recover_helper()
2131 opendata->o_arg.open_flags = 0; in nfs4_open_recover_helper()
2132 opendata->o_arg.fmode = fmode; in nfs4_open_recover_helper()
2133 opendata->o_arg.share_access = nfs4_map_atomic_open_share( in nfs4_open_recover_helper()
2134 NFS_SB(opendata->dentry->d_sb), in nfs4_open_recover_helper()
2136 memset(&opendata->o_res, 0, sizeof(opendata->o_res)); in nfs4_open_recover_helper()
2137 memset(&opendata->c_res, 0, sizeof(opendata->c_res)); in nfs4_open_recover_helper()
2138 nfs4_init_opendata_res(opendata); in nfs4_open_recover_helper()
2139 ret = _nfs4_recover_proc_open(opendata); in nfs4_open_recover_helper()
2142 newstate = nfs4_opendata_to_nfs4_state(opendata); in nfs4_open_recover_helper()
2145 if (newstate != opendata->state) in nfs4_open_recover_helper()
2151 static int nfs4_open_recover(struct nfs4_opendata *opendata, struct nfs4_state *state) in nfs4_open_recover() argument
2157 ret = nfs4_open_recover_helper(opendata, FMODE_READ|FMODE_WRITE); in nfs4_open_recover()
2160 ret = nfs4_open_recover_helper(opendata, FMODE_WRITE); in nfs4_open_recover()
2163 ret = nfs4_open_recover_helper(opendata, FMODE_READ); in nfs4_open_recover()
2187 struct nfs4_opendata *opendata; in _nfs4_do_open_reclaim() local
2191 opendata = nfs4_open_recoverdata_alloc(ctx, state, in _nfs4_do_open_reclaim()
2193 if (IS_ERR(opendata)) in _nfs4_do_open_reclaim()
2194 return PTR_ERR(opendata); in _nfs4_do_open_reclaim()
2200 opendata->o_arg.u.delegation_type = delegation_type; in _nfs4_do_open_reclaim()
2201 status = nfs4_open_recover(opendata, state); in _nfs4_do_open_reclaim()
2202 nfs4_opendata_put(opendata); in _nfs4_do_open_reclaim()
2296 struct nfs4_opendata *opendata; in nfs4_open_delegation_recall() local
2299 opendata = nfs4_open_recoverdata_alloc(ctx, state, in nfs4_open_delegation_recall()
2301 if (IS_ERR(opendata)) in nfs4_open_delegation_recall()
2302 return PTR_ERR(opendata); in nfs4_open_delegation_recall()
2303 nfs4_stateid_copy(&opendata->o_arg.u.delegation, stateid); in nfs4_open_delegation_recall()
2305 err = nfs4_open_recover_helper(opendata, FMODE_READ|FMODE_WRITE); in nfs4_open_delegation_recall()
2310 err = nfs4_open_recover_helper(opendata, FMODE_WRITE); in nfs4_open_delegation_recall()
2315 err = nfs4_open_recover_helper(opendata, FMODE_READ); in nfs4_open_delegation_recall()
2321 nfs4_opendata_put(opendata); in nfs4_open_delegation_recall()
2614 struct nfs4_opendata *opendata, in nfs4_opendata_access() argument
2623 if (opendata->o_res.access_supported == 0) in nfs4_opendata_access()
2637 } else if ((fmode & FMODE_READ) && !opendata->file_created) in nfs4_opendata_access()
2641 nfs_access_set_mask(&cache, opendata->o_res.access_result); in nfs4_opendata_access()
2708 struct nfs4_opendata *opendata; in _nfs4_open_expired() local
2711 opendata = nfs4_open_recoverdata_alloc(ctx, state, in _nfs4_open_expired()
2713 if (IS_ERR(opendata)) in _nfs4_open_expired()
2714 return PTR_ERR(opendata); in _nfs4_open_expired()
2715 ret = nfs4_open_recover(opendata, state); in _nfs4_open_expired()
2718 nfs4_opendata_put(opendata); in _nfs4_open_expired()
2979 static unsigned nfs4_exclusive_attrset(struct nfs4_opendata *opendata, in nfs4_exclusive_attrset() argument
2982 const __u32 *bitmask = opendata->o_arg.server->exclcreat_bitmask; in nfs4_exclusive_attrset()
2988 attrset[i] = opendata->o_res.attrset[i]; in nfs4_exclusive_attrset()
2989 if (opendata->o_arg.createmode == NFS4_CREATE_EXCLUSIVE4_1) in nfs4_exclusive_attrset()
2993 ret = (opendata->o_arg.createmode == NFS4_CREATE_EXCLUSIVE) ? in nfs4_exclusive_attrset()
3015 static int _nfs4_open_and_get_state(struct nfs4_opendata *opendata, in _nfs4_open_and_get_state() argument
3018 struct nfs4_state_owner *sp = opendata->owner; in _nfs4_open_and_get_state()
3023 struct inode *dir = d_inode(opendata->dir); in _nfs4_open_and_get_state()
3031 ret = _nfs4_proc_open(opendata, ctx); in _nfs4_open_and_get_state()
3035 state = _nfs4_opendata_to_nfs4_state(opendata); in _nfs4_open_and_get_state()
3042 if (opendata->o_res.rflags & NFS4_OPEN_RESULT_MAY_NOTIFY_LOCK) in _nfs4_open_and_get_state()
3045 dentry = opendata->dentry; in _nfs4_open_and_get_state()
3059 switch(opendata->o_arg.claim) { in _nfs4_open_and_get_state()
3065 if (!opendata->rpc_done) in _nfs4_open_and_get_state()
3067 if (opendata->o_res.delegation_type != 0) in _nfs4_open_and_get_state()
3073 pnfs_parse_lgopen(state->inode, opendata->lgp, ctx); in _nfs4_open_and_get_state()
3075 ret = nfs4_opendata_access(sp->so_cred, opendata, state, in _nfs4_open_and_get_state()
3087 if (!opendata->cancelled) { in _nfs4_open_and_get_state()
3088 if (opendata->lgp) { in _nfs4_open_and_get_state()
3089 nfs4_lgopen_release(opendata->lgp); in _nfs4_open_and_get_state()
3090 opendata->lgp = NULL; in _nfs4_open_and_get_state()
3092 nfs4_sequence_free_slot(&opendata->o_res.seq_res); in _nfs4_open_and_get_state()
3109 struct nfs4_opendata *opendata; in _nfs4_do_open() local
3135 opendata = nfs4_opendata_alloc(dentry, sp, fmode, flags, in _nfs4_do_open()
3137 if (opendata == NULL) in _nfs4_do_open()
3149 if (!opendata->f_attr.mdsthreshold) { in _nfs4_do_open()
3150 opendata->f_attr.mdsthreshold = pnfs_mdsthreshold_alloc(); in _nfs4_do_open()
3151 if (!opendata->f_attr.mdsthreshold) in _nfs4_do_open()
3154 opendata->o_arg.open_bitmap = &nfs4_pnfs_open_bitmap[0]; in _nfs4_do_open()
3157 opendata->state = nfs4_get_open_state(d_inode(dentry), sp); in _nfs4_do_open()
3159 status = _nfs4_open_and_get_state(opendata, flags, ctx); in _nfs4_do_open()
3164 if ((opendata->o_arg.open_flags & (O_CREAT|O_EXCL)) == (O_CREAT|O_EXCL) && in _nfs4_do_open()
3165 (opendata->o_arg.createmode != NFS4_CREATE_GUARDED)) { in _nfs4_do_open()
3166 unsigned attrs = nfs4_exclusive_attrset(opendata, sattr, &label); in _nfs4_do_open()
3175 nfs_fattr_init(opendata->o_res.f_attr); in _nfs4_do_open()
3177 opendata->o_res.f_attr, sattr, in _nfs4_do_open()
3181 opendata->o_res.f_attr); in _nfs4_do_open()
3182 nfs_setsecurity(state->inode, opendata->o_res.f_attr, olabel); in _nfs4_do_open()
3187 if (opened && opendata->file_created) in _nfs4_do_open()
3190 if (pnfs_use_threshold(ctx_th, opendata->f_attr.mdsthreshold, server)) { in _nfs4_do_open()
3191 *ctx_th = opendata->f_attr.mdsthreshold; in _nfs4_do_open()
3192 opendata->f_attr.mdsthreshold = NULL; in _nfs4_do_open()
3197 nfs4_opendata_put(opendata); in _nfs4_do_open()
3203 nfs4_opendata_put(opendata); in _nfs4_do_open()