svn commit: r260240 - stable/10/sys/kern
Konstantin Belousov
kib at FreeBSD.org
Fri Jan 3 20:02:31 UTC 2014
Author: kib
Date: Fri Jan 3 20:02:30 2014
New Revision: 260240
URL: http://svnweb.freebsd.org/changeset/base/260240
Log:
MFC r259953:
Fix accounting for the negative cache entries when reusing v_cache_dd.
Modified:
stable/10/sys/kern/vfs_cache.c
Directory Properties:
stable/10/ (props changed)
Modified: stable/10/sys/kern/vfs_cache.c
==============================================================================
--- stable/10/sys/kern/vfs_cache.c Fri Jan 3 19:31:40 2014 (r260239)
+++ stable/10/sys/kern/vfs_cache.c Fri Jan 3 20:02:30 2014 (r260240)
@@ -749,16 +749,20 @@ cache_enter_time(dvp, vp, cnp, tsp, dtsp
ncp->nc_flag & NCF_ISDOTDOT) {
KASSERT(ncp->nc_dvp == dvp,
("wrong isdotdot parent"));
- if (ncp->nc_vp != NULL)
+ if (ncp->nc_vp != NULL) {
TAILQ_REMOVE(&ncp->nc_vp->v_cache_dst,
ncp, nc_dst);
- else
+ } else {
TAILQ_REMOVE(&ncneg, ncp, nc_dst);
- if (vp != NULL)
+ numneg--;
+ }
+ if (vp != NULL) {
TAILQ_INSERT_HEAD(&vp->v_cache_dst,
ncp, nc_dst);
- else
+ } else {
TAILQ_INSERT_TAIL(&ncneg, ncp, nc_dst);
+ numneg++;
+ }
ncp->nc_vp = vp;
CACHE_WUNLOCK();
return;
@@ -894,6 +898,8 @@ cache_enter_time(dvp, vp, cnp, tsp, dtsp
}
if (numneg * ncnegfactor > numcache) {
ncp = TAILQ_FIRST(&ncneg);
+ KASSERT(ncp->nc_vp == NULL, ("ncp %p vp %p on ncneg",
+ ncp, ncp->nc_vp));
zap = 1;
}
if (hold)
More information about the svn-src-stable-10
mailing list