2009-06-18 Hui Zhu <teawater@gmail.com>
authorMichael Snyder <msnyder@vmware.com>
Thu, 18 Jun 2009 23:41:27 +0000 (23:41 +0000)
committerMichael Snyder <msnyder@vmware.com>
Thu, 18 Jun 2009 23:41:27 +0000 (23:41 +0000)
    Michael Snyder  <msnyder@vmware.com>

* infrun.c (handle_inferior_event): Improve reverse stepping
through function epilogue.

gdb/ChangeLog
gdb/infrun.c

index 352deeb3284aff3b1da47520e5e06804f5027655..0d5e763163ea7c89faab06fa16a0212232090ad3 100644 (file)
@@ -1,3 +1,9 @@
+2009-06-18  Hui Zhu  <teawater@gmail.com>
+           Michael Snyder  <msnyder@vmware.com>
+
+       * infrun.c (handle_inferior_event): Improve reverse stepping
+       through function epilogue.
+
 2009-06-18  Paul Pluzhnikov  <ppluzhnikov@google.com>
 
        * dwarf2-frame.c (struct comp_unit): Use bfd_size_type for
index 3eaf89e1b617f3e7c80cee53f42e6996999fc062..7488912c06ba84eaf319283e5abdf1ed48ad466b 100644 (file)
@@ -3630,9 +3630,17 @@ infrun: not switching back to stepped thread, it has vanished\n");
 
      Note that step_range_end is the address of the first instruction
      beyond the step range, and NOT the address of the last instruction
-     within it! */
+     within it!
+
+     Note also that during reverse execution, we may be stepping
+     through a function epilogue and therefore must detect when
+     the current-frame changes in the middle of a line.  */
+
   if (stop_pc >= ecs->event_thread->step_range_start
-      && stop_pc < ecs->event_thread->step_range_end)
+      && stop_pc < ecs->event_thread->step_range_end
+      && (execution_direction != EXEC_REVERSE
+         || frame_id_eq (get_frame_id (get_current_frame ()),
+                         ecs->event_thread->step_frame_id)))
     {
       if (debug_infrun)
        fprintf_unfiltered (gdb_stdlog, "infrun: stepping inside range [0x%s-0x%s]\n",