X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fbreakpoint.c;h=f7f9e90a7bb6525b753e8c265af6f08315d4dd56;hb=bf77540f53dbb693d87b9ff4fbfd09d3de7fb2d9;hp=7892dc1f23a561abff788a897caf5d30ad0e97d4;hpb=6c605fa4b46d3fee9304c4e40e0e605aa5a24f28;p=sbcl.git diff --git a/src/runtime/breakpoint.c b/src/runtime/breakpoint.c index 7892dc1..f7f9e90 100644 --- a/src/runtime/breakpoint.c +++ b/src/runtime/breakpoint.c @@ -115,7 +115,7 @@ static long compute_offset(os_context_t *context, lispobj code) if (pc < code_start) return 0; else { - long offset = pc - code_start; + unsigned long offset = pc - code_start; if (offset >= codeptr->code_size) return 0; else @@ -139,7 +139,7 @@ void handle_breakpoint(os_context_t *context) thread_sigmask(SIG_SETMASK, os_context_sigmask_addr(context), 0); #endif - funcall3(SymbolFunction(HANDLE_BREAKPOINT), + funcall3(StaticSymbolFunction(HANDLE_BREAKPOINT), compute_offset(context, code), code, context_sap); @@ -164,7 +164,7 @@ void *handle_fun_end_breakpoint(os_context_t *context) thread_sigmask(SIG_SETMASK, os_context_sigmask_addr(context), 0); #endif - funcall3(SymbolFunction(HANDLE_BREAKPOINT), + funcall3(StaticSymbolFunction(HANDLE_BREAKPOINT), compute_offset(context, code), code, context_sap); @@ -188,20 +188,13 @@ void *handle_fun_end_breakpoint(os_context_t *context) void handle_single_step_trap (os_context_t *context, int kind, int register_offset) { - lispobj context_sap; - - /* Allocate the SAP object while the interrupts are still - * disabled. */ - context_sap = alloc_sap(context); - fake_foreign_function_call(context); #ifndef LISP_FEATURE_WIN32 thread_sigmask(SIG_SETMASK, os_context_sigmask_addr(context), 0); #endif - funcall3(SymbolFunction(HANDLE_SINGLE_STEP_TRAP), - context_sap, + funcall2(StaticSymbolFunction(HANDLE_SINGLE_STEP_TRAP), make_fixnum(kind), make_fixnum(register_offset));