summaryrefslogtreecommitdiff
path: root/sys/kern/vfs_subr.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/kern/vfs_subr.c')
-rw-r--r--sys/kern/vfs_subr.c43
1 files changed, 15 insertions, 28 deletions
diff --git a/sys/kern/vfs_subr.c b/sys/kern/vfs_subr.c
index 59fd706af2a..dbb9721598a 100644
--- a/sys/kern/vfs_subr.c
+++ b/sys/kern/vfs_subr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vfs_subr.c,v 1.35 1999/03/11 18:55:24 deraadt Exp $ */
+/* $OpenBSD: vfs_subr.c,v 1.36 1999/03/11 19:47:25 deraadt Exp $ */
/* $NetBSD: vfs_subr.c,v 1.53 1996/04/22 01:39:13 christos Exp $ */
/*
@@ -1727,6 +1727,9 @@ vfs_unmountall()
void
vfs_shutdown()
{
+ register struct buf *bp;
+ int iter, nbusy;
+
/* XXX Should suspend scheduling. */
(void) spl0();
@@ -1748,40 +1751,24 @@ vfs_shutdown()
vfs_unmountall();
}
- if (vfs_syncwait(1))
- printf("giving up\n");
- else
- printf("done\n");
-}
-
-/*
- * perform sync() operation and wait for buffers to flush.
- * assumtions: called w/ scheduler disabled and physical io enabled
- * for now called at spl0() XXX
- */
-int
-vfs_syncwait(verbose)
- int verbose;
-{
- register struct buf *bp;
- int iter, nbusy;
-
+ /* Sync again after unmount, just in case. */
sys_sync(&proc0, (void *)0, (register_t *)0);
-
+
/* Wait for sync to finish. */
for (iter = 0; iter < 20; iter++) {
nbusy = 0;
for (bp = &buf[nbuf]; --bp >= buf; )
if ((bp->b_flags & (B_BUSY|B_INVAL)) == B_BUSY)
nbusy++;
- if (nbusy == 0)
- break;
- if (verbose)
- printf("%d ", nbusy);
- DELAY(40000 * iter);
- }
-
- return nbusy;
+ if (nbusy == 0)
+ break;
+ printf("%d ", nbusy);
+ DELAY(40000 * iter);
+ }
+ if (nbusy)
+ printf("giving up\n");
+ else
+ printf("done\n");
}
/*