summaryrefslogtreecommitdiffstats
path: root/sys/vm
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2003-12-08 00:47:33 +0000
committeralc <alc@FreeBSD.org>2003-12-08 00:47:33 +0000
commit672d48f582ee28a50650e63f90c182d45e4cae58 (patch)
tree3eac928f2d0c276035b5ca35616a05afff6871ef /sys/vm
parent161c19f0ba5e5a9bc385cd8e1fa343ff992d1266 (diff)
downloadFreeBSD-src-672d48f582ee28a50650e63f90c182d45e4cae58.zip
FreeBSD-src-672d48f582ee28a50650e63f90c182d45e4cae58.tar.gz
Addendum to revision 1.174: In the case where vm_pager_allocate() is called
to create a vnode-backed object, the vnode lock must be held by the caller. Reported by: truckman Discussed with: kan
Diffstat (limited to 'sys/vm')
-rw-r--r--sys/vm/vm_mmap.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/sys/vm/vm_mmap.c b/sys/vm/vm_mmap.c
index c210a8d..987318d 100644
--- a/sys/vm/vm_mmap.c
+++ b/sys/vm/vm_mmap.c
@@ -1223,6 +1223,8 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
if (vp->v_type == VCHR) {
type = OBJT_DEVICE;
handle = vp->v_rdev;
+ vput(vp);
+ mtx_unlock(&Giant);
} else {
struct vattr vat;
@@ -1242,8 +1244,6 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
flags |= MAP_NOSYNC;
}
}
- vput(vp);
- mtx_unlock(&Giant);
}
if (handle == NULL) {
@@ -1252,6 +1252,10 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
} else {
object = vm_pager_allocate(type,
handle, objsize, prot, foff);
+ if (type == OBJT_VNODE) {
+ vput(vp);
+ mtx_unlock(&Giant);
+ }
if (object == NULL) {
return (type == OBJT_DEVICE ? EINVAL : ENOMEM);
}
OpenPOWER on IntegriCloud