blob: fc54f5b5f87e4dac26b175d659e9ece6d4ec665c [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"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000017#include "lldb/Core/StreamFile.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000018#include "lldb/Interpreter/CommandInterpreter.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000019#include "lldb/Symbol/CompileUnit.h"
20#include "lldb/Symbol/SymbolContext.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000021#include "lldb/Target/Process.h"
22#include "lldb/Target/Queue.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000023#include "lldb/Target/StopInfo.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000024#include "lldb/Target/SystemRuntime.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000025#include "lldb/Target/Target.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000026#include "lldb/Target/Thread.h"
27#include "lldb/Target/ThreadPlan.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000028#include "lldb/Target/ThreadPlanPython.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000029#include "lldb/Target/ThreadPlanStepInRange.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000030#include "lldb/Target/ThreadPlanStepInstruction.h"
31#include "lldb/Target/ThreadPlanStepOut.h"
32#include "lldb/Target/ThreadPlanStepRange.h"
Pavel Labathd821c992018-08-07 11:07:21 +000033#include "lldb/Utility/State.h"
Zachary Turnerbf9a7732017-02-02 21:39:50 +000034#include "lldb/Utility/Stream.h"
Pavel Labathf2a8bcc2017-06-27 10:45:31 +000035#include "lldb/Utility/StructuredData.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000036
37#include "lldb/API/SBAddress.h"
38#include "lldb/API/SBDebugger.h"
39#include "lldb/API/SBEvent.h"
40#include "lldb/API/SBFrame.h"
41#include "lldb/API/SBProcess.h"
42#include "lldb/API/SBThreadPlan.h"
43#include "lldb/API/SBValue.h"
44
45using namespace lldb;
46using namespace lldb_private;
47
48//----------------------------------------------------------------------
49// Constructors
50//----------------------------------------------------------------------
Kate Stoneb9c1b512016-09-06 20:57:50 +000051SBThreadPlan::SBThreadPlan() {}
Jim Ingham2bdbfd52014-09-29 23:17:18 +000052
Kate Stoneb9c1b512016-09-06 20:57:50 +000053SBThreadPlan::SBThreadPlan(const ThreadPlanSP &lldb_object_sp)
54 : m_opaque_sp(lldb_object_sp) {}
Jim Ingham2bdbfd52014-09-29 23:17:18 +000055
Kate Stoneb9c1b512016-09-06 20:57:50 +000056SBThreadPlan::SBThreadPlan(const SBThreadPlan &rhs)
57 : m_opaque_sp(rhs.m_opaque_sp) {}
Jim Ingham2bdbfd52014-09-29 23:17:18 +000058
Kate Stoneb9c1b512016-09-06 20:57:50 +000059SBThreadPlan::SBThreadPlan(lldb::SBThread &sb_thread, const char *class_name) {
60 Thread *thread = sb_thread.get();
61 if (thread)
62 m_opaque_sp.reset(new ThreadPlanPython(*thread, class_name));
Jim Ingham2bdbfd52014-09-29 23:17:18 +000063}
64
65//----------------------------------------------------------------------
66// Assignment operator
67//----------------------------------------------------------------------
68
Kate Stoneb9c1b512016-09-06 20:57:50 +000069const lldb::SBThreadPlan &SBThreadPlan::operator=(const SBThreadPlan &rhs) {
70 if (this != &rhs)
71 m_opaque_sp = rhs.m_opaque_sp;
72 return *this;
Jim Ingham2bdbfd52014-09-29 23:17:18 +000073}
74//----------------------------------------------------------------------
75// Destructor
76//----------------------------------------------------------------------
Kate Stoneb9c1b512016-09-06 20:57:50 +000077SBThreadPlan::~SBThreadPlan() {}
78
79lldb_private::ThreadPlan *SBThreadPlan::get() { return m_opaque_sp.get(); }
80
81bool SBThreadPlan::IsValid() const { return m_opaque_sp.get() != NULL; }
82
83void SBThreadPlan::Clear() { m_opaque_sp.reset(); }
84
85lldb::StopReason SBThreadPlan::GetStopReason() { return eStopReasonNone; }
86
87size_t SBThreadPlan::GetStopReasonDataCount() { return 0; }
88
89uint64_t SBThreadPlan::GetStopReasonDataAtIndex(uint32_t idx) { return 0; }
90
91SBThread SBThreadPlan::GetThread() const {
92 if (m_opaque_sp) {
93 return SBThread(m_opaque_sp->GetThread().shared_from_this());
94 } else
95 return SBThread();
Jim Ingham2bdbfd52014-09-29 23:17:18 +000096}
97
Kate Stoneb9c1b512016-09-06 20:57:50 +000098bool SBThreadPlan::GetDescription(lldb::SBStream &description) const {
99 if (m_opaque_sp) {
100 m_opaque_sp->GetDescription(description.get(), eDescriptionLevelFull);
101 } else {
102 description.Printf("Empty SBThreadPlan");
103 }
104 return true;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000105}
106
Kate Stoneb9c1b512016-09-06 20:57:50 +0000107void SBThreadPlan::SetThreadPlan(const ThreadPlanSP &lldb_object_sp) {
108 m_opaque_sp = lldb_object_sp;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000109}
110
Kate Stoneb9c1b512016-09-06 20:57:50 +0000111void SBThreadPlan::SetPlanComplete(bool success) {
112 if (m_opaque_sp)
113 m_opaque_sp->SetPlanComplete(success);
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000114}
115
Kate Stoneb9c1b512016-09-06 20:57:50 +0000116bool SBThreadPlan::IsPlanComplete() {
117 if (m_opaque_sp)
118 return m_opaque_sp->IsPlanComplete();
119 else
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000120 return true;
121}
122
Kate Stoneb9c1b512016-09-06 20:57:50 +0000123bool SBThreadPlan::IsPlanStale() {
124 if (m_opaque_sp)
125 return m_opaque_sp->IsPlanStale();
126 else
127 return true;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000128}
129
Kate Stoneb9c1b512016-09-06 20:57:50 +0000130bool SBThreadPlan::IsValid() {
131 if (m_opaque_sp)
132 return m_opaque_sp->ValidatePlan(nullptr);
133 else
134 return false;
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000135}
136
Kate Stoneb9c1b512016-09-06 20:57:50 +0000137// This section allows an SBThreadPlan to push another of the common types of
138// plans...
139//
140// FIXME, you should only be able to queue thread plans from inside the methods
Adrian Prantl05097242018-04-30 16:49:04 +0000141// of a Scripted Thread Plan. Need a way to enforce that.
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000142
143SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000144SBThreadPlan::QueueThreadPlanForStepOverRange(SBAddress &sb_start_address,
145 lldb::addr_t size) {
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000146 SBError error;
147 return QueueThreadPlanForStepOverRange(sb_start_address, size, error);
148}
149
150SBThreadPlan SBThreadPlan::QueueThreadPlanForStepOverRange(
151 SBAddress &sb_start_address, lldb::addr_t size, SBError &error) {
Kate Stoneb9c1b512016-09-06 20:57:50 +0000152 if (m_opaque_sp) {
153 Address *start_address = sb_start_address.get();
154 if (!start_address) {
155 return SBThreadPlan();
156 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000157
Kate Stoneb9c1b512016-09-06 20:57:50 +0000158 AddressRange range(*start_address, size);
159 SymbolContext sc;
160 start_address->CalculateSymbolContext(&sc);
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000161 Status plan_status;
162
163 SBThreadPlan plan =
164 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepOverRange(
165 false, range, sc, eAllThreads, plan_status));
166
167 if (plan_status.Fail())
168 error.SetErrorString(plan_status.AsCString());
169
170 return plan;
Kate Stoneb9c1b512016-09-06 20:57:50 +0000171 } else {
172 return SBThreadPlan();
173 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000174}
175
176SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000177SBThreadPlan::QueueThreadPlanForStepInRange(SBAddress &sb_start_address,
178 lldb::addr_t size) {
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000179 SBError error;
180 return QueueThreadPlanForStepInRange(sb_start_address, size, error);
181}
182
183SBThreadPlan
184SBThreadPlan::QueueThreadPlanForStepInRange(SBAddress &sb_start_address,
185 lldb::addr_t size, SBError &error) {
Kate Stoneb9c1b512016-09-06 20:57:50 +0000186 if (m_opaque_sp) {
187 Address *start_address = sb_start_address.get();
188 if (!start_address) {
189 return SBThreadPlan();
190 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000191
Kate Stoneb9c1b512016-09-06 20:57:50 +0000192 AddressRange range(*start_address, size);
193 SymbolContext sc;
194 start_address->CalculateSymbolContext(&sc);
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000195
196 Status plan_status;
197 SBThreadPlan plan =
198 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepInRange(
199 false, range, sc, NULL, eAllThreads, plan_status));
200
201 if (plan_status.Fail())
202 error.SetErrorString(plan_status.AsCString());
203
204 return plan;
Kate Stoneb9c1b512016-09-06 20:57:50 +0000205 } else {
206 return SBThreadPlan();
207 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000208}
209
210SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000211SBThreadPlan::QueueThreadPlanForStepOut(uint32_t frame_idx_to_step_to,
212 bool first_insn) {
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000213 SBError error;
214 return QueueThreadPlanForStepOut(frame_idx_to_step_to, first_insn, error);
215}
216
217SBThreadPlan
218SBThreadPlan::QueueThreadPlanForStepOut(uint32_t frame_idx_to_step_to,
219 bool first_insn, SBError &error) {
Kate Stoneb9c1b512016-09-06 20:57:50 +0000220 if (m_opaque_sp) {
221 SymbolContext sc;
222 sc = m_opaque_sp->GetThread().GetStackFrameAtIndex(0)->GetSymbolContext(
223 lldb::eSymbolContextEverything);
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000224
225 Status plan_status;
226 SBThreadPlan plan =
227 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepOut(
228 false, &sc, first_insn, false, eVoteYes, eVoteNoOpinion,
229 frame_idx_to_step_to, plan_status));
230
231 if (plan_status.Fail())
232 error.SetErrorString(plan_status.AsCString());
233
234 return plan;
Kate Stoneb9c1b512016-09-06 20:57:50 +0000235 } else {
236 return SBThreadPlan();
237 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000238}
239
240SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000241SBThreadPlan::QueueThreadPlanForRunToAddress(SBAddress sb_address) {
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000242 SBError error;
243 return QueueThreadPlanForRunToAddress(sb_address, error);
244}
245
246SBThreadPlan SBThreadPlan::QueueThreadPlanForRunToAddress(SBAddress sb_address,
247 SBError &error) {
Kate Stoneb9c1b512016-09-06 20:57:50 +0000248 if (m_opaque_sp) {
249 Address *address = sb_address.get();
250 if (!address)
251 return SBThreadPlan();
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000252
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000253 Status plan_status;
254 SBThreadPlan plan =
255 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForRunToAddress(
256 false, *address, false, plan_status));
257
258 if (plan_status.Fail())
259 error.SetErrorString(plan_status.AsCString());
260
261 return plan;
Kate Stoneb9c1b512016-09-06 20:57:50 +0000262 } else {
263 return SBThreadPlan();
264 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000265}
Aleksandr Urakovc1c0fac2018-10-25 08:27:42 +0000266
267SBThreadPlan
268SBThreadPlan::QueueThreadPlanForStepScripted(const char *script_class_name) {
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000269 SBError error;
270 return QueueThreadPlanForStepScripted(script_class_name, error);
271}
272
273SBThreadPlan
274SBThreadPlan::QueueThreadPlanForStepScripted(const char *script_class_name,
275 SBError &error) {
Aleksandr Urakovc1c0fac2018-10-25 08:27:42 +0000276 if (m_opaque_sp) {
Jonas Devliegheree103ae92018-11-15 01:18:15 +0000277 Status plan_status;
278 SBThreadPlan plan =
279 SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepScripted(
280 false, script_class_name, false, plan_status));
281
282 if (plan_status.Fail())
283 error.SetErrorString(plan_status.AsCString());
284
285 return plan;
Aleksandr Urakovc1c0fac2018-10-25 08:27:42 +0000286 } else {
287 return SBThreadPlan();
288 }
289}