94 llvm::Expected<StoppedExecutionContext> exe_ctx =
101 if (exe_ctx->HasThreadScope()) {
102 queue_sp = exe_ctx->GetThreadPtr()->GetQueue();
113 return this->
operator bool();
115SBThread::operator
bool()
const {
120 llvm::Expected<StoppedExecutionContext> exe_ctx =
127 return m_opaque_sp->GetThreadSP().get() !=
nullptr;
140 llvm::Expected<StoppedExecutionContext> exe_ctx =
147 if (exe_ctx->HasThreadScope())
148 return exe_ctx->GetThreadPtr()->GetStopReason();
156 llvm::Expected<StoppedExecutionContext> exe_ctx =
159 if (exe_ctx->HasThreadScope()) {
160 StopInfoSP stop_info_sp = exe_ctx->GetThreadPtr()->GetStopInfo();
162 return stop_info_sp->GetStopReasonDataCount();
174 llvm::Expected<StoppedExecutionContext> exe_ctx =
177 if (exe_ctx->HasThreadScope()) {
178 Thread *thread = exe_ctx->GetThreadPtr();
179 StopInfoSP stop_info_sp = thread->GetStopInfo();
181 return stop_info_sp->GetStopReasonDataAtIndex(idx);
195 llvm::Expected<StoppedExecutionContext> exe_ctx =
202 if (!exe_ctx->HasThreadScope())
205 StopInfoSP stop_info = exe_ctx->GetThreadPtr()->GetStopInfo();
221 llvm::Expected<StoppedExecutionContext> exe_ctx =
228 if (!exe_ctx->HasThreadScope())
231 ProcessSP process_sp = exe_ctx->GetProcessSP();
233 StopInfoSP stop_info = exe_ctx->GetThreadPtr()->GetStopInfo();
238 threads = process_sp->GetInstrumentationRuntime(type)
239 ->GetBacktracesFromExtendedStopInfo(info);
249 llvm::Expected<StoppedExecutionContext> exe_ctx =
256 if (!exe_ctx->HasThreadScope())
260 const std::string stop_desc = exe_ctx->GetThreadPtr()->GetStopDescription();
272 llvm::Expected<StoppedExecutionContext> exe_ctx =
279 if (!exe_ctx->HasThreadScope())
282 std::string thread_stop_desc = exe_ctx->GetThreadPtr()->GetStopDescription();
283 if (thread_stop_desc.empty())
287 return ::snprintf(dst_or_null, dst_len,
"%s", thread_stop_desc.c_str()) + 1;
291 return thread_stop_desc.size() + 1;
298 llvm::Expected<StoppedExecutionContext> exe_ctx =
305 if (exe_ctx->HasThreadScope()) {
306 StopInfoSP stop_info_sp = exe_ctx->GetThreadPtr()->GetStopInfo();
312 return SBValue(return_valobj_sp);
324 return thread_sp->GetID();
333 return thread_sp->GetIndexID();
340 llvm::Expected<StoppedExecutionContext> exe_ctx =
347 if (!exe_ctx->HasThreadScope())
356 llvm::Expected<StoppedExecutionContext> exe_ctx =
363 if (!exe_ctx->HasThreadScope())
373 llvm::Expected<StoppedExecutionContext> exe_ctx =
380 if (exe_ctx->HasThreadScope()) {
381 id = exe_ctx->GetThreadPtr()->GetQueueID();
390 bool success =
false;
391 llvm::Expected<StoppedExecutionContext> exe_ctx =
394 if (exe_ctx->HasThreadScope()) {
395 Thread *thread = exe_ctx->GetThreadPtr();
399 info_root_sp->GetObjectForDotSeparatedPath(path);
402 strm.
ref() << node->GetAsString()->GetValue();
406 strm.Printf(
"0x%" PRIx64, node->GetUnsignedIntegerValue());
410 strm.Printf(
"0x%f", node->GetAsFloat()->GetValue());
414 if (node->GetAsBoolean()->GetValue())
417 strm.Printf(
"false");
443 if (new_plan !=
nullptr) {
453 std::unique_lock<std::recursive_mutex> api_lock = exe_ctx.
AllowResume();
469 llvm::Expected<StoppedExecutionContext> exe_ctx =
476 if (!exe_ctx->HasThreadScope()) {
481 Thread *thread = exe_ctx->GetThreadPtr();
482 bool abort_other_plans =
false;
488 if (frame_sp->HasDebugInformation()) {
490 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
491 new_plan_sp = thread->QueueThreadPlanForStepOverRange(
492 abort_other_plans, sc.
line_entry, sc, stop_other_threads,
493 new_plan_status, avoid_no_debug);
495 new_plan_sp = thread->QueueThreadPlanForStepSingleInstruction(
496 true, abort_other_plans, stop_other_threads, new_plan_status);
505 StepInto(
nullptr, stop_other_threads);
520 llvm::Expected<StoppedExecutionContext> exe_ctx =
527 if (!exe_ctx->HasThreadScope()) {
532 bool abort_other_plans =
false;
534 Thread *thread = exe_ctx->GetThreadPtr();
539 if (frame_sp && frame_sp->HasDebugInformation()) {
540 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
552 const LazyBool step_out_avoids_code_without_debug_info =
554 const LazyBool step_in_avoids_code_without_debug_info =
556 new_plan_sp = thread->QueueThreadPlanForStepInRange(
557 abort_other_plans, range, sc, target_name, stop_other_threads,
558 new_plan_status, step_in_avoids_code_without_debug_info,
559 step_out_avoids_code_without_debug_info);
561 new_plan_sp = thread->QueueThreadPlanForStepSingleInstruction(
562 false, abort_other_plans, stop_other_threads, new_plan_status);
581 llvm::Expected<StoppedExecutionContext> exe_ctx =
588 if (!exe_ctx->HasThreadScope()) {
593 bool abort_other_plans =
false;
594 bool stop_other_threads =
false;
596 Thread *thread = exe_ctx->GetThreadPtr();
600 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepOut(
601 abort_other_plans,
nullptr,
false, stop_other_threads,
eVoteYes,
620 llvm::Expected<StoppedExecutionContext> exe_ctx =
634 if (!exe_ctx->HasThreadScope()) {
639 bool abort_other_plans =
false;
640 bool stop_other_threads =
false;
641 Thread *thread = exe_ctx->GetThreadPtr();
648 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepOut(
649 abort_other_plans,
nullptr,
false, stop_other_threads,
eVoteYes,
668 llvm::Expected<StoppedExecutionContext> exe_ctx =
675 if (!exe_ctx->HasThreadScope()) {
680 Thread *thread = exe_ctx->GetThreadPtr();
682 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepSingleInstruction(
683 step_over,
false,
true, new_plan_status));
701 llvm::Expected<StoppedExecutionContext> exe_ctx =
708 if (!exe_ctx->HasThreadScope()) {
713 bool abort_other_plans =
false;
714 bool stop_other_threads =
true;
718 Thread *thread = exe_ctx->GetThreadPtr();
721 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForRunToAddress(
722 abort_other_plans, target_addr, stop_other_threads, new_plan_status));
737 llvm::Expected<StoppedExecutionContext> exe_ctx =
744 if (exe_ctx->HasThreadScope()) {
745 Target *target = exe_ctx->GetTargetPtr();
746 Thread *thread = exe_ctx->GetThreadPtr();
760 frame_sp = thread->GetStackFrameAtIndex(0);
770 frame_sc = frame_sp->GetSymbolContext(
771 eSymbolContextCompUnit | eSymbolContextFunction |
772 eSymbolContextLineEntry | eSymbolContextSymbol);
776 "frame %u doesn't have debug information", frame_sp->GetFrameIndex());
783 step_file_spec = sb_file_spec.
ref();
789 "invalid file argument or no file for frame");
799 bool all_in_function =
true;
801 std::vector<addr_t> step_over_until_addrs;
802 const bool abort_other_plans =
false;
803 const bool stop_other_threads =
false;
806 step_file_spec, line, std::nullopt,
true,
811 eSymbolContextLineEntry, sc_list);
814 sc.line_entry.range.GetBaseAddress().GetLoadAddress(target);
819 step_over_until_addrs.push_back(step_addr);
821 all_in_function =
false;
825 if (step_over_until_addrs.empty()) {
826 if (all_in_function) {
827 step_file_spec.
GetPath(path,
sizeof(path));
829 "No line entries for %s:%u", path, line);
832 "step until target not in current function");
835 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepUntil(
836 abort_other_plans, &step_over_until_addrs[0],
837 step_over_until_addrs.size(), stop_other_threads,
838 frame_sp->GetFrameIndex(), new_plan_status));
841 sb_error =
ResumeNewPlan(std::move(*exe_ctx), new_plan_sp.get());
858 bool resume_immediately) {
868 bool resume_immediately) {
873 llvm::Expected<StoppedExecutionContext> exe_ctx =
878 if (!exe_ctx->HasThreadScope()) {
883 Thread *thread = exe_ctx->GetThreadPtr();
887 ThreadPlanSP new_plan_sp = thread->QueueThreadPlanForStepScripted(
888 false, script_class_name, obj_sp,
false, new_plan_status);
890 if (new_plan_status.
Fail()) {
895 if (!resume_immediately)
911 llvm::Expected<StoppedExecutionContext> exe_ctx =
916 if (!exe_ctx->HasThreadScope()) {
921 Thread *thread = exe_ctx->GetThreadPtr();
923 Status err = thread->JumpToLine(file_spec.
ref(), line,
true);
933 llvm::Expected<StoppedExecutionContext> exe_ctx =
938 if (exe_ctx->HasThreadScope()) {
939 Thread *thread = exe_ctx->GetThreadPtr();
952 llvm::Expected<StoppedExecutionContext> exe_ctx =
957 if (exe_ctx->HasThreadScope()) {
958 Thread *thread = exe_ctx->GetThreadPtr();
959 sb_error.
SetError(thread->UnwindInnermostExpression());
961 thread->SetSelectedFrameByIndex(0,
false);
977 llvm::Expected<StoppedExecutionContext> exe_ctx =
985 if (exe_ctx->HasThreadScope()) {
1003 llvm::Expected<StoppedExecutionContext> exe_ctx =
1011 bool result =
false;
1012 if (exe_ctx->HasThreadScope()) {
1013 const bool override_suspend =
true;
1014 exe_ctx->GetThreadPtr()->SetResumeState(
eStateRunning, override_suspend);
1024 llvm::Expected<StoppedExecutionContext> exe_ctx =
1031 if (exe_ctx->HasThreadScope())
1039 llvm::Expected<StoppedExecutionContext> exe_ctx =
1046 if (exe_ctx->HasThreadScope())
1055 llvm::Expected<StoppedExecutionContext> exe_ctx =
1062 if (exe_ctx->HasThreadScope()) {
1065 sb_process.
SetSP(exe_ctx->GetProcessSP());
1074 llvm::Expected<StoppedExecutionContext> exe_ctx =
1081 if (exe_ctx->HasThreadScope())
1082 return exe_ctx->GetThreadPtr()->GetStackFrameCount();
1091 llvm::Expected<StoppedExecutionContext> exe_ctx =
1098 if (exe_ctx->HasThreadScope()) {
1099 StackFrameSP frame_sp = exe_ctx->GetThreadPtr()->GetStackFrameAtIndex(idx);
1110 llvm::Expected<StoppedExecutionContext> exe_ctx =
1117 if (exe_ctx->HasThreadScope()) {
1119 exe_ctx->GetThreadPtr()->GetStackFrameList();
1123 return sb_frame_list;
1130 llvm::Expected<StoppedExecutionContext> exe_ctx =
1137 if (exe_ctx->HasThreadScope()) {
1151 llvm::Expected<StoppedExecutionContext> exe_ctx =
1158 if (exe_ctx->HasThreadScope()) {
1159 Thread *thread = exe_ctx->GetThreadPtr();
1160 frame_sp = thread->GetStackFrameAtIndex(idx);
1162 thread->SetSelectedFrame(frame_sp.get());
1207 llvm::Expected<StoppedExecutionContext> exe_ctx =
1214 if (exe_ctx->HasThreadScope()) {
1215 exe_ctx->GetThreadPtr()->GetStatus(strm, 0, 1, 1,
true,
1234 llvm::Expected<StoppedExecutionContext> exe_ctx =
1241 if (exe_ctx->HasThreadScope()) {
1242 exe_ctx->GetThreadPtr()->DumpUsingSettingsFormat(
1260 llvm::Expected<StoppedExecutionContext> exe_ctx =
1267 if (exe_ctx->HasThreadScope()) {
1268 if (exe_ctx->GetThreadPtr()->DumpUsingFormat(
1275 "It was not possible to generate a thread description with the given "
1276 "format string '%s'",
1284 llvm::Expected<StoppedExecutionContext> exe_ctx =
1288 if (exe_ctx->HasThreadScope()) {
1289 ThreadSP real_thread(exe_ctx->GetThreadSP());
1292 Process *process = exe_ctx->GetProcessPtr();
1298 if (new_thread_sp) {
1302 sb_origin_thread.
SetThread(new_thread_sp);
1312 return sb_origin_thread;
1320 return thread_sp->GetExtendedBacktraceOriginatingIndexID();
1331 return SBValue(thread_sp->GetCurrentException());
1341 return SBThread(thread_sp->GetCurrentExceptionBacktrace());
1349 return thread_sp->SafeToCallFunctions();
1369 return thread_sp->GetSiginfoValue();
static llvm::raw_ostream & error(Stream &strm)
#define LLDB_INSTRUMENT()
#define LLDB_INSTRUMENT_VA(...)
#define LLDB_LOG_ERROR(log, error,...)
static Status ResumeNewPlan(StoppedExecutionContext exe_ctx, ThreadPlan *new_plan)
void SetError(uint32_t err, lldb::ErrorType type)
lldb_private::Event * get() const
const lldb_private::FileSpec & ref() const
Represents a list of SBFrame objects.
void SetFrameList(const lldb::StackFrameListSP &frame_list_sp)
void SetFrameSP(const lldb::StackFrameSP &lldb_object_sp)
lldb::SBThread GetThread() const
lldb::StackFrameSP GetFrameSP() const
void SetSP(const lldb::ProcessSP &process_sp)
void SetQueue(const lldb::QueueSP &queue_sp)
lldb_private::Stream & ref()
StructuredDataImplUP m_impl_up
static const char * GetBroadcasterClassName()
void StepInto(lldb::RunMode stop_other_threads=lldb::eOnlyDuringStepping)
bool Suspend()
LLDB currently supports process centric debugging which means when any thread in a process stops,...
const char * GetName() const
bool GetStopDescription(lldb::SBStream &stream) const
Gets a human-readable description of why the thread stopped.
const lldb::SBThread & operator=(const lldb::SBThread &rhs)
lldb::SBFrame SetSelectedFrame(uint32_t frame_idx)
SBError UnwindInnermostExpression()
friend class SBThreadCollection
const char * GetQueueName() const
uint32_t GetIndexID() const
bool GetDescription(lldb::SBStream &description) const
static bool EventIsThreadEvent(const SBEvent &event)
lldb_private::Thread * operator->()
lldb_private::Thread * get()
void StepOutOfFrame(SBFrame &frame)
bool GetStatus(lldb::SBStream &status) const
static SBFrame GetStackFrameFromEvent(const SBEvent &event)
lldb::queue_id_t GetQueueID() const
bool GetInfoItemByPathAsString(const char *path, SBStream &strm)
lldb::SBFrame GetSelectedFrame()
bool operator!=(const lldb::SBThread &rhs) const
SBError StepUsingScriptedThreadPlan(const char *script_class_name)
lldb::tid_t GetThreadID() const
lldb::SBFrame GetFrameAtIndex(uint32_t idx)
uint32_t GetExtendedBacktraceOriginatingIndexID()
lldb::SBQueue GetQueue() const
lldb::SBFrameList GetFrames()
bool SafeToCallFunctions()
lldb::SBProcess GetProcess()
size_t GetStopReasonDataCount()
Get the number of words associated with the stop reason.
void StepInstruction(bool step_over)
SBThread GetCurrentExceptionBacktrace()
static SBThread GetThreadFromEvent(const SBEvent &event)
bool GetStopReasonExtendedInfoAsJSON(lldb::SBStream &stream)
lldb::StopReason GetStopReason()
SBValue GetStopReturnValue()
void StepOver(lldb::RunMode stop_other_threads=lldb::eOnlyDuringStepping)
SBError JumpToLine(lldb::SBFileSpec &file_spec, uint32_t line)
SBError GetDescriptionWithFormat(const SBFormat &format, SBStream &output)
Similar to GetDescription() but the format of the description can be configured via the format parame...
SBThreadCollection GetStopReasonExtendedBacktraces(InstrumentationRuntimeType type)
SBValue GetCurrentException()
void SetThread(const lldb::ThreadSP &lldb_object_sp)
lldb::ThreadSP GetSP() const
SBThread GetExtendedBacktraceThread(const char *type)
lldb::ExecutionContextRefSP m_opaque_sp
void RunToAddress(lldb::addr_t addr)
uint64_t GetStopReasonDataAtIndex(uint32_t idx)
Get information associated with a stop reason.
SBError ReturnFromFrame(SBFrame &frame, SBValue &return_value)
bool operator==(const lldb::SBThread &rhs) const
SBError StepOverUntil(lldb::SBFrame &frame, lldb::SBFileSpec &file_spec, uint32_t line)
lldb::ValueObjectSP GetSP() const
Same as the protected version of GetSP that takes a locker, except that we make the locker locally in...
A section + offset based address range class.
A section + offset based address class.
void ResolveSymbolContext(const SourceLocationSpec &src_location_spec, lldb::SymbolContextItem resolve_scope, SymbolContextList &sc_list, RealpathPrefixes *realpath_prefixes=nullptr)
Resolve symbol contexts by file and line.
A uniqued constant string class.
const char * AsCString(const char *value_if_empty=nullptr) const
Get the string value as a C string.
const char * GetCString() const
Get the string value as a C string.
Execution context objects refer to objects in the execution of the program that is being debugged.
Process * GetProcessPtr() const
Returns a pointer to the process object.
Thread * GetThreadPtr() const
Returns a pointer to the thread object.
size_t GetPath(char *path, size_t max_path_length, bool denormalize=true) const
Extract the full path to the file.
bool GetRangeContainingLoadAddress(lldb::addr_t load_addr, Target &target, AddressRange &range)
A plug-in interface definition class for debugging a process.
ThreadList & GetThreadList()
Status Resume()
Resumes all of a process's threads as configured using the Thread run control functions.
virtual SystemRuntime * GetSystemRuntime()
Get the system runtime plug-in for this process.
ThreadList & GetExtendedThreadList()
Status ResumeSynchronous(Stream *stream)
Resume a process, and wait for it to stop.
Target & GetTarget()
Get the target object pointer for this module.
"lldb/Core/SourceLocationSpec.h" A source location specifier class.
static Status FromErrorStringWithFormat(const char *format,...) __attribute__((format(printf
static Status FromErrorString(const char *str)
bool Fail() const
Test for error condition.
const char * AsCString(const char *default_error_str="unknown error") const
Get the error string associated with the current error.
static Status FromError(llvm::Error error)
Avoid using this in new code. Migrate APIs to llvm::Expected instead.
bool Success() const
Test for success condition.
static lldb::ValueObjectSP GetReturnValueObject(lldb::StopInfoSP &stop_info_sp)
A stream class that can stream formatted output to a file.
size_t PutCString(llvm::StringRef cstr)
Output a C string to the stream.
std::shared_ptr< Object > ObjectSP
Defines a list of symbol context objects.
Defines a symbol context baton that can be handed other debug core functions.
llvm::Error GetAddressRangeFromHereToEndLine(uint32_t end_line, AddressRange &range)
Function * function
The Function for a given query.
CompileUnit * comp_unit
The CompileUnit for a given query.
LineEntry line_entry
The LineEntry for a given query.
A plug-in interface definition class for system runtimes.
virtual lldb::ThreadSP GetExtendedBacktraceThread(lldb::ThreadSP thread, ConstString type)
Return a Thread which shows the origin of this thread's creation.
Debugger & GetDebugger() const
void AddThread(const lldb::ThreadSP &thread_sp)
bool SetSelectedThreadByID(lldb::tid_t tid, bool notify=false)
void SetOkayToDiscard(bool value)
bool SetIsControllingPlan(bool value)
static const ThreadEventData * GetEventDataFromEvent(const Event *event_ptr)
static lldb::ThreadSP GetThreadFromEvent(const Event *event_ptr)
static lldb::StackFrameSP GetStackFrameFromEvent(const Event *event_ptr)
static llvm::StringRef GetStaticBroadcasterClass()
#define LLDB_INVALID_QUEUE_ID
#define LLDB_INVALID_LINE_NUMBER
#define LLDB_INVALID_THREAD_ID
#define LLDB_INVALID_INDEX32
#define LLDB_INVALID_ADDRESS
@ DoNoSelectMostRelevantFrame
@ SelectMostRelevantFrame
A class that represents a running process on the host machine.
Log * GetLog(Cat mask)
Retrieve the Log object for the channel associated with the given log enum.
bool StateIsStoppedState(lldb::StateType state, bool must_exist)
Check if a state represents a state where the process or thread is stopped.
std::unique_ptr< T > clone(const std::unique_ptr< T > &src)
llvm::Expected< StoppedExecutionContext > GetStoppedExecutionContext(const ExecutionContextRef *exe_ctx_ref_ptr)
std::shared_ptr< lldb_private::ThreadPlan > ThreadPlanSP
std::shared_ptr< lldb_private::Queue > QueueSP
std::shared_ptr< lldb_private::StackFrame > StackFrameSP
std::shared_ptr< lldb_private::Thread > ThreadSP
std::shared_ptr< lldb_private::ValueObject > ValueObjectSP
@ eStateSuspended
Process or thread is in a suspended state as far as the debugger is concerned while other processes o...
@ eStateRunning
Process or thread is running and can't be examined.
std::shared_ptr< lldb_private::Process > ProcessSP
InstrumentationRuntimeType
std::shared_ptr< lldb_private::StopInfo > StopInfoSP
StopReason
Thread stop reasons.
@ eStructuredDataTypeFloat
@ eStructuredDataTypeInteger
@ eStructuredDataTypeNull
@ eStructuredDataTypeBoolean
@ eStructuredDataTypeString
std::shared_ptr< lldb_private::StackFrameList > StackFrameListSP
bool IsValid() const
Check if a line entry object is valid.
AddressRange range
The section offset address range for this line entry.
const FileSpec & GetFile() const
Helper to access the file.
A wrapper class representing an execution context with non-null Target and Process pointers,...
std::unique_lock< std::recursive_mutex > AllowResume()
Clears this context, unlocking the ProcessRunLock and returning the locked API lock,...