From dea6593d6c5edb11052948c458e94a8408c78ecf Mon Sep 17 00:00:00 2001 From: Grigoriy Orlov Date: Tue, 13 Mar 2001 18:17:26 +0000 Subject: correct softdep integration error, add missed lock; --- sys/ufs/ffs/ffs_vfsops.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'sys') diff --git a/sys/ufs/ffs/ffs_vfsops.c b/sys/ufs/ffs/ffs_vfsops.c index e50422b6862..d6af1f605ca 100644 --- a/sys/ufs/ffs/ffs_vfsops.c +++ b/sys/ufs/ffs/ffs_vfsops.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ffs_vfsops.c,v 1.30 2001/02/21 23:24:31 csapuntz Exp $ */ +/* $OpenBSD: ffs_vfsops.c,v 1.31 2001/03/13 18:17:25 gluk Exp $ */ /* $NetBSD: ffs_vfsops.c,v 1.19 1996/02/09 22:22:26 christos Exp $ */ /* @@ -924,11 +924,13 @@ loop: * Force stale file system control information to be flushed. */ if ((ump->um_mountp->mnt_flag & MNT_SOFTDEP) && waitfor == MNT_WAIT) { - if ((error == softdep_flushworklist(ump->um_mountp, &count, p)) - != 0) + if ((error = softdep_flushworklist(ump->um_mountp, &count, p))) allerror = error; - if (count) + /* Flushed work items may create new vnodes to clean */ + if (count) { + simple_lock(&mntvnode_slock); goto loop; + } } if (waitfor != MNT_LAZY) { if (ump->um_mountp->mnt_flag & MNT_SOFTDEP) -- cgit v1.2.3