X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fsparc-arch.c;h=2eee865ab57459e9c7dab09a2fa7d6b328ccfb8b;hb=35ab27e7aab71c94aa6be12da15603c7fd87fca8;hp=aa0fef613548baca0ac3c351f0b3a639270cb936;hpb=1d06300e09f767a38bbe6d5b38232ca334ab1913;p=sbcl.git diff --git a/src/runtime/sparc-arch.c b/src/runtime/sparc-arch.c index aa0fef6..2eee865 100644 --- a/src/runtime/sparc-arch.c +++ b/src/runtime/sparc-arch.c @@ -35,6 +35,9 @@ void arch_init(void) os_vm_address_t arch_get_bad_addr(int sig, siginfo_t *code, os_context_t *context) { +#if 1 /* New way. */ + return (os_vm_address_t)code->si_addr; +#else /* Old way, almost certainly predates sigaction(2)-style handlers */ unsigned int badinst; unsigned int *pc; int rs1; @@ -82,6 +85,7 @@ os_vm_address_t arch_get_bad_addr(int sig, siginfo_t *code, os_context_t *contex (*os_context_register_addr(context, rs1) + *os_context_register_addr(context, rs2)); } +#endif } void arch_skip_instruction(os_context_t *context)