I'm very pleased to announce the release of our new website and documentation using the new toolchain with Hugo and AsciiDoctor. To get more information about the new toolchain please read the FreeBSD Documentation Project Primer[1], Hugo docs[2] and AsciiDoctor docs[3]. Acknowledgment: Benedict Reuschling <bcr@> Glen Barber <gjb@> Hiroki Sato <hrs@> Li-Wen Hsu <lwhsu@> Sean Chittenden <seanc@> The FreeBSD Foundation [1] https://docs.FreeBSD.org/en/books/fdp-primer/ [2] https://gohugo.io/documentation/ [3] https://docs.asciidoctor.org/home/ Approved by: doceng, core
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;
|
|
}
|