summaryrefslogtreecommitdiff
path: root/sys/kern
diff options
context:
space:
mode:
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/vfs_bio.c35
1 files changed, 8 insertions, 27 deletions
diff --git a/sys/kern/vfs_bio.c b/sys/kern/vfs_bio.c
index d97339469ec..efd38401530 100644
--- a/sys/kern/vfs_bio.c
+++ b/sys/kern/vfs_bio.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vfs_bio.c,v 1.42 2001/09/19 18:05:27 art Exp $ */
+/* $OpenBSD: vfs_bio.c,v 1.43 2001/09/20 08:22:26 gluk Exp $ */
/* $NetBSD: vfs_bio.c,v 1.44 1996/06/11 11:15:36 pk Exp $ */
/*-
@@ -544,20 +544,6 @@ brelse(bp)
if (ISSET(bp->b_flags, (B_NOCACHE|B_ERROR)))
SET(bp->b_flags, B_INVAL);
- if (ISSET(bp->b_flags, B_VFLUSH)) {
- /*
- * This is a delayed write buffer that was just flushed to
- * disk. It is still on the DIRTY queue. If it's become
- * invalid, then we need to move it to a different queue;
- * If buffer was redirtied (because it has dependencies),
- * leave it in its current position.
- */
- CLR(bp->b_flags, B_VFLUSH);
- if (!ISSET(bp->b_flags, B_ERROR|B_INVAL|B_LOCKED|B_AGE))
- goto already_queued;
- bremfree(bp);
- }
-
if ((bp->b_bufsize <= 0) || ISSET(bp->b_flags, B_INVAL)) {
/*
* If it's invalid or empty, dissociate it from its vnode
@@ -608,7 +594,6 @@ brelse(bp)
binstailfree(bp, bufq);
}
-already_queued:
/* Unlock the buffer. */
CLR(bp->b_flags, (B_AGE | B_ASYNC | B_BUSY | B_NOCACHE | B_DEFERRED));
@@ -948,7 +933,7 @@ void
buf_daemon(struct proc *p)
{
int s;
- struct buf *bp, *nbp;
+ struct buf *bp;
struct timeval starttime, timediff;
flusherproc = curproc;
@@ -960,23 +945,20 @@ buf_daemon(struct proc *p)
starttime = time;
s = splbio();
- for (bp = TAILQ_FIRST(&bufqueues[BQ_DIRTY]); bp; bp = nbp) {
- nbp = TAILQ_NEXT(bp, b_freelist);
- if (ISSET(bp->b_flags, B_VFLUSH))
- continue;
+ while ((bp = TAILQ_FIRST(&bufqueues[BQ_DIRTY]))) {
bremfree(bp);
SET(bp->b_flags, B_BUSY);
splx(s);
-#ifdef DIAGNOSTIC
- if (!ISSET(bp->b_flags, B_DELWRI))
- panic("Clean buffer on BQ_DIRTY");
-#endif
+
if (ISSET(bp->b_flags, B_INVAL)) {
brelse(bp);
s = splbio();
continue;
}
-
+#ifdef DIAGNOSTIC
+ if (!ISSET(bp->b_flags, B_DELWRI))
+ panic("Clean buffer on BQ_DIRTY");
+#endif
if (LIST_FIRST(&bp->b_dep) != NULL &&
!ISSET(bp->b_flags, B_DEFERRED) &&
buf_countdeps(bp, 0, 1)) {
@@ -998,7 +980,6 @@ buf_daemon(struct proc *p)
break;
s = splbio();
- nbp = TAILQ_FIRST(&bufqueues[BQ_DIRTY]);
}
}
}