blob: 527362672c4cc3edf20e9ed7cd69ac8c93480b7f [file] [log] [blame]
Alexander Shaposhnikov696bd632016-11-26 05:23:44 +00001//===-- SBThreadPlan.cpp ----------------------------------------*- C++ -*-===//
Jim Ingham2bdbfd52014-09-29 23:17:18 +00002//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Jim Ingham2bdbfd52014-09-29 23:17:18 +000010#include "lldb/API/SBThread.h"
11
Jim Ingham2bdbfd52014-09-29 23:17:18 +000012#include "lldb/API/SBFileSpec.h"
13#include "lldb/API/SBStream.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000014#include "lldb/API/SBSymbolContext.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000015#include "lldb/Breakpoint/BreakpointLocation.h"
16#include "lldb/Core/Debugger.h"
17#include "lldb/Core/State.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000018#include "lldb/Core/StreamFile.h"
19#include "lldb/Core/StructuredData.h"
20#include "lldb/Interpreter/CommandInterpreter.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000021#include "lldb/Symbol/CompileUnit.h"
22#include "lldb/Symbol/SymbolContext.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000023#include "lldb/Target/Process.h"
24#include "lldb/Target/Queue.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000025#include "lldb/Target/StopInfo.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000026#include "lldb/Target/SystemRuntime.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000027#include "lldb/Target/Target.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000028#include "lldb/Target/Thread.h"
29#include "lldb/Target/ThreadPlan.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000030#include "lldb/Target/ThreadPlan.h"
31#include "lldb/Target/ThreadPlanPython.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000032#include "lldb/Target/ThreadPlanStepInRange.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000033#include "lldb/Target/ThreadPlanStepInstruction.h"
34#include "lldb/Target/ThreadPlanStepOut.h"
35#include "lldb/Target/ThreadPlanStepRange.h"
Zachary Turnerbf9a7732017-02-02 21:39:50 +000036#include "lldb/Utility/Stream.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000037
38#include "lldb/API/SBAddress.h"
39#include "lldb/API/SBDebugger.h"
40#include "lldb/API/SBEvent.h"
41#include "lldb/API/SBFrame.h"
42#include "lldb/API/SBProcess.h"
43#include "lldb/API/SBThreadPlan.h"
44#include "lldb/API/SBValue.h"
45
46using namespace lldb;
47using namespace lldb_private;
48
49//----------------------------------------------------------------------
50// Constructors
51//----------------------------------------------------------------------
Kate Stoneb9c1b512016-09-06 20:57:50 +000052SBThreadPlan::SBThreadPlan() {}
Jim Ingham2bdbfd52014-09-29 23:17:18 +000053
Kate Stoneb9c1b512016-09-06 20:57:50 +000054SBThreadPlan::SBThreadPlan(const ThreadPlanSP &lldb_object_sp)
55 : m_opaque_sp(lldb_object_sp) {}
Jim Ingham2bdbfd52014-09-29 23:17:18 +000056
Kate Stoneb9c1b512016-09-06 20:57:50 +000057SBThreadPlan::SBThreadPlan(const SBThreadPlan &rhs)
58 : m_opaque_sp(rhs.m_opaque_sp) {}
Jim Ingham2bdbfd52014-09-29 23:17:18 +000059
Kate Stoneb9c1b512016-09-06 20:57:50 +000060SBThreadPlan::SBThreadPlan(lldb::SBThread &sb_thread, const char *class_name) {
61 Thread *thread = sb_thread.get();
62 if (thread)
63 m_opaque_sp.reset(new ThreadPlanPython(*thread, class_name));
Jim Ingham2bdbfd52014-09-29 23:17:18 +000064}
65
66//----------------------------------------------------------------------
67// Assignment operator
68//----------------------------------------------------------------------
69
Kate Stoneb9c1b512016-09-06 20:57:50 +000070const lldb::SBThreadPlan &SBThreadPlan::operator=(const SBThreadPlan &rhs) {
71 if (this != &rhs)
72 m_opaque_sp = rhs.m_opaque_sp;
73 return *this;
Jim Ingham2bdbfd52014-09-29 23:17:18 +000074}
75//----------------------------------------------------------------------
76// Destructor
77//----------------------------------------------------------------------
Kate Stoneb9c1b512016-09-06 20:57:50 +000078SBThreadPlan::~SBThreadPlan() {}
79
80lldb_private::ThreadPlan *SBThreadPlan::get() { return m_opaque_sp.get(); }
81
82bool SBThreadPlan::IsValid() const { return m_opaque_sp.get() != NULL; }
83
84void SBThreadPlan::Clear() { m_opaque_sp.reset(); }
85
86lldb::StopReason SBThreadPlan::GetStopReason() { return eStopReasonNone; }
87
88size_t SBThreadPlan::GetStopReasonDataCount() { return 0; }
89
90uint64_t SBThreadPlan::GetStopReasonDataAtIndex(uint32_t idx) { return 0; }
91
92SBThread SBThreadPlan::GetThread() const {
93 if (m_opaque_sp) {
94 return SBThread(m_opaque_sp->GetThread().shared_from_this());
95 } else
96 return SBThread();
Jim Ingham2bdbfd52014-09-29 23:17:18 +000097}
98
Kate Stoneb9c1b512016-09-06 20:57:50 +000099bool SBThreadPlan::GetDescription(lldb::SBStream &description) const {
100 if (m_opaque_sp) {
101 m_opaque_sp->GetDescription(description.get(), eDescriptionLevelFull);
102 } else {
103 description.Printf("Empty SBThreadPlan");
104 }
105 return true;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000106}
107
Kate Stoneb9c1b512016-09-06 20:57:50 +0000108void SBThreadPlan::SetThreadPlan(const ThreadPlanSP &lldb_object_sp) {
109 m_opaque_sp = lldb_object_sp;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000110}
111
Kate Stoneb9c1b512016-09-06 20:57:50 +0000112void SBThreadPlan::SetPlanComplete(bool success) {
113 if (m_opaque_sp)
114 m_opaque_sp->SetPlanComplete(success);
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000115}
116
Kate Stoneb9c1b512016-09-06 20:57:50 +0000117bool SBThreadPlan::IsPlanComplete() {
118 if (m_opaque_sp)
119 return m_opaque_sp->IsPlanComplete();
120 else
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000121 return true;
122}
123
Kate Stoneb9c1b512016-09-06 20:57:50 +0000124bool SBThreadPlan::IsPlanStale() {
125 if (m_opaque_sp)
126 return m_opaque_sp->IsPlanStale();
127 else
128 return true;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000129}
130
Kate Stoneb9c1b512016-09-06 20:57:50 +0000131bool SBThreadPlan::IsValid() {
132 if (m_opaque_sp)
133 return m_opaque_sp->ValidatePlan(nullptr);
134 else
135 return false;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000136}
137
Kate Stoneb9c1b512016-09-06 20:57:50 +0000138// This section allows an SBThreadPlan to push another of the common types of
139// plans...
140//
141// FIXME, you should only be able to queue thread plans from inside the methods
142// of a
143// Scripted Thread Plan. Need a way to enforce that.
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000144
145SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000146SBThreadPlan::QueueThreadPlanForStepOverRange(SBAddress &sb_start_address,
147 lldb::addr_t size) {
148 if (m_opaque_sp) {
149 Address *start_address = sb_start_address.get();
150 if (!start_address) {
151 return SBThreadPlan();
152 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000153
Kate Stoneb9c1b512016-09-06 20:57:50 +0000154 AddressRange range(*start_address, size);
155 SymbolContext sc;
156 start_address->CalculateSymbolContext(&sc);
157 return SBThreadPlan(
158 m_opaque_sp->GetThread().QueueThreadPlanForStepOverRange(
159 false, range, sc, eAllThreads));
160 } else {
161 return SBThreadPlan();
162 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000163}
164
165SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000166SBThreadPlan::QueueThreadPlanForStepInRange(SBAddress &sb_start_address,
167 lldb::addr_t size) {
168 if (m_opaque_sp) {
169 Address *start_address = sb_start_address.get();
170 if (!start_address) {
171 return SBThreadPlan();
172 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000173
Kate Stoneb9c1b512016-09-06 20:57:50 +0000174 AddressRange range(*start_address, size);
175 SymbolContext sc;
176 start_address->CalculateSymbolContext(&sc);
177 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepInRange(
178 false, range, sc, NULL, eAllThreads));
179 } else {
180 return SBThreadPlan();
181 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000182}
183
184SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000185SBThreadPlan::QueueThreadPlanForStepOut(uint32_t frame_idx_to_step_to,
186 bool first_insn) {
187 if (m_opaque_sp) {
188 SymbolContext sc;
189 sc = m_opaque_sp->GetThread().GetStackFrameAtIndex(0)->GetSymbolContext(
190 lldb::eSymbolContextEverything);
191 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepOut(
192 false, &sc, first_insn, false, eVoteYes, eVoteNoOpinion,
193 frame_idx_to_step_to));
194 } else {
195 return SBThreadPlan();
196 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000197}
198
199SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000200SBThreadPlan::QueueThreadPlanForRunToAddress(SBAddress sb_address) {
201 if (m_opaque_sp) {
202 Address *address = sb_address.get();
203 if (!address)
204 return SBThreadPlan();
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000205
Kate Stoneb9c1b512016-09-06 20:57:50 +0000206 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForRunToAddress(
207 false, *address, false));
208 } else {
209 return SBThreadPlan();
210 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000211}