7936339495
and associated user-level signal trampoline glue. Without this patch, an SA_SIGINFO style handler can be installed by a linux app, but if the handler accesses its sip argument, it will get a garbage pointer and likely segfault. We currently supply a valid pointer, but its contents are mainly garbage. Filling this in properly is future work. This is the second of 3 commits that will get IBM's JDK 1.3 working with FreeBSD ...
41 lines
1.0 KiB
ArmAsm
41 lines
1.0 KiB
ArmAsm
/* $FreeBSD$ */
|
|
|
|
#include "linux_assym.h" /* system definitions */
|
|
#include <machine/asmacros.h> /* miscellaneous asm macros */
|
|
|
|
#include <i386/linux/linux_syscall.h> /* system call numbers */
|
|
|
|
NON_GPROF_ENTRY(linux_sigcode)
|
|
call *LINUX_SIGF_HANDLER(%esp)
|
|
leal LINUX_SIGF_SC(%esp),%ebx /* linux scp */
|
|
movl LINUX_SC_GS(%ebx),%gs
|
|
push %eax /* fake ret addr */
|
|
movl $LINUX_SYS_linux_sigreturn,%eax /* linux_sigreturn() */
|
|
int $0x80 /* enter kernel with args */
|
|
0: jmp 0b
|
|
ALIGN_TEXT
|
|
/* XXXXX */
|
|
|
|
_linux_rt_sigcode:
|
|
call *LINUX_RT_SIGF_HANDLER(%esp)
|
|
leal LINUX_RT_SIGF_UC(%esp),%ebx /* linux ucp */
|
|
movl LINUX_SC_GS(%ebx),%gs
|
|
push %eax /* fake ret addr */
|
|
movl $LINUX_SYS_linux_rt_sigreturn,%eax /* linux_rt_sigreturn() */
|
|
int $0x80 /* enter kernel with args */
|
|
0: jmp 0b
|
|
ALIGN_TEXT
|
|
/* XXXXX */
|
|
_linux_esigcode:
|
|
|
|
.data
|
|
.globl _linux_szsigcode, _linux_sznonrtsigcode
|
|
_linux_szsigcode:
|
|
.long _linux_esigcode-_linux_sigcode
|
|
_linux_sznonrtsigcode:
|
|
.long _linux_rt_sigcode-_linux_sigcode
|
|
.text
|
|
|
|
|
|
|