summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorArtur Grabowski <art@cvs.openbsd.org>2002-08-11 22:32:32 +0000
committerArtur Grabowski <art@cvs.openbsd.org>2002-08-11 22:32:32 +0000
commitbbd5a4a5fd801f5262250bf5798f6897f255c43f (patch)
tree4c11a801b2ff9d7b57792189b95ce7cded13edf2 /sys
parentda14b392e8e586b4676863b9058147aea49bc9f7 (diff)
Add two missing vfs_busy calls in the failure path of sysctl_vnode.
Found by aaron@ NOTE - I think we need a mount-point iterator just like we have NOTE - vfs_mount_foreach_vnode. (btw. why don't we use foreach_vnode in here?)
Diffstat (limited to 'sys')
-rw-r--r--sys/kern/vfs_subr.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/sys/kern/vfs_subr.c b/sys/kern/vfs_subr.c
index 3f70cc8ad1d..88978dd0c2e 100644
--- a/sys/kern/vfs_subr.c
+++ b/sys/kern/vfs_subr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: vfs_subr.c,v 1.87 2002/07/12 14:02:22 art Exp $ */
+/* $OpenBSD: vfs_subr.c,v 1.88 2002/08/11 22:32:31 art Exp $ */
/* $NetBSD: vfs_subr.c,v 1.53 1996/04/22 01:39:13 christos Exp $ */
/*
@@ -1469,6 +1469,7 @@ again:
if (bp + sizeof(struct e_vnode) > ewhere) {
simple_unlock(&mntvnode_slock);
*sizep = bp - where;
+ vfs_unbusy(mp, p);
return (ENOMEM);
}
if ((error = copyout((caddr_t)&vp,
@@ -1476,8 +1477,10 @@ again:
sizeof(struct vnode *))) ||
(error = copyout((caddr_t)vp,
&((struct e_vnode *)bp)->vnode,
- sizeof(struct vnode))))
+ sizeof(struct vnode)))) {
+ vfs_unbusy(mp, p);
return (error);
+ }
bp += sizeof(struct e_vnode);
simple_lock(&mntvnode_slock);
}