Mirror of the gdb mailing list
 help / color / mirror / Atom feed
* Stopping reverse debugging behaves differently with btrace
@ 2016-06-07 20:13 Marc Khouzam
  2016-06-08  6:41 ` Metzger, Markus T
  0 siblings, 1 reply; 7+ messages in thread
From: Marc Khouzam @ 2016-06-07 20:13 UTC (permalink / raw)
  To: gdb

Hi,

I noticed a difference of behaviour when stopping reverse debugging
with btrace vs record/replay (full mode).

If full mode, if I step to line 200 and then back to line 150 then give
the record stop command, real execution will start from line 150 as 
I step my program. (This is really cool btw.)

In btrace mode (I tried bts), after I step back to line 150 and send 
the record stop command, GDB appears to still be at line 150 but on
the next step, execution jumps to line 200 before doing the step 
operation.

I'm guessing this has to do with the fact that btrace does not store 
registers and memory, so cannot restart execution just anywhere.  

I find it strange though that when turning off record, every indication 
to the user is that we are still at line 150, when in reality, GDB is 
effectively back at line 200.  This is particularly noticeable in a 
frontends when execution jumps (unexpectedly) when the first step
is requested.  

Variables also remain unavailable until the next step (or strangely,
until I send some register command).

I was wondering if GDB should reset its execution to the proper
place upon a 'record stop' for btrace?  And notify the frontend of
that change.

Any opinions?

Thanks

Marc




^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2016-06-17 11:48 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2016-06-07 20:13 Stopping reverse debugging behaves differently with btrace Marc Khouzam
2016-06-08  6:41 ` Metzger, Markus T
2016-06-09 14:11   ` Metzger, Markus T
2016-06-13 15:21     ` Metzger, Markus T
2016-06-13 17:43       ` Marc Khouzam
2016-06-14  7:40         ` Metzger, Markus T
2016-06-17 11:48           ` Metzger, Markus T

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox