summaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2002-06-22 19:13:56 +0000
committeralc <alc@FreeBSD.org>2002-06-22 19:13:56 +0000
commit61c5eca9e37b94d9a93d9a5158d75a7e6cf77a41 (patch)
treea786f5baaae9f5489a278f26984130237de0da38 /sys
parent0af4a7d8da66dacf1d307fa01b5bd13241d44aec (diff)
downloadFreeBSD-src-61c5eca9e37b94d9a93d9a5158d75a7e6cf77a41.zip
FreeBSD-src-61c5eca9e37b94d9a93d9a5158d75a7e6cf77a41.tar.gz
o Reduce the scope of Giant in vm_mmap() to just the code that manipulates
a vnode. (Thus, MAP_ANON and MAP_STACK never acquire Giant.)
Diffstat (limited to 'sys')
-rw-r--r--sys/vm/vm_mmap.c6
1 files changed, 2 insertions, 4 deletions
diff --git a/sys/vm/vm_mmap.c b/sys/vm/vm_mmap.c
index 8b47c87..6af6eb8 100644
--- a/sys/vm/vm_mmap.c
+++ b/sys/vm/vm_mmap.c
@@ -1137,12 +1137,10 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
if ((flags & MAP_FIXED) == 0) {
fitit = TRUE;
*addr = round_page(*addr);
- mtx_lock(&Giant);
} else {
if (*addr != trunc_page(*addr))
return (EINVAL);
fitit = FALSE;
- mtx_lock(&Giant);
(void) vm_map_remove(map, *addr, *addr + size);
}
@@ -1158,6 +1156,7 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
foff = 0;
} else {
vp = (struct vnode *) handle;
+ mtx_lock(&Giant);
if (vp->v_type == VCHR) {
type = OBJT_DEVICE;
handle = (void *)(intptr_t)vp->v_rdev;
@@ -1180,6 +1179,7 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
flags |= MAP_NOSYNC;
}
}
+ mtx_unlock(&Giant);
}
if (handle == NULL) {
@@ -1189,7 +1189,6 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
object = vm_pager_allocate(type,
handle, objsize, prot, foff);
if (object == NULL) {
- mtx_unlock(&Giant);
return (type == OBJT_DEVICE ? EINVAL : ENOMEM);
}
docow = MAP_PREFAULT_PARTIAL;
@@ -1243,7 +1242,6 @@ vm_mmap(vm_map_t map, vm_offset_t *addr, vm_size_t size, vm_prot_t prot,
if (rv != KERN_SUCCESS)
(void) vm_map_remove(map, *addr, *addr + size);
}
- mtx_unlock(&Giant);
switch (rv) {
case KERN_SUCCESS:
return (0);
OpenPOWER on IntegriCloud