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.c26
1 files changed, 20 insertions, 6 deletions
diff --git a/sys/kern/vfs_subr.c b/sys/kern/vfs_subr.c
index 1e1150a044b..bf376248b66 100644
--- a/sys/kern/vfs_subr.c
+++ b/sys/kern/vfs_subr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vfs_subr.c,v 1.106 2004/12/28 15:14:37 deraadt Exp $ */
+/* $OpenBSD: vfs_subr.c,v 1.107 2004/12/31 12:13:53 pedro Exp $ */
/* $NetBSD: vfs_subr.c,v 1.53 1996/04/22 01:39:13 christos Exp $ */
/*
@@ -796,11 +796,16 @@ vput(vp)
panic("vput: v_writecount != 0");
}
#endif
- vputonfreelist(vp);
-
simple_unlock(&vp->v_interlock);
VOP_INACTIVE(vp, p);
+
+ simple_lock(&vp->v_interlock);
+
+ if (vp->v_usecount == 0)
+ vputonfreelist(vp);
+
+ simple_unlock(&vp->v_interlock);
}
/*
@@ -836,10 +841,19 @@ vrele(vp)
panic("vrele: v_writecount != 0");
}
#endif
- vputonfreelist(vp);
+ if (vn_lock(vp, LK_EXCLUSIVE|LK_INTERLOCK, p)) {
+ vprint("vrele: cannot lock", vp);
+ return;
+ }
- if (vn_lock(vp, LK_EXCLUSIVE|LK_INTERLOCK, p) == 0)
- VOP_INACTIVE(vp, p);
+ VOP_INACTIVE(vp, p);
+
+ simple_lock(&vp->v_interlock);
+
+ if (vp->v_usecount == 0)
+ vputonfreelist(vp);
+
+ simple_unlock(&vp->v_interlock);
}
void vhold(struct vnode *vp);