From f891ccb78e8c209dd34b173b5293831c84961b0f Mon Sep 17 00:00:00 2001 From: gallatin Date: Tue, 17 Oct 2000 00:25:43 +0000 Subject: [PATCH] Some linux apps, such as IBM's JDK 1.3, will attempt to mmap thread stacks near the top of their address space. If their TOS is greater than vm_maxsaddr, vm_map_growstack() will confuse the thread stack with the process stack and deliver a SEGV if they attempt to grow the thread stack past their current stacksize rlimit. To avoid this, adjust vm_maxsaddr upwards to reflect the current stacksize rlimit rather than the maximum possible stacksize. It would be better to adjust the mmap'ed region, but some apps (again, IBM's JDK 1.3) do not check mmap's return value.. This commit (in conjunction with setting MINSIGSTKSZ to 2048 & rebuilding your kernel and modules) will get IBM's JDK 1.3 working with FreeBSD at least well enough to run many of the example applets. Reviewed by: marcel Tested by: sto@stat.duke.edu, many others on freebsd-java@ --- sys/i386/linux/linux_machdep.c | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/sys/i386/linux/linux_machdep.c b/sys/i386/linux/linux_machdep.c index d5ea70fc4b41..4917f613dadb 100644 --- a/sys/i386/linux/linux_machdep.c +++ b/sys/i386/linux/linux_machdep.c @@ -34,12 +34,20 @@ #include #include #include +#include +#include #include #include #include #include +#include +#include +#include +#include + + #include #include #include @@ -341,6 +349,26 @@ linux_mmap(struct proc *p, struct linux_mmap_args *args) /* This gives us TOS */ bsd_args.addr = linux_args.addr + linux_args.len; + if (bsd_args.addr > p->p_vmspace->vm_maxsaddr) { + /* Some linux apps will attempt to mmap + * thread stacks near the top of their + * address space. If their TOS is greater + * than vm_maxsaddr, vm_map_growstack() + * will confuse the thread stack with the + * process stack and deliver a SEGV if they + * attempt to grow the thread stack past their + * current stacksize rlimit. To avoid this, + * adjust vm_maxsaddr upwards to reflect + * the current stacksize rlimit rather + * than the maximum possible stacksize. + * It would be better to adjust the + * mmap'ed region, but some apps do not check + * mmap's return value. + */ + p->p_vmspace->vm_maxsaddr = (char *)USRSTACK - + p->p_rlimit[RLIMIT_STACK].rlim_cur; + } + /* This gives us our maximum stack size */ if (linux_args.len > STACK_SIZE - GUARD_SIZE) bsd_args.len = linux_args.len;