Re: panic: No NCF_TS

From: John Baldwin <jhb_at_freebsd.org>
Date: Wed, 25 Jan 2012 13:35:43 -0500
On Wednesday, January 25, 2012 7:15:28 am Kostik Belousov wrote:
> diff --git a/sys/fs/nfsclient/nfs_clvnops.c b/sys/fs/nfsclient/nfs_clvnops.c
> index 2747191..709cd8d 100644
> --- a/sys/fs/nfsclient/nfs_clvnops.c
> +++ b/sys/fs/nfsclient/nfs_clvnops.c
> _at__at_ -1431,8 +1431,6 _at__at_ nfs_mknodrpc(struct vnode *dvp, struct vnode **vpp, 
struct componentname *cnp,
>  		}
>  	}
>  	if (!error) {
> -		if ((cnp->cn_flags & MAKEENTRY))
> -			cache_enter(dvp, newvp, cnp);
>  		*vpp = newvp;
>  	} else if (NFS_ISV4(dvp)) {
>  		error = nfscl_maperr(cnp->cn_thread, error, vap->va_uid,

This is good.

> _at__at_ -1591,7 +1589,7 _at__at_ again:
>  	}
>  	if (!error) {
>  		if (cnp->cn_flags & MAKEENTRY)
> -			cache_enter(dvp, newvp, cnp);
> +			cache_enter_time(dvp, newvp, cnp, &vap->va_ctime);
>  		*ap->a_vpp = newvp;
>  	} else if (NFS_ISV4(dvp)) {
>  		error = nfscl_maperr(cnp->cn_thread, error, vap->va_uid,

This should use the post-op attrs instead.  Maybe this:

	if (cnp->cn_flags & MAKEENTRY && attrflag)
		cache_enter_time(dvp, newvp, cnp, &nfsva.na_ctime);

> _at__at_ -1966,8 +1964,9 _at__at_ nfs_link(struct vop_link_args *ap)
>  	 * must care about lookup caching hit rate, so...
>  	 */
>  	if (VFSTONFS(vp->v_mount)->nm_negnametimeo != 0 &&
> -	    (cnp->cn_flags & MAKEENTRY))
> -		cache_enter(tdvp, vp, cnp);
> +	    (cnp->cn_flags & MAKEENTRY) && dattrflag) {
> +		cache_enter_time(tdvp, vp, cnp, &dnfsva.na_mtime);
> +	}
>  	if (error && NFS_ISV4(vp))
>  		error = nfscl_maperr(cnp->cn_thread, error, (uid_t)0,
>  		    (gid_t)0);

Looks good.

> _at__at_ -2023,15 +2022,6 _at__at_ nfs_symlink(struct vop_symlink_args *ap)
>  			error = nfscl_maperr(cnp->cn_thread, error,
>  			    vap->va_uid, vap->va_gid);
>  	} else {
> -		/*
> -		 * If negative lookup caching is enabled, I might as well
> -		 * add an entry for this node. Not necessary for correctness,
> -		 * but if negative caching is enabled, then the system
> -		 * must care about lookup caching hit rate, so...
> -		 */
> -		if (VFSTONFS(dvp->v_mount)->nm_negnametimeo != 0 &&
> -		    (cnp->cn_flags & MAKEENTRY))
> -			cache_enter(dvp, newvp, cnp);
>  		*ap->a_vpp = newvp;
>  	}
> _at__at_ -2041,6 +2031,16 _at__at_ nfs_symlink(struct vop_symlink_args *ap)
>  	if (dattrflag != 0) {
>  		mtx_unlock(&dnp->n_mtx);
>  		(void) nfscl_loadattrcache(&dvp, &dnfsva, NULL, NULL, 0, 1);
> +		/*
> +		 * If negative lookup caching is enabled, I might as well
> +		 * add an entry for this node. Not necessary for correctness,
> +		 * but if negative caching is enabled, then the system
> +		 * must care about lookup caching hit rate, so...
> +		 */
> +		if (VFSTONFS(dvp->v_mount)->nm_negnametimeo != 0 &&
> +		    (cnp->cn_flags & MAKEENTRY)) {
> +			cache_enter_time(dvp, newvp, cnp, &dnfsva.na_mtime);
> +		}
>  	} else {
>  		dnp->n_attrstamp = 0;
>  		mtx_unlock(&dnp->n_mtx);

Good.

> _at__at_ -2116,8 +2116,9 _at__at_ nfs_mkdir(struct vop_mkdir_args *ap)
>  		 * must care about lookup caching hit rate, so...
>  		 */
>  		if (VFSTONFS(dvp->v_mount)->nm_negnametimeo != 0 &&
> -		    (cnp->cn_flags & MAKEENTRY))
> -			cache_enter(dvp, newvp, cnp);
> +		    (cnp->cn_flags & MAKEENTRY) && dattrflag) {
> +			cache_enter_time(dvp, newvp, cnp, &dnfsva.na_mtime);
> +		}
>  		*ap->a_vpp = newvp;
>  	}
>  	return (error);

Correct (I'm still not sure it is really best to be adding these
extra entries, but that's a separate issue).

> diff --git a/sys/kern/vfs_cache.c b/sys/kern/vfs_cache.c
> index 647dcac..4562ebc 100644
> --- a/sys/kern/vfs_cache.c
> +++ b/sys/kern/vfs_cache.c
> _at__at_ -237,13 +237,9 _at__at_ static void
>  cache_out_ts(struct namecache *ncp, struct timespec *tsp, int *ticksp)
>  {
>  
> -	if ((ncp->nc_flag & NCF_TS) == 0) {
> -		if (tsp != NULL)
> -			bzero(tsp, sizeof(*tsp));
> -		if (ticksp != NULL)
> -			*ticksp = 0;
> -		return;
> -	}
> +	KASSERT((ncp->nc_flag & NCF_TS) != 0 ||
> +	    (tsp == NULL && ticksp == NULL),
> +	    ("No NCF_TS"));
>  
>  	if (tsp != NULL)
>  		*tsp = ((struct namecache_ts *)ncp)->nc_time;
> _at__at_ -791,8 +787,8 _at__at_ cache_enter_time(dvp, vp, cnp, tsp)
>  		    n2->nc_nlen == cnp->cn_namelen &&
>  		    !bcmp(nc_get_name(n2), cnp->cn_nameptr, n2->nc_nlen)) {
>  			if (tsp != NULL) {
> -				if ((n2->nc_flag & NCF_TS) == 0)
> -					continue;
> +				KASSERT((n2->nc_flag & NCF_TS) != 0,
> +				    ("no NCF_TS"));
>  				n3 = (struct namecache_ts *)n2;
>  				n3->nc_time =
>  				    ((struct namecache_ts *)ncp)->nc_time;

Good.

> diff --git a/sys/nfsclient/nfs_vnops.c b/sys/nfsclient/nfs_vnops.c
> index a39b29b..c2dfd97 100644
> --- a/sys/nfsclient/nfs_vnops.c
> +++ b/sys/nfsclient/nfs_vnops.c
> _at__at_ -1530,8 +1530,6 _at__at_ nfsmout:
>  		if (newvp)
>  			vput(newvp);
>  	} else {
> -		if (cnp->cn_flags & MAKEENTRY)
> -			cache_enter(dvp, newvp, cnp);
>  		*vpp = newvp;
>  	}
>  	mtx_lock(&(VTONFS(dvp))->n_mtx);
> _at__at_ -1670,8 +1668,6 _at__at_ nfsmout:
>  			vput(newvp);
>  	}
>  	if (!error) {
> -		if (cnp->cn_flags & MAKEENTRY)
> -			cache_enter(dvp, newvp, cnp);
>  		*ap->a_vpp = newvp;
>  	}
>  	mtx_lock(&(VTONFS(dvp))->n_mtx);

This is fine.  If we really cared about these, we could add a variant of 
nfsm_wcc_data() that returned the post-op attributes, but it's not really 
worth doing I think.

-- 
John Baldwin
Received on Wed Jan 25 2012 - 17:35:44 UTC

This archive was generated by hypermail 2.4.0 : Wed May 19 2021 - 11:40:23 UTC