blob: c15c39aab514e049dda75baf1b36286900acd3a5 [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) {
146 if (m_opaque_sp) {
147 Address *start_address = sb_start_address.get();
148 if (!start_address) {
149 return SBThreadPlan();
150 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000151
Kate Stoneb9c1b512016-09-06 20:57:50 +0000152 AddressRange range(*start_address, size);
153 SymbolContext sc;
154 start_address->CalculateSymbolContext(&sc);
155 return SBThreadPlan(
156 m_opaque_sp->GetThread().QueueThreadPlanForStepOverRange(
157 false, range, sc, eAllThreads));
158 } else {
159 return SBThreadPlan();
160 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000161}
162
163SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000164SBThreadPlan::QueueThreadPlanForStepInRange(SBAddress &sb_start_address,
165 lldb::addr_t size) {
166 if (m_opaque_sp) {
167 Address *start_address = sb_start_address.get();
168 if (!start_address) {
169 return SBThreadPlan();
170 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000171
Kate Stoneb9c1b512016-09-06 20:57:50 +0000172 AddressRange range(*start_address, size);
173 SymbolContext sc;
174 start_address->CalculateSymbolContext(&sc);
175 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepInRange(
176 false, range, sc, NULL, eAllThreads));
177 } else {
178 return SBThreadPlan();
179 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000180}
181
182SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000183SBThreadPlan::QueueThreadPlanForStepOut(uint32_t frame_idx_to_step_to,
184 bool first_insn) {
185 if (m_opaque_sp) {
186 SymbolContext sc;
187 sc = m_opaque_sp->GetThread().GetStackFrameAtIndex(0)->GetSymbolContext(
188 lldb::eSymbolContextEverything);
189 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepOut(
190 false, &sc, first_insn, false, eVoteYes, eVoteNoOpinion,
191 frame_idx_to_step_to));
192 } else {
193 return SBThreadPlan();
194 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000195}
196
197SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000198SBThreadPlan::QueueThreadPlanForRunToAddress(SBAddress sb_address) {
199 if (m_opaque_sp) {
200 Address *address = sb_address.get();
201 if (!address)
202 return SBThreadPlan();
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000203
Kate Stoneb9c1b512016-09-06 20:57:50 +0000204 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForRunToAddress(
205 false, *address, false));
206 } else {
207 return SBThreadPlan();
208 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000209}
Aleksandr Urakovc1c0fac2018-10-25 08:27:42 +0000210
211SBThreadPlan
212SBThreadPlan::QueueThreadPlanForStepScripted(const char *script_class_name) {
213 if (m_opaque_sp) {
214 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepScripted(
215 false, script_class_name, false));
216 } else {
217 return SBThreadPlan();
218 }
219}