* infrun.c (handle_inferior_event): When doing a "next", and
authorMark Kettenis <kettenis@gnu.org>
Wed, 3 May 2000 20:16:05 +0000 (20:16 +0000)
committerMark Kettenis <kettenis@gnu.org>
Wed, 3 May 2000 20:16:05 +0000 (20:16 +0000)
stepping out of a signal handler into its calling trampoline
ignore the value of step_frame_address.
(step_over_function): Only modify step_resume_breakpoint->frame if
the value of step_frame_address is non-zero.

gdb/ChangeLog
gdb/infrun.c

index 0e5995623f4040a206f2f3d542ca59ad7aa01908..5f2469f667ec99daeeaccfe6b76cc27a7b7aa7aa 100644 (file)
@@ -1,3 +1,11 @@
+2000-05-01  Mark Kettenis  <kettenis@gnu.org>
+
+       * infrun.c (handle_inferior_event): When doing a "next", and
+       stepping out of a signal handler into its calling trampoline
+       ignore the value of step_frame_address.
+       (step_over_function): Only modify step_resume_breakpoint->frame if
+       the value of step_frame_address is non-zero.
+
 2000-05-03  Michael Snyder  <msnyder@seadog.cygnus.com>
 
        * monitor.c (monitor_fetch_register): MAX_REGISTER_RAW_SIZE
index 8bf3012a6678d8b6e73453c9daecd005937c0a53..fb24203cb112eee6674448a5cf838c1356900feb 100644 (file)
@@ -2745,6 +2745,20 @@ handle_inferior_event (struct execution_control_state *ecs)
        if (step_over_calls > 0 || IGNORE_HELPER_CALL (stop_pc))
          {
            /* We're doing a "next".  */
+
+           if (IN_SIGTRAMP (stop_pc, ecs->stop_func_name)
+               && INNER_THAN (step_frame_address, read_sp()))
+             /* We stepped out of a signal handler, and into its
+                 calling trampoline.  This is misdetected as a
+                 subroutine call, but stepping over the signal
+                 trampoline isn't such a bad idea.  In order to do
+                 that, we have to ignore the value in
+                 step_frame_address, since that doesn't represent the
+                 frame that'll reach when we return from the signal
+                 trampoline.  Otherwise we'll probably continue to the
+                 end of the program.  */
+             step_frame_address = 0;
+
            step_over_function (ecs);
            keep_going (ecs);
            return;
@@ -3045,7 +3059,7 @@ step_over_function (struct execution_control_state *ecs)
   step_resume_breakpoint =
     set_momentary_breakpoint (sr_sal, get_current_frame (), bp_step_resume);
 
-  if (!IN_SOLIB_DYNSYM_RESOLVE_CODE (sr_sal.pc))
+  if (step_frame_address && !IN_SOLIB_DYNSYM_RESOLVE_CODE (sr_sal.pc))
     step_resume_breakpoint->frame = step_frame_address;
 
   if (breakpoints_inserted)