diff options
author | phk <phk@FreeBSD.org> | 2004-10-25 09:14:03 +0000 |
---|---|---|
committer | phk <phk@FreeBSD.org> | 2004-10-25 09:14:03 +0000 |
commit | 0e87ab8bc6e542c845f82c2bb526208587b200ad (patch) | |
tree | 200ff5f062ab8c134c56e5c8d6bd7fb2f35f6bad /sys/kern/vfs_default.c | |
parent | 100e94e682f93c8aeae0f6683f1adab50f67b1f7 (diff) | |
download | FreeBSD-src-0e87ab8bc6e542c845f82c2bb526208587b200ad.zip FreeBSD-src-0e87ab8bc6e542c845f82c2bb526208587b200ad.tar.gz |
Loose the v_dirty* and v_clean* alias macros.
Check the count field where we just want to know the full/empty state,
rather than using TAILQ_EMPTY() or TAILQ_FIRST().
Diffstat (limited to 'sys/kern/vfs_default.c')
-rw-r--r-- | sys/kern/vfs_default.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/sys/kern/vfs_default.c b/sys/kern/vfs_default.c index 72e03bf..0f77900 100644 --- a/sys/kern/vfs_default.c +++ b/sys/kern/vfs_default.c @@ -550,7 +550,7 @@ loop1: * MARK/SCAN initialization to avoid infinite loops. */ s = splbio(); - TAILQ_FOREACH(bp, &vp->v_dirtyblkhd, b_bobufs) { + TAILQ_FOREACH(bp, &vp->v_bufobj.bo_dirty.bv_hd, b_bobufs) { bp->b_vflags &= ~BV_SCANNED; bp->b_error = 0; } @@ -561,8 +561,7 @@ loop1: */ loop2: s = splbio(); - for (bp = TAILQ_FIRST(&vp->v_dirtyblkhd); bp != NULL; bp = nbp) { - nbp = TAILQ_NEXT(bp, b_bobufs); + TAILQ_FOREACH_SAFE(bp, &vp->v_bufobj.bo_dirty.bv_hd, b_bobufs, nbp) { if ((bp->b_vflags & BV_SCANNED) != 0) continue; bp->b_vflags |= BV_SCANNED; @@ -724,7 +723,7 @@ loop: MNT_VNODE_FOREACH(vp, mp, nvp) { VI_LOCK(vp); - if (TAILQ_EMPTY(&vp->v_dirtyblkhd)) { + if (vp->v_bufobj.bo_dirty.bv_cnt == 0) { VI_UNLOCK(vp); continue; } |