summaryrefslogtreecommitdiffstats
path: root/sys/ufs/ffs
diff options
context:
space:
mode:
authorkib <kib@FreeBSD.org>2009-07-02 18:02:55 +0000
committerkib <kib@FreeBSD.org>2009-07-02 18:02:55 +0000
commit350f96b4bfb4f448e5d1daefbab2238552c76cf9 (patch)
tree1d1f89470a093cacfe161f84e5ec9c2a86b5abab /sys/ufs/ffs
parent9055b3da210645c5201faab9905fe4b81baab9a8 (diff)
downloadFreeBSD-src-350f96b4bfb4f448e5d1daefbab2238552c76cf9.zip
FreeBSD-src-350f96b4bfb4f448e5d1daefbab2238552c76cf9.tar.gz
In vn_vget_ino() and their inline equivalents, mnt_ref() the mount point
around the sequence that drop vnode lock and then busies the mount point. Not having vlocked node or direct reference to the mp allows for the forced unmount to proceed, making mp unmounted or reused. Tested by: pho Reviewed by: jeff Approved by: re (kensmith) MFC after: 2 weeks
Diffstat (limited to 'sys/ufs/ffs')
-rw-r--r--sys/ufs/ffs/ffs_softdep.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/sys/ufs/ffs/ffs_softdep.c b/sys/ufs/ffs/ffs_softdep.c
index d7b8818..72522b2 100644
--- a/sys/ufs/ffs/ffs_softdep.c
+++ b/sys/ufs/ffs/ffs_softdep.c
@@ -5104,9 +5104,11 @@ softdep_fsync(vp)
FFSV_FORCEINSMQ)) {
error = vfs_busy(mp, MBF_NOWAIT);
if (error != 0) {
+ vfs_ref(mp);
VOP_UNLOCK(vp, 0);
error = vfs_busy(mp, 0);
vn_lock(vp, LK_EXCLUSIVE | LK_RETRY);
+ vfs_rel(mp);
if (error != 0)
return (ENOENT);
if (vp->v_iflag & VI_DOOMED) {
OpenPOWER on IntegriCloud