Path: blob/main/website/static/security/patches/EN-09:05/null6.patch
18096 views
Index: sys/kern/kern_exec.c1===================================================================2--- sys/kern/kern_exec.c (revision 197682)3+++ sys/kern/kern_exec.c (working copy)4@@ -104,6 +104,13 @@5SYSCTL_ULONG(_kern, OID_AUTO, ps_arg_cache_limit, CTLFLAG_RW,6&ps_arg_cache_limit, 0, "");78+SYSCTL_DECL(_security_bsd);9+10+static int map_at_zero = 1;11+TUNABLE_INT("security.bsd.map_at_zero", &map_at_zero);12+SYSCTL_INT(_security_bsd, OID_AUTO, map_at_zero, CTLFLAG_RW, &map_at_zero, 0,13+ "Permit processes to map an object at virtual address 0.");14+15static int16sysctl_kern_ps_strings(SYSCTL_HANDLER_ARGS)17{18@@ -914,7 +921,7 @@19int error;20struct proc *p = imgp->proc;21struct vmspace *vmspace = p->p_vmspace;22- vm_offset_t stack_addr;23+ vm_offset_t sv_minuser, stack_addr;24vm_map_t map;2526imgp->vmspace_destroyed = 1;27@@ -928,14 +935,18 @@28* not disrupted29*/30map = &vmspace->vm_map;31- if (vmspace->vm_refcnt == 1 && vm_map_min(map) == sv->sv_minuser &&32+ if (map_at_zero)33+ sv_minuser = sv->sv_minuser;34+ else35+ sv_minuser = MAX(sv->sv_minuser, PAGE_SIZE);36+ if (vmspace->vm_refcnt == 1 && vm_map_min(map) == sv_minuser &&37vm_map_max(map) == sv->sv_maxuser) {38shmexit(vmspace);39pmap_remove_pages(vmspace_pmap(vmspace), vm_map_min(map),40vm_map_max(map));41vm_map_remove(map, vm_map_min(map), vm_map_max(map));42} else {43- vmspace_exec(p, sv->sv_minuser, sv->sv_maxuser);44+ vmspace_exec(p, sv_minuser, sv->sv_maxuser);45vmspace = p->p_vmspace;46map = &vmspace->vm_map;47}484950