X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Falpha-arch.c;h=827080f8694101aef9e4088fd3fea149c6001853;hb=6c605fa4b46d3fee9304c4e40e0e605aa5a24f28;hp=8fab937081ac6cac741f0a51c922261abc384eb9;hpb=bf282f716a1ecaa09794a2cac7ce7da8d0d87675;p=sbcl.git diff --git a/src/runtime/alpha-arch.c b/src/runtime/alpha-arch.c index 8fab937..827080f 100644 --- a/src/runtime/alpha-arch.c +++ b/src/runtime/alpha-arch.c @@ -75,7 +75,7 @@ arch_get_bad_addr (int sig, siginfo_t *code, os_context_t *context) if ( (pc < READ_ONLY_SPACE_START || pc >= READ_ONLY_SPACE_START+READ_ONLY_SPACE_SIZE) && (pc < current_dynamic_space || - pc >= current_dynamic_space + DYNAMIC_SPACE_SIZE)) + pc >= current_dynamic_space + dynamic_space_size)) return NULL; return context->uc_mcontext.sc_traparg_a0; @@ -277,6 +277,21 @@ void arch_do_displaced_inst(os_context_t *context,unsigned int orig_inst) os_flush_icache((os_vm_address_t)next_pc, sizeof(unsigned int)); } +void +arch_handle_breakpoint(os_context_t *context) +{ + *os_context_pc_addr(context) -=4; + handle_breakpoint(context); +} + +void +arch_handle_fun_end_breakpoint(os_context_t *context) +{ + *os_context_pc_addr(context) -=4; + *os_context_pc_addr(context) = + (int)handle_fun_end_breakpoint(context); +} + static void sigtrap_handler(int signal, siginfo_t *siginfo, os_context_t *context) { @@ -313,38 +328,8 @@ sigtrap_handler(int signal, siginfo_t *siginfo, os_context_t *context) } else /* a "system service" */ code=*((u32 *)(*os_context_pc_addr(context))); - - switch (code) { - case trap_PendingInterrupt: - arch_skip_instruction(context); - interrupt_handle_pending(context); - break; - - case trap_Halt: - fake_foreign_function_call(context); - lose("%%primitive halt called; the party is over.\n"); - - case trap_Error: - case trap_Cerror: - interrupt_internal_error(signal, siginfo, context, code==trap_Cerror); - break; - - case trap_Breakpoint: /* call lisp-level handler */ - *os_context_pc_addr(context) -=4; - handle_breakpoint(signal, siginfo, context); - break; - - case trap_FunEndBreakpoint: - *os_context_pc_addr(context) -=4; - *os_context_pc_addr(context) = - (int)handle_fun_end_breakpoint(signal, siginfo, context); - break; - - default: - fprintf(stderr, "unidentified breakpoint/trap %d\n",code); + if (!maybe_handle_trap(context, code)) interrupt_handle_now(signal, siginfo, context); - break; - } } unsigned long