diff options
author | Artur Grabowski <art@cvs.openbsd.org> | 2001-02-27 08:46:11 +0000 |
---|---|---|
committer | Artur Grabowski <art@cvs.openbsd.org> | 2001-02-27 08:46:11 +0000 |
commit | 68ce2342f8432890c5474826d1c6f61d79bcf3da (patch) | |
tree | a9fbca3de158c75447030318702263fc17839232 | |
parent | 69dbab6810963e296e7ec0142b71fe2cf7318ca7 (diff) |
Instead of doing VOP_ISLOCKED, vn_lock(..LK_RETRY..) we can do vn_lock(..LK_NOWAIT..).
Also, when we fail to get the lock on the vnode we want to sync, push
it ahead one second in time.
XXX - this could lead to some vnodes not being synced for a long time,
but that is better than a panic.
-rw-r--r-- | sys/kern/vfs_sync.c | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/sys/kern/vfs_sync.c b/sys/kern/vfs_sync.c index cb88a051466..3998673834f 100644 --- a/sys/kern/vfs_sync.c +++ b/sys/kern/vfs_sync.c @@ -1,4 +1,4 @@ -/* $OpenBSD: vfs_sync.c,v 1.16 2001/02/24 23:50:00 csapuntz Exp $ */ +/* $OpenBSD: vfs_sync.c,v 1.17 2001/02/27 08:46:10 art Exp $ */ /* * Portions of this code are: @@ -164,12 +164,18 @@ sched_sync(p) syncer_delayno = 0; s = splbio(); while ((vp = LIST_FIRST(slp)) != NULL) { - splx(s); - if (VOP_ISLOCKED(vp) == 0) { - vn_lock(vp, LK_EXCLUSIVE | LK_RETRY, p); - (void) VOP_FSYNC(vp, p->p_ucred, MNT_LAZY, p); - VOP_UNLOCK(vp, 0, p); + if (vn_lock(vp, LK_EXCLUSIVE | LK_NOWAIT, p) != 0) { + /* + * If we fail to get the lock, we move this + * vnode one second ahead in time. + * XXX - no good, but the best we can do. + */ + vn_syncer_add_to_worklist(vp, 1); + continue; } + splx(s); + (void) VOP_FSYNC(vp, p->p_ucred, MNT_LAZY, p); + VOP_UNLOCK(vp, 0, p); s = splbio(); if (LIST_FIRST(slp) == vp) { /* |