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