diff options
Diffstat (limited to 'sys/fs/nfsserver/nfs_nfsdport.c')
| -rw-r--r-- | sys/fs/nfsserver/nfs_nfsdport.c | 25 | 
1 files changed, 13 insertions, 12 deletions
| diff --git a/sys/fs/nfsserver/nfs_nfsdport.c b/sys/fs/nfsserver/nfs_nfsdport.c index b2966934f9b7..9fe3f4426124 100644 --- a/sys/fs/nfsserver/nfs_nfsdport.c +++ b/sys/fs/nfsserver/nfs_nfsdport.c @@ -675,7 +675,7 @@ nfsvno_namei(struct nfsrv_descript *nd, struct nameidata *ndp,  	}  	if (islocked)  		NFSVOPUNLOCK(dp); -	VREF(dp); +	vref(dp);  	*retdirp = dp;  	if (NFSVNO_EXRDONLY(exp))  		cnp->cn_flags |= RDONLY; @@ -697,7 +697,7 @@ nfsvno_namei(struct nfsrv_descript *nd, struct nameidata *ndp,  				goto out;  			}  			dp = rootvnode; -			VREF(dp); +			vref(dp);  		}  	} else if ((nfsrv_enable_crossmntpt == 0 && NFSVNO_EXPORTED(exp)) ||  	    (nd->nd_flag & ND_NFSV4) == 0) { @@ -814,7 +814,7 @@ nfsvno_namei(struct nfsrv_descript *nd, struct nameidata *ndp,  		if (cnp->cn_pnbuf[0] == '/') {  			vrele(ndp->ni_dvp);  			ndp->ni_dvp = ndp->ni_rootdir; -			VREF(ndp->ni_dvp); +			vref(ndp->ni_dvp);  		}  		ndp->ni_startdir = ndp->ni_dvp;  		ndp->ni_dvp = NULL; @@ -2607,6 +2607,7 @@ again:  	 * rpc reply  	 */  	if (siz == 0) { +ateof:  		vput(vp);  		if (nd->nd_flag & ND_NFSV3)  			nfsrv_postopattr(nd, getret, &at); @@ -2648,6 +2649,8 @@ again:  		ncookies--;  	}  	if (cpos >= cend || ncookies == 0) { +		if (eofflag != 0) +			goto ateof;  		siz = fullsiz;  		toff = off;  		goto again; @@ -3190,7 +3193,8 @@ nfsv4_sattr(struct nfsrv_descript *nd, vnode_t vp, struct nfsvattr *nvap,  		bitpos = NFSATTRBIT_MAX;  	} else {  		bitpos = 0; -		if (NFSISSET_ATTRBIT(attrbitp, NFSATTRBIT_HIDDEN) || +		if (NFSISSET_ATTRBIT(attrbitp, NFSATTRBIT_ARCHIVE) || +		    NFSISSET_ATTRBIT(attrbitp, NFSATTRBIT_HIDDEN) ||  		    NFSISSET_ATTRBIT(attrbitp, NFSATTRBIT_SYSTEM))  			nvap->na_flags = 0;  	} @@ -3223,9 +3227,11 @@ nfsv4_sattr(struct nfsrv_descript *nd, vnode_t vp, struct nfsvattr *nvap,  			attrsum += aclsize;  			break;  		case NFSATTRBIT_ARCHIVE: -			NFSM_DISSECT(tl, u_int32_t *, NFSX_UNSIGNED); -			if (!nd->nd_repstat) -				nd->nd_repstat = NFSERR_ATTRNOTSUPP; +			NFSM_DISSECT(tl, uint32_t *, NFSX_UNSIGNED); +			if (nd->nd_repstat == 0) { +				if (*tl == newnfs_true) +					nvap->na_flags |= UF_ARCHIVE; +			}  			attrsum += NFSX_UNSIGNED;  			break;  		case NFSATTRBIT_HIDDEN: @@ -3475,11 +3481,6 @@ nfsd_excred(struct nfsrv_descript *nd, struct nfsexstuff *exp,  		     (nd->nd_flag & ND_AUTHNONE) != 0) {  			nd->nd_cred->cr_uid = credanon->cr_uid;  			nd->nd_cred->cr_gid = credanon->cr_gid; -			/* -			 * 'credanon' is already a 'struct ucred' that was built -			 * internally with calls to crsetgroups_and_egid(), so -			 * we don't need a fallback here. -			 */  			crsetgroups(nd->nd_cred, credanon->cr_ngroups,  			    credanon->cr_groups);  		} else if ((nd->nd_flag & ND_GSS) == 0) { | 
