diff options
author | Robert O'Callahan <rocallahan@google.com> | 2025-01-22 20:37:17 +1300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-01-22 08:37:17 +0100 |
commit | b7b9ccf44988edf49886743ae5c3cf4184db211f (patch) | |
tree | 23a42c4f7287081feb4b958f53c1a7f9f49e9d08 /lldb/source/Interpreter/CommandInterpreter.cpp | |
parent | 830bd0e8f263c6efcfd37f38cc621b0476582b83 (diff) | |
download | llvm-b7b9ccf44988edf49886743ae5c3cf4184db211f.zip llvm-b7b9ccf44988edf49886743ae5c3cf4184db211f.tar.gz llvm-b7b9ccf44988edf49886743ae5c3cf4184db211f.tar.bz2 |
[lldb] Implement basic support for reverse-continue (#112079)
This commit adds support for a
`SBProcess::ContinueInDirection()` API. A user-accessible command for
this will follow in a later commit.
This feature depends on a gdbserver implementation (e.g. `rr`) providing
support for the `bc` and `bs` packets. `lldb-server` does not support
those packets, and there is no plan to change that. For testing
purposes, this commit adds a Python implementation of *very limited*
record-and-reverse-execute functionality, implemented as a proxy between
lldb and lldb-server in `lldbreverse.py`. This should not (and in
practice cannot) be used for anything except testing.
The tests here are quite minimal but we test that simple breakpoints and
watchpoints work as expected during reverse execution, and that
conditional breakpoints and watchpoints work when the condition calls a
function that must be executed in the forward direction.
Diffstat (limited to 'lldb/source/Interpreter/CommandInterpreter.cpp')
-rw-r--r-- | lldb/source/Interpreter/CommandInterpreter.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/lldb/source/Interpreter/CommandInterpreter.cpp b/lldb/source/Interpreter/CommandInterpreter.cpp index 764dcfd..284955a 100644 --- a/lldb/source/Interpreter/CommandInterpreter.cpp +++ b/lldb/source/Interpreter/CommandInterpreter.cpp @@ -2557,7 +2557,8 @@ bool CommandInterpreter::DidProcessStopAbnormally() const { const StopReason reason = stop_info->GetStopReason(); if (reason == eStopReasonException || reason == eStopReasonInstrumentation || - reason == eStopReasonProcessorTrace || reason == eStopReasonInterrupt) + reason == eStopReasonProcessorTrace || reason == eStopReasonInterrupt || + reason == eStopReasonHistoryBoundary) return true; if (reason == eStopReasonSignal) { |