summaryrefslogtreecommitdiffstats
path: root/lldb/source/Target/ThreadPlanStepRange.cpp
diff options
context:
space:
mode:
authorBoris Ulasevich <boris.ulasevich@gmail.com>2016-12-20 08:09:50 +0000
committerBoris Ulasevich <boris.ulasevich@gmail.com>2016-12-20 08:09:50 +0000
commit881989cb69c405ca92ddabccea547d91491a2d14 (patch)
treeb923fb57feca3f2117fe34a641224b04dc561739 /lldb/source/Target/ThreadPlanStepRange.cpp
parent003fe25b07947a1cce021a9c523f5b4780790198 (diff)
downloadbcm5719-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.cpp10
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;
}
}
OpenPOWER on IntegriCloud