Lines Matching refs:opendata
1877 static struct nfs4_state *nfs4_try_open_cached(struct nfs4_opendata *opendata) in nfs4_try_open_cached() argument
1879 struct nfs4_state *state = opendata->state; in nfs4_try_open_cached()
1881 int open_mode = opendata->o_arg.open_flags; in nfs4_try_open_cached()
1882 fmode_t fmode = opendata->o_arg.fmode; in nfs4_try_open_cached()
1883 enum open_claim_type4 claim = opendata->o_arg.claim; in nfs4_try_open_cached()
1904 nfs_release_seqid(opendata->o_arg.seqid); in nfs4_try_open_cached()
1905 if (!opendata->is_recover) { in nfs4_try_open_cached()
2117 struct nfs4_opendata *opendata; in nfs4_open_recoverdata_alloc() local
2119 opendata = nfs4_opendata_alloc(ctx->dentry, state->owner, 0, 0, in nfs4_open_recoverdata_alloc()
2121 if (opendata == NULL) in nfs4_open_recoverdata_alloc()
2123 opendata->state = state; in nfs4_open_recoverdata_alloc()
2125 return opendata; in nfs4_open_recoverdata_alloc()
2128 static int nfs4_open_recover_helper(struct nfs4_opendata *opendata, in nfs4_open_recover_helper() argument
2134 if (!nfs4_mode_match_open_stateid(opendata->state, fmode)) in nfs4_open_recover_helper()
2136 opendata->o_arg.open_flags = 0; in nfs4_open_recover_helper()
2137 opendata->o_arg.fmode = fmode; in nfs4_open_recover_helper()
2138 opendata->o_arg.share_access = nfs4_map_atomic_open_share( in nfs4_open_recover_helper()
2139 NFS_SB(opendata->dentry->d_sb), in nfs4_open_recover_helper()
2141 memset(&opendata->o_res, 0, sizeof(opendata->o_res)); in nfs4_open_recover_helper()
2142 memset(&opendata->c_res, 0, sizeof(opendata->c_res)); in nfs4_open_recover_helper()
2143 nfs4_init_opendata_res(opendata); in nfs4_open_recover_helper()
2144 ret = _nfs4_recover_proc_open(opendata); in nfs4_open_recover_helper()
2147 newstate = nfs4_opendata_to_nfs4_state(opendata); in nfs4_open_recover_helper()
2150 if (newstate != opendata->state) in nfs4_open_recover_helper()
2156 static int nfs4_open_recover(struct nfs4_opendata *opendata, struct nfs4_state *state) in nfs4_open_recover() argument
2162 ret = nfs4_open_recover_helper(opendata, FMODE_READ|FMODE_WRITE); in nfs4_open_recover()
2165 ret = nfs4_open_recover_helper(opendata, FMODE_WRITE); in nfs4_open_recover()
2168 ret = nfs4_open_recover_helper(opendata, FMODE_READ); in nfs4_open_recover()
2192 struct nfs4_opendata *opendata; in _nfs4_do_open_reclaim() local
2196 opendata = nfs4_open_recoverdata_alloc(ctx, state, in _nfs4_do_open_reclaim()
2198 if (IS_ERR(opendata)) in _nfs4_do_open_reclaim()
2199 return PTR_ERR(opendata); in _nfs4_do_open_reclaim()
2205 opendata->o_arg.u.delegation_type = delegation_type; in _nfs4_do_open_reclaim()
2206 status = nfs4_open_recover(opendata, state); in _nfs4_do_open_reclaim()
2207 nfs4_opendata_put(opendata); in _nfs4_do_open_reclaim()
2302 struct nfs4_opendata *opendata; in nfs4_open_delegation_recall() local
2305 opendata = nfs4_open_recoverdata_alloc(ctx, state, in nfs4_open_delegation_recall()
2307 if (IS_ERR(opendata)) in nfs4_open_delegation_recall()
2308 return PTR_ERR(opendata); in nfs4_open_delegation_recall()
2309 nfs4_stateid_copy(&opendata->o_arg.u.delegation, stateid); in nfs4_open_delegation_recall()
2311 err = nfs4_open_recover_helper(opendata, FMODE_READ|FMODE_WRITE); in nfs4_open_delegation_recall()
2316 err = nfs4_open_recover_helper(opendata, FMODE_WRITE); in nfs4_open_delegation_recall()
2321 err = nfs4_open_recover_helper(opendata, FMODE_READ); in nfs4_open_delegation_recall()
2327 nfs4_opendata_put(opendata); in nfs4_open_delegation_recall()
2627 struct nfs4_opendata *opendata, in nfs4_opendata_access() argument
2636 if (opendata->o_res.access_supported == 0) in nfs4_opendata_access()
2650 } else if ((fmode & FMODE_READ) && !opendata->file_created) in nfs4_opendata_access()
2653 nfs_access_set_mask(&cache, opendata->o_res.access_result); in nfs4_opendata_access()
2719 struct nfs4_opendata *opendata; in _nfs4_open_expired() local
2722 opendata = nfs4_open_recoverdata_alloc(ctx, state, in _nfs4_open_expired()
2724 if (IS_ERR(opendata)) in _nfs4_open_expired()
2725 return PTR_ERR(opendata); in _nfs4_open_expired()
2726 ret = nfs4_open_recover(opendata, state); in _nfs4_open_expired()
2729 nfs4_opendata_put(opendata); in _nfs4_open_expired()
2990 static unsigned nfs4_exclusive_attrset(struct nfs4_opendata *opendata, in nfs4_exclusive_attrset() argument
2993 const __u32 *bitmask = opendata->o_arg.server->exclcreat_bitmask; in nfs4_exclusive_attrset()
2999 attrset[i] = opendata->o_res.attrset[i]; in nfs4_exclusive_attrset()
3000 if (opendata->o_arg.createmode == NFS4_CREATE_EXCLUSIVE4_1) in nfs4_exclusive_attrset()
3004 ret = (opendata->o_arg.createmode == NFS4_CREATE_EXCLUSIVE) ? in nfs4_exclusive_attrset()
3026 static int _nfs4_open_and_get_state(struct nfs4_opendata *opendata, in _nfs4_open_and_get_state() argument
3029 struct nfs4_state_owner *sp = opendata->owner; in _nfs4_open_and_get_state()
3034 struct inode *dir = d_inode(opendata->dir); in _nfs4_open_and_get_state()
3042 ret = _nfs4_proc_open(opendata, ctx); in _nfs4_open_and_get_state()
3046 state = _nfs4_opendata_to_nfs4_state(opendata); in _nfs4_open_and_get_state()
3053 if (opendata->o_res.rflags & NFS4_OPEN_RESULT_MAY_NOTIFY_LOCK) in _nfs4_open_and_get_state()
3055 if (opendata->o_res.rflags & NFS4_OPEN_RESULT_PRESERVE_UNLINKED) in _nfs4_open_and_get_state()
3058 dentry = opendata->dentry; in _nfs4_open_and_get_state()
3072 switch(opendata->o_arg.claim) { in _nfs4_open_and_get_state()
3078 if (!opendata->rpc_done) in _nfs4_open_and_get_state()
3080 if (opendata->o_res.delegation_type != 0) in _nfs4_open_and_get_state()
3086 pnfs_parse_lgopen(state->inode, opendata->lgp, ctx); in _nfs4_open_and_get_state()
3088 ret = nfs4_opendata_access(sp->so_cred, opendata, state, in _nfs4_open_and_get_state()
3100 if (!opendata->cancelled) { in _nfs4_open_and_get_state()
3101 if (opendata->lgp) { in _nfs4_open_and_get_state()
3102 nfs4_lgopen_release(opendata->lgp); in _nfs4_open_and_get_state()
3103 opendata->lgp = NULL; in _nfs4_open_and_get_state()
3105 nfs4_sequence_free_slot(&opendata->o_res.seq_res); in _nfs4_open_and_get_state()
3122 struct nfs4_opendata *opendata; in _nfs4_do_open() local
3147 opendata = nfs4_opendata_alloc(dentry, sp, fmode, flags, in _nfs4_do_open()
3149 if (opendata == NULL) in _nfs4_do_open()
3153 if (!opendata->f_attr.mdsthreshold) { in _nfs4_do_open()
3154 opendata->f_attr.mdsthreshold = pnfs_mdsthreshold_alloc(); in _nfs4_do_open()
3155 if (!opendata->f_attr.mdsthreshold) in _nfs4_do_open()
3158 opendata->o_arg.open_bitmap = &nfs4_pnfs_open_bitmap[0]; in _nfs4_do_open()
3161 opendata->state = nfs4_get_open_state(d_inode(dentry), sp); in _nfs4_do_open()
3163 status = _nfs4_open_and_get_state(opendata, flags, ctx); in _nfs4_do_open()
3168 if ((opendata->o_arg.open_flags & (O_CREAT|O_EXCL)) == (O_CREAT|O_EXCL) && in _nfs4_do_open()
3169 (opendata->o_arg.createmode != NFS4_CREATE_GUARDED)) { in _nfs4_do_open()
3170 unsigned attrs = nfs4_exclusive_attrset(opendata, sattr, &label); in _nfs4_do_open()
3179 nfs_fattr_init(opendata->o_res.f_attr); in _nfs4_do_open()
3181 opendata->o_res.f_attr, sattr, in _nfs4_do_open()
3185 opendata->o_res.f_attr); in _nfs4_do_open()
3186 nfs_setsecurity(state->inode, opendata->o_res.f_attr); in _nfs4_do_open()
3191 if (opened && opendata->file_created) in _nfs4_do_open()
3194 if (pnfs_use_threshold(ctx_th, opendata->f_attr.mdsthreshold, server)) { in _nfs4_do_open()
3195 *ctx_th = opendata->f_attr.mdsthreshold; in _nfs4_do_open()
3196 opendata->f_attr.mdsthreshold = NULL; in _nfs4_do_open()
3199 nfs4_opendata_put(opendata); in _nfs4_do_open()
3203 nfs4_opendata_put(opendata); in _nfs4_do_open()