blob: a19023f66de237334c45bcbada64d538c56b62ae [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"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000019#include "lldb/Interpreter/CommandInterpreter.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000020#include "lldb/Symbol/CompileUnit.h"
21#include "lldb/Symbol/SymbolContext.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000022#include "lldb/Target/Process.h"
23#include "lldb/Target/Queue.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000024#include "lldb/Target/StopInfo.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000025#include "lldb/Target/SystemRuntime.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000026#include "lldb/Target/Target.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000027#include "lldb/Target/Thread.h"
28#include "lldb/Target/ThreadPlan.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000029#include "lldb/Target/ThreadPlanPython.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000030#include "lldb/Target/ThreadPlanStepInRange.h"
Jim Ingham2bdbfd52014-09-29 23:17:18 +000031#include "lldb/Target/ThreadPlanStepInstruction.h"
32#include "lldb/Target/ThreadPlanStepOut.h"
33#include "lldb/Target/ThreadPlanStepRange.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
141// of a
142// Scripted Thread Plan. Need a way to enforce that.
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000143
144SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000145SBThreadPlan::QueueThreadPlanForStepOverRange(SBAddress &sb_start_address,
146 lldb::addr_t size) {
147 if (m_opaque_sp) {
148 Address *start_address = sb_start_address.get();
149 if (!start_address) {
150 return SBThreadPlan();
151 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000152
Kate Stoneb9c1b512016-09-06 20:57:50 +0000153 AddressRange range(*start_address, size);
154 SymbolContext sc;
155 start_address->CalculateSymbolContext(&sc);
156 return SBThreadPlan(
157 m_opaque_sp->GetThread().QueueThreadPlanForStepOverRange(
158 false, range, sc, eAllThreads));
159 } else {
160 return SBThreadPlan();
161 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000162}
163
164SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000165SBThreadPlan::QueueThreadPlanForStepInRange(SBAddress &sb_start_address,
166 lldb::addr_t size) {
167 if (m_opaque_sp) {
168 Address *start_address = sb_start_address.get();
169 if (!start_address) {
170 return SBThreadPlan();
171 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000172
Kate Stoneb9c1b512016-09-06 20:57:50 +0000173 AddressRange range(*start_address, size);
174 SymbolContext sc;
175 start_address->CalculateSymbolContext(&sc);
176 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepInRange(
177 false, range, sc, NULL, eAllThreads));
178 } else {
179 return SBThreadPlan();
180 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000181}
182
183SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000184SBThreadPlan::QueueThreadPlanForStepOut(uint32_t frame_idx_to_step_to,
185 bool first_insn) {
186 if (m_opaque_sp) {
187 SymbolContext sc;
188 sc = m_opaque_sp->GetThread().GetStackFrameAtIndex(0)->GetSymbolContext(
189 lldb::eSymbolContextEverything);
190 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForStepOut(
191 false, &sc, first_insn, false, eVoteYes, eVoteNoOpinion,
192 frame_idx_to_step_to));
193 } else {
194 return SBThreadPlan();
195 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000196}
197
198SBThreadPlan
Kate Stoneb9c1b512016-09-06 20:57:50 +0000199SBThreadPlan::QueueThreadPlanForRunToAddress(SBAddress sb_address) {
200 if (m_opaque_sp) {
201 Address *address = sb_address.get();
202 if (!address)
203 return SBThreadPlan();
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000204
Kate Stoneb9c1b512016-09-06 20:57:50 +0000205 return SBThreadPlan(m_opaque_sp->GetThread().QueueThreadPlanForRunToAddress(
206 false, *address, false));
207 } else {
208 return SBThreadPlan();
209 }
Jim Ingham2bdbfd52014-09-29 23:17:18 +0000210}