Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/kern fix setrlimit(RLIMIT_STACK) for __MACHINE_STACK_GRO...
details: https://anonhg.NetBSD.org/src/rev/04fad11551e7
branches: trunk
changeset: 783751:04fad11551e7
user: chs <chs%NetBSD.org@localhost>
date: Mon Jan 07 16:54:54 2013 +0000
description:
fix setrlimit(RLIMIT_STACK) for __MACHINE_STACK_GROWS_UP platforms.
diffstat:
sys/kern/kern_resource.c | 15 ++++++++-------
1 files changed, 8 insertions(+), 7 deletions(-)
diffs (45 lines):
diff -r c605549c9946 -r 04fad11551e7 sys/kern/kern_resource.c
--- a/sys/kern/kern_resource.c Mon Jan 07 15:14:17 2013 +0000
+++ b/sys/kern/kern_resource.c Mon Jan 07 16:54:54 2013 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: kern_resource.c,v 1.171 2012/12/21 19:39:48 njoly Exp $ */
+/* $NetBSD: kern_resource.c,v 1.172 2013/01/07 16:54:54 chs Exp $ */
/*-
* Copyright (c) 1982, 1986, 1991, 1993
@@ -37,7 +37,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_resource.c,v 1.171 2012/12/21 19:39:48 njoly Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_resource.c,v 1.172 2013/01/07 16:54:54 chs Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -409,20 +409,21 @@
vaddr_t addr;
vsize_t size;
vm_prot_t prot;
+ char *base, *tmp;
+ base = p->p_vmspace->vm_minsaddr;
if (limp->rlim_cur > alimp->rlim_cur) {
prot = VM_PROT_READ | VM_PROT_WRITE;
size = limp->rlim_cur - alimp->rlim_cur;
- addr = (vaddr_t)p->p_vmspace->vm_minsaddr -
- limp->rlim_cur;
+ tmp = STACK_GROW(base, alimp->rlim_cur);
} else {
prot = VM_PROT_NONE;
size = alimp->rlim_cur - limp->rlim_cur;
- addr = (vaddr_t)p->p_vmspace->vm_minsaddr -
- alimp->rlim_cur;
+ tmp = STACK_GROW(base, limp->rlim_cur);
}
+ addr = (vaddr_t)STACK_ALLOC(tmp, size);
(void) uvm_map_protect(&p->p_vmspace->vm_map,
- addr, addr+size, prot, false);
+ addr, addr + size, prot, false);
}
break;
Home |
Main Index |
Thread Index |
Old Index