Lines Matching refs:exp

29 	struct svc_export *exp = expv;  in nfsd_acceptable()  local
34 if (exp->ex_flags & NFSEXP_NOSUBTREECHECK) in nfsd_acceptable()
38 while (tdentry != exp->ex_path.dentry && !IS_ROOT(tdentry)) { in nfsd_acceptable()
50 if (tdentry != exp->ex_path.dentry) in nfsd_acceptable()
52 rv = (tdentry == exp->ex_path.dentry); in nfsd_acceptable()
101 struct svc_export *exp) in nfsd_setuser_and_check_port() argument
103 int flags = nfsexp_flags(rqstp, exp); in nfsd_setuser_and_check_port()
114 return nfserrno(nfsd_setuser(rqstp, exp)); in nfsd_setuser_and_check_port()
118 struct dentry *dentry, struct svc_export *exp) in check_pseudo_root() argument
120 if (!(exp->ex_flags & NFSEXP_V4ROOT)) in check_pseudo_root()
142 if (unlikely(dentry != exp->ex_path.dentry)) in check_pseudo_root()
156 struct svc_export *exp; in nfsd_set_fh_dentry() local
195 exp = rqst_exp_find(rqstp, fh->fh_fsid_type, fh->fh_fsid); in nfsd_set_fh_dentry()
208 exp = rqst_exp_find(rqstp, FSID_DEV, tfh); in nfsd_set_fh_dentry()
212 if (PTR_ERR(exp) == -ENOENT) in nfsd_set_fh_dentry()
215 if (IS_ERR(exp)) in nfsd_set_fh_dentry()
216 return nfserrno(PTR_ERR(exp)); in nfsd_set_fh_dentry()
218 if (exp->ex_flags & NFSEXP_NOSUBTREECHECK) { in nfsd_set_fh_dentry()
239 error = nfsd_setuser_and_check_port(rqstp, exp); in nfsd_set_fh_dentry()
265 dentry = dget(exp->ex_path.dentry); in nfsd_set_fh_dentry()
267 dentry = exportfs_decode_fh(exp->ex_path.mnt, fid, in nfsd_set_fh_dentry()
269 nfsd_acceptable, exp); in nfsd_set_fh_dentry()
286 fhp->fh_export = exp; in nfsd_set_fh_dentry()
289 exp_put(exp); in nfsd_set_fh_dentry()
323 struct svc_export *exp; in fh_verify() local
335 exp = fhp->fh_export; in fh_verify()
352 error = check_pseudo_root(rqstp, dentry, exp); in fh_verify()
356 error = nfsd_setuser_and_check_port(rqstp, exp); in fh_verify()
377 && exp->ex_path.dentry == dentry) in fh_verify()
380 error = check_nfsd_access(exp, rqstp); in fh_verify()
386 error = nfsd_permission(rqstp, exp, dentry, access); in fh_verify()
408 static void _fh_update(struct svc_fh *fhp, struct svc_export *exp, in _fh_update() argument
411 if (dentry != exp->ex_path.dentry) { in _fh_update()
415 int subtreecheck = !(exp->ex_flags & NFSEXP_NOSUBTREECHECK); in _fh_update()
429 struct svc_export *exp, in _fh_update_old() argument
435 (exp->ex_flags & NFSEXP_NOSUBTREECHECK)) in _fh_update_old()
439 static bool is_root_export(struct svc_export *exp) in is_root_export() argument
441 return exp->ex_path.dentry == exp->ex_path.dentry->d_sb->s_root; in is_root_export()
444 static struct super_block *exp_sb(struct svc_export *exp) in exp_sb() argument
446 return exp->ex_path.dentry->d_sb; in exp_sb()
449 static bool fsid_type_ok_for_exp(u8 fsid_type, struct svc_export *exp) in fsid_type_ok_for_exp() argument
453 if (!old_valid_dev(exp_sb(exp)->s_dev)) in fsid_type_ok_for_exp()
458 return exp_sb(exp)->s_type->fs_flags & FS_REQUIRES_DEV; in fsid_type_ok_for_exp()
460 return exp->ex_flags & NFSEXP_FSID; in fsid_type_ok_for_exp()
463 if (!is_root_export(exp)) in fsid_type_ok_for_exp()
468 return exp->ex_uuid != NULL; in fsid_type_ok_for_exp()
474 static void set_version_and_fsid_type(struct svc_fh *fhp, struct svc_export *exp, struct svc_fh *re… in set_version_and_fsid_type() argument
480 if (ref_fh && ref_fh->fh_export == exp) { in set_version_and_fsid_type()
502 if (!fsid_type_ok_for_exp(fsid_type, exp)) in set_version_and_fsid_type()
504 } else if (exp->ex_flags & NFSEXP_FSID) { in set_version_and_fsid_type()
506 } else if (exp->ex_uuid) { in set_version_and_fsid_type()
508 if (is_root_export(exp)) in set_version_and_fsid_type()
513 if (is_root_export(exp)) in set_version_and_fsid_type()
518 } else if (!old_valid_dev(exp_sb(exp)->s_dev)) in set_version_and_fsid_type()
529 fh_compose(struct svc_fh *fhp, struct svc_export *exp, struct dentry *dentry, in fh_compose() argument
541 dev_t ex_dev = exp_sb(exp)->s_dev; in fh_compose()
545 (long) d_inode(exp->ex_path.dentry)->i_ino, in fh_compose()
553 set_version_and_fsid_type(fhp, exp, ref_fh); in fh_compose()
568 fhp->fh_export = exp_get(exp); in fh_compose()
578 ino_t_to_u32(d_inode(exp->ex_path.dentry)->i_ino); in fh_compose()
581 _fh_update_old(dentry, exp, &fhp->fh_handle); in fh_compose()
590 d_inode(exp->ex_path.dentry)->i_ino, in fh_compose()
591 exp->ex_fsid, exp->ex_uuid); in fh_compose()
594 _fh_update(fhp, exp, dentry); in fh_compose()
646 struct svc_export * exp = fhp->fh_export; in fh_put() local
654 if (exp) { in fh_put()
655 exp_put(exp); in fh_put()