diff options
author | Boris Ulasevich <boris.ulasevich@gmail.com> | 2016-12-20 08:09:50 +0000 |
---|---|---|
committer | Boris Ulasevich <boris.ulasevich@gmail.com> | 2016-12-20 08:09:50 +0000 |
commit | 881989cb69c405ca92ddabccea547d91491a2d14 (patch) | |
tree | b923fb57feca3f2117fe34a641224b04dc561739 /lldb/source/Target/ThreadPlanStepRange.cpp | |
parent | 003fe25b07947a1cce021a9c523f5b4780790198 (diff) | |
download | bcm5719-llvm-881989cb69c405ca92ddabccea547d91491a2d14.tar.gz bcm5719-llvm-881989cb69c405ca92ddabccea547d91491a2d14.zip |
Bug 30863 - Step doesn't stop with coditional breakpoint on the next line
Fixed by additional completed plans detection, and applying them on breakpoint condition fail.
Thread::GetStopInfo reworked. New test added.
Review https://reviews.llvm.org/D26497
Many thanks to Jim
llvm-svn: 290168
Diffstat (limited to 'lldb/source/Target/ThreadPlanStepRange.cpp')
-rw-r--r-- | lldb/source/Target/ThreadPlanStepRange.cpp | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/lldb/source/Target/ThreadPlanStepRange.cpp b/lldb/source/Target/ThreadPlanStepRange.cpp index dcee82ea32a..47672113c6b 100644 --- a/lldb/source/Target/ThreadPlanStepRange.cpp +++ b/lldb/source/Target/ThreadPlanStepRange.cpp @@ -461,6 +461,16 @@ bool ThreadPlanStepRange::IsPlanStale() { // One tricky bit here is that some stubs don't push a frame, so we should. // check that we are in the same symbol. if (!InRange()) { + // Set plan Complete when we reach next instruction just after the range + lldb::addr_t addr = m_thread.GetRegisterContext()->GetPC() - 1; + size_t num_ranges = m_address_ranges.size(); + for (size_t i = 0; i < num_ranges; i++) { + bool in_range = m_address_ranges[i].ContainsLoadAddress( + addr, m_thread.CalculateTarget().get()); + if (in_range) { + SetPlanComplete(); + } + } return true; } } |