From 94ddc7076d38c1ddbea48dda096b2a34e64f17e6 Mon Sep 17 00:00:00 2001 From: Alan Cox Date: Fri, 3 Sep 2004 05:11:32 +0000 Subject: Push Giant deep into vm_forkproc(), acquiring it only if the process has mapped System V shared memory segments (see shmfork_myhook()) or requires the allocation of an ldt (see vm_fault_wire()). --- sys/vm/vm_fault.c | 4 ++++ 1 file changed, 4 insertions(+) (limited to 'sys/vm/vm_fault.c') diff --git a/sys/vm/vm_fault.c b/sys/vm/vm_fault.c index b6e8b521726d..16f8272c0e90 100644 --- a/sys/vm/vm_fault.c +++ b/sys/vm/vm_fault.c @@ -1026,9 +1026,13 @@ vm_fault_wire(vm_map_t map, vm_offset_t start, vm_offset_t end, * read-only sections. */ for (va = start; va < end; va += PAGE_SIZE) { + if (map->system_map) + mtx_lock(&Giant); rv = vm_fault(map, va, user_wire ? VM_PROT_READ : VM_PROT_READ | VM_PROT_WRITE, user_wire ? VM_FAULT_USER_WIRE : VM_FAULT_CHANGE_WIRING); + if (map->system_map) + mtx_unlock(&Giant); if (rv) { if (va != start) vm_fault_unwire(map, start, va, fictitious); -- cgit v1.2.3