patches for easier mirroring, to eliminate a special copy, to make www.freebsd.org/security a full copy of security.freebsd.org and be eventually be the same. For now files are just sitting there. The symlinks are missing. Discussed on: www (repository location) Discussed with: simon (so)
48 lines
1.5 KiB
Diff
48 lines
1.5 KiB
Diff
Index: sys/kern/kern_exec.c
|
|
===================================================================
|
|
--- sys/kern/kern_exec.c (revision 197682)
|
|
+++ sys/kern/kern_exec.c (working copy)
|
|
@@ -104,6 +104,13 @@
|
|
SYSCTL_ULONG(_kern, OID_AUTO, ps_arg_cache_limit, CTLFLAG_RW,
|
|
&ps_arg_cache_limit, 0, "");
|
|
|
|
+SYSCTL_DECL(_security_bsd);
|
|
+
|
|
+static int map_at_zero = 1;
|
|
+TUNABLE_INT("security.bsd.map_at_zero", &map_at_zero);
|
|
+SYSCTL_INT(_security_bsd, OID_AUTO, map_at_zero, CTLFLAG_RW, &map_at_zero, 0,
|
|
+ "Permit processes to map an object at virtual address 0.");
|
|
+
|
|
static int
|
|
sysctl_kern_ps_strings(SYSCTL_HANDLER_ARGS)
|
|
{
|
|
@@ -914,7 +921,7 @@
|
|
int error;
|
|
struct proc *p = imgp->proc;
|
|
struct vmspace *vmspace = p->p_vmspace;
|
|
- vm_offset_t stack_addr;
|
|
+ vm_offset_t sv_minuser, stack_addr;
|
|
vm_map_t map;
|
|
|
|
imgp->vmspace_destroyed = 1;
|
|
@@ -928,14 +935,18 @@
|
|
* not disrupted
|
|
*/
|
|
map = &vmspace->vm_map;
|
|
- if (vmspace->vm_refcnt == 1 && vm_map_min(map) == sv->sv_minuser &&
|
|
+ if (map_at_zero)
|
|
+ sv_minuser = sv->sv_minuser;
|
|
+ else
|
|
+ sv_minuser = MAX(sv->sv_minuser, PAGE_SIZE);
|
|
+ if (vmspace->vm_refcnt == 1 && vm_map_min(map) == sv_minuser &&
|
|
vm_map_max(map) == sv->sv_maxuser) {
|
|
shmexit(vmspace);
|
|
pmap_remove_pages(vmspace_pmap(vmspace), vm_map_min(map),
|
|
vm_map_max(map));
|
|
vm_map_remove(map, vm_map_min(map), vm_map_max(map));
|
|
} else {
|
|
- vmspace_exec(p, sv->sv_minuser, sv->sv_maxuser);
|
|
+ vmspace_exec(p, sv_minuser, sv->sv_maxuser);
|
|
vmspace = p->p_vmspace;
|
|
map = &vmspace->vm_map;
|
|
}
|