diff options
author | jeff <jeff@FreeBSD.org> | 2003-02-09 12:28:51 +0000 |
---|---|---|
committer | jeff <jeff@FreeBSD.org> | 2003-02-09 12:28:51 +0000 |
commit | 079aa5230a8f11e8fcbefd553378cb8423fbb77d (patch) | |
tree | 3dcafe5e95d23b0186e38262e1ea727f84d144d2 /sys | |
parent | 528cceebc448225964e94119b7b8d18a422d984c (diff) | |
download | FreeBSD-src-079aa5230a8f11e8fcbefd553378cb8423fbb77d.zip FreeBSD-src-079aa5230a8f11e8fcbefd553378cb8423fbb77d.tar.gz |
- Use the new vop_stdfsync instead of recreating our own.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/gnu/ext2fs/ext2_vnops.c | 52 | ||||
-rw-r--r-- | sys/gnu/fs/ext2fs/ext2_vnops.c | 52 |
2 files changed, 6 insertions, 98 deletions
diff --git a/sys/gnu/ext2fs/ext2_vnops.c b/sys/gnu/ext2fs/ext2_vnops.c index 9d17f59..e030b7c 100644 --- a/sys/gnu/ext2fs/ext2_vnops.c +++ b/sys/gnu/ext2fs/ext2_vnops.c @@ -674,59 +674,13 @@ ext2_fsync(ap) struct thread *a_td; } */ *ap; { - struct vnode *vp = ap->a_vp; - struct buf *bp; - struct buf *nbp; - int s; - - /* - * XXX why is all this fs specific? - */ - /* * Flush all dirty buffers associated with a vnode. */ - ext2_discard_prealloc(VTOI(vp)); + ext2_discard_prealloc(VTOI(ap->a_vp)); + + vop_stdfsync(ap); -loop: - VI_LOCK(vp); - s = splbio(); - for (bp = TAILQ_FIRST(&vp->v_dirtyblkhd); bp; bp = nbp) { - nbp = TAILQ_NEXT(bp, b_vnbufs); - VI_UNLOCK(vp); - if (BUF_LOCK(bp, LK_EXCLUSIVE | LK_NOWAIT)) { - VI_LOCK(vp); - continue; - } - if ((bp->b_flags & B_DELWRI) == 0) - panic("ext2_fsync: not dirty"); - bremfree(bp); - splx(s); - /* - * Wait for I/O associated with indirect blocks to complete, - * since there is no way to quickly wait for them below. - */ - if (bp->b_vp == vp || ap->a_waitfor == MNT_NOWAIT) - (void) bawrite(bp); - else - (void) bwrite(bp); - goto loop; - } - if (ap->a_waitfor == MNT_WAIT) { - while (vp->v_numoutput) { - vp->v_iflag |= VI_BWAIT; - msleep(&vp->v_numoutput, VI_MTX(vp), - PRIBIO + 1, "e2fsyn", 0); - } -#if DIAGNOSTIC - if (!TAILQ_EMPTY(&vp->v_dirtyblkhd)) { - vprint("ext2_fsync: dirty", vp); - goto loop; - } -#endif - } - VI_UNLOCK(vp); - splx(s); return (ext2_update(ap->a_vp, ap->a_waitfor == MNT_WAIT)); } diff --git a/sys/gnu/fs/ext2fs/ext2_vnops.c b/sys/gnu/fs/ext2fs/ext2_vnops.c index 9d17f59..e030b7c 100644 --- a/sys/gnu/fs/ext2fs/ext2_vnops.c +++ b/sys/gnu/fs/ext2fs/ext2_vnops.c @@ -674,59 +674,13 @@ ext2_fsync(ap) struct thread *a_td; } */ *ap; { - struct vnode *vp = ap->a_vp; - struct buf *bp; - struct buf *nbp; - int s; - - /* - * XXX why is all this fs specific? - */ - /* * Flush all dirty buffers associated with a vnode. */ - ext2_discard_prealloc(VTOI(vp)); + ext2_discard_prealloc(VTOI(ap->a_vp)); + + vop_stdfsync(ap); -loop: - VI_LOCK(vp); - s = splbio(); - for (bp = TAILQ_FIRST(&vp->v_dirtyblkhd); bp; bp = nbp) { - nbp = TAILQ_NEXT(bp, b_vnbufs); - VI_UNLOCK(vp); - if (BUF_LOCK(bp, LK_EXCLUSIVE | LK_NOWAIT)) { - VI_LOCK(vp); - continue; - } - if ((bp->b_flags & B_DELWRI) == 0) - panic("ext2_fsync: not dirty"); - bremfree(bp); - splx(s); - /* - * Wait for I/O associated with indirect blocks to complete, - * since there is no way to quickly wait for them below. - */ - if (bp->b_vp == vp || ap->a_waitfor == MNT_NOWAIT) - (void) bawrite(bp); - else - (void) bwrite(bp); - goto loop; - } - if (ap->a_waitfor == MNT_WAIT) { - while (vp->v_numoutput) { - vp->v_iflag |= VI_BWAIT; - msleep(&vp->v_numoutput, VI_MTX(vp), - PRIBIO + 1, "e2fsyn", 0); - } -#if DIAGNOSTIC - if (!TAILQ_EMPTY(&vp->v_dirtyblkhd)) { - vprint("ext2_fsync: dirty", vp); - goto loop; - } -#endif - } - VI_UNLOCK(vp); - splx(s); return (ext2_update(ap->a_vp, ap->a_waitfor == MNT_WAIT)); } |