93 llvm::Expected<StoppedExecutionContext> exe_ctx =
100 if (exe_ctx->HasThreadScope()) {
101 queue_sp = exe_ctx->GetThreadPtr()->GetQueue();
112 return this->
operator bool();
114SBThread::operator
bool()
const {
119 llvm::Expected<StoppedExecutionContext> exe_ctx =
126 return m_opaque_sp->GetThreadSP().get() !=
nullptr;
139 llvm::Expected<StoppedExecutionContext> exe_ctx =
146 if (exe_ctx->HasThreadScope())
147 return exe_ctx->GetThreadPtr()->GetStopReason();
155 llvm::Expected<StoppedExecutionContext> exe_ctx =
158 if (exe_ctx->HasThreadScope()) {
159 StopInfoSP stop_info_sp = exe_ctx->GetThreadPtr()->GetStopInfo();
161 return stop_info_sp->GetStopReasonDataCount();
173 llvm::Expected<StoppedExecutionContext> exe_ctx =
176 if (exe_ctx->HasThreadScope()) {
177 Thread *thread = exe_ctx->GetThreadPtr();
178 StopInfoSP stop_info_sp = thread->GetStopInfo();
180 return stop_info_sp->GetStopReasonDataAtIndex(idx);
194 llvm::Expected<StoppedExecutionContext> exe_ctx =
201 if (!exe_ctx->HasThreadScope())
204 StopInfoSP stop_info = exe_ctx->GetThreadPtr()->GetStopInfo();
220 llvm::Expected<StoppedExecutionContext> exe_ctx =
227 if (!exe_ctx->HasThreadScope())
230 ProcessSP process_sp = exe_ctx->GetProcessSP();
232 StopInfoSP stop_info = exe_ctx->GetThreadPtr()->GetStopInfo();
237 threads = process_sp->GetInstrumentationRuntime(type)
238 ->GetBacktracesFromExtendedStopInfo(info);
248 llvm::Expected<StoppedExecutionContext> exe_ctx =
255 if (!exe_ctx->HasThreadScope())
259 const std::string stop_desc = exe_ctx->GetThreadPtr()->GetStopDescription();
271 llvm::Expected<StoppedExecutionContext> exe_ctx =
278 if (!exe_ctx->HasThreadScope())
281 std::string thread_stop_desc = exe_ctx->GetThreadPtr()->GetStopDescription();
282 if (thread_stop_desc.empty())
286 return ::snprintf(dst_or_null, dst_len,
"%s", thread_stop_desc.c_str()) + 1;
290 return thread_stop_desc.size() + 1;
297 llvm::Expected<StoppedExecutionContext> exe_ctx =
304 if (exe_ctx->HasThreadScope()) {
305 StopInfoSP stop_info_sp = exe_ctx->GetThreadPtr()->GetStopInfo();
311 return SBValue(return_valobj_sp);
323 return thread_sp->GetID();
332 return thread_sp->GetIndexID();
339 llvm::Expected<StoppedExecutionContext> exe_ctx =
346 if (!exe_ctx->HasThreadScope())
355 llvm::Expected<StoppedExecutionContext> exe_ctx =
362 if (!exe_ctx->HasThreadScope())
372 llvm::Expected<StoppedExecutionContext> exe_ctx =
379 if (exe_ctx->HasThreadScope()) {
380 id = exe_ctx->GetThreadPtr()->GetQueueID();
389 bool success =
false;
390 llvm::Expected<StoppedExecutionContext> exe_ctx =
393 if (exe_ctx->HasThreadScope()) {
394 Thread *thread = exe_ctx->GetThreadPtr();
398 info_root_sp->GetObjectForDotSeparatedPath(path);
401 strm.
ref() << node->GetAsString()->GetValue();
405 strm.Printf(
"0x%" PRIx64, node->GetUnsignedIntegerValue());
409 strm.Printf(
"0x%f", node->GetAsFloat()->GetValue());
413 if (node->GetAsBoolean()->GetValue())
416 strm.Printf(
"false");
442 if (new_plan !=
nullptr) {
452 std::unique_lock<std::recursive_mutex> api_lock = exe_ctx.
AllowResume();
468 llvm::Expected<StoppedExecutionContext> exe_ctx =
475 if (!exe_ctx->HasThreadScope()) {
480 Thread *thread = exe_ctx->GetThreadPtr();
481 bool abort_other_plans =
false;
487 if (frame_sp->HasDebugInformation()) {
489 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
490 new_plan_sp = thread->QueueThreadPlanForStepOverRange(
491 abort_other_plans, sc.
line_entry, sc, stop_other_threads,
492 new_plan_status, avoid_no_debug);
494 new_plan_sp = thread->QueueThreadPlanForStepSingleInstruction(
495 true, abort_other_plans, stop_other_threads, new_plan_status);
504 StepInto(
nullptr, stop_other_threads);
519 llvm::Expected<StoppedExecutionContext> exe_ctx =
526 if (!exe_ctx->HasThreadScope()) {
531 bool abort_other_plans =
false;
533 Thread *thread = exe_ctx->GetThreadPtr();
538 if (frame_sp && frame_sp->HasDebugInformation()) {
539 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
551 const LazyBool step_out_avoids_code_without_debug_info =
553 const LazyBool step_in_avoids_code_without_debug_info =
555 new_plan_sp = thread->QueueThreadPlanForStepInRange(
556 abort_other_plans, range, sc, target_name, stop_other_threads,
557 new_plan_status, step_in_avoids_code_without_debug_info,
558 step_out_avoids_code_without_debug_info);
560 new_plan_sp = thread->QueueThreadPlanForStepSingleInstruction(
561 false, abort_other_plans, stop_other_threads, new_plan_status);
580 llvm::Expected<StoppedExecutionContext> exe_ctx =
587 if (!exe_ctx->HasThreadScope()) {
592 bool abort_other_plans =
false;
593 bool stop_other_threads =
false;
595 Thread *thread = exe_ctx->GetThreadPtr();
599 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepOut(
600 abort_other_plans,
nullptr,
false, stop_other_threads,
eVoteYes,
619 llvm::Expected<StoppedExecutionContext> exe_ctx =
633 if (!exe_ctx->HasThreadScope()) {
638 bool abort_other_plans =
false;
639 bool stop_other_threads =
false;
640 Thread *thread = exe_ctx->GetThreadPtr();
647 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepOut(
648 abort_other_plans,
nullptr,
false, stop_other_threads,
eVoteYes,
667 llvm::Expected<StoppedExecutionContext> exe_ctx =
674 if (!exe_ctx->HasThreadScope()) {
679 Thread *thread = exe_ctx->GetThreadPtr();
681 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepSingleInstruction(
682 step_over,
false,
true, new_plan_status));
700 llvm::Expected<StoppedExecutionContext> exe_ctx =
707 if (!exe_ctx->HasThreadScope()) {
712 bool abort_other_plans =
false;
713 bool stop_other_threads =
true;
717 Thread *thread = exe_ctx->GetThreadPtr();
720 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForRunToAddress(
721 abort_other_plans, target_addr, stop_other_threads, new_plan_status));
736 llvm::Expected<StoppedExecutionContext> exe_ctx =
743 if (exe_ctx->HasThreadScope()) {
744 Target *target = exe_ctx->GetTargetPtr();
745 Thread *thread = exe_ctx->GetThreadPtr();
759 frame_sp = thread->GetStackFrameAtIndex(0);
769 frame_sc = frame_sp->GetSymbolContext(
770 eSymbolContextCompUnit | eSymbolContextFunction |
771 eSymbolContextLineEntry | eSymbolContextSymbol);
775 "frame %u doesn't have debug information", frame_sp->GetFrameIndex());
782 step_file_spec = sb_file_spec.
ref();
788 "invalid file argument or no file for frame");
798 bool all_in_function =
true;
800 std::vector<addr_t> step_over_until_addrs;
801 const bool abort_other_plans =
false;
802 const bool stop_other_threads =
false;
805 step_file_spec, line, std::nullopt,
true,
810 eSymbolContextLineEntry, sc_list);
813 sc.line_entry.range.GetBaseAddress().GetLoadAddress(target);
818 step_over_until_addrs.push_back(step_addr);
820 all_in_function =
false;
824 if (step_over_until_addrs.empty()) {
825 if (all_in_function) {
826 step_file_spec.
GetPath(path,
sizeof(path));
828 "No line entries for %s:%u", path, line);
831 "step until target not in current function");
834 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepUntil(
835 abort_other_plans, &step_over_until_addrs[0],
836 step_over_until_addrs.size(), stop_other_threads,
837 frame_sp->GetFrameIndex(), new_plan_status));
840 sb_error =
ResumeNewPlan(std::move(*exe_ctx), new_plan_sp.get());
857 bool resume_immediately) {
867 bool resume_immediately) {
872 llvm::Expected<StoppedExecutionContext> exe_ctx =
877 if (!exe_ctx->HasThreadScope()) {
882 Thread *thread = exe_ctx->GetThreadPtr();
886 ThreadPlanSP new_plan_sp = thread->QueueThreadPlanForStepScripted(
887 false, script_class_name, obj_sp,
false, new_plan_status);
889 if (new_plan_status.
Fail()) {
894 if (!resume_immediately)
910 llvm::Expected<StoppedExecutionContext> exe_ctx =
915 if (!exe_ctx->HasThreadScope()) {
920 Thread *thread = exe_ctx->GetThreadPtr();
922 Status err = thread->JumpToLine(file_spec.
ref(), line,
true);
932 llvm::Expected<StoppedExecutionContext> exe_ctx =
937 if (exe_ctx->HasThreadScope()) {
938 Thread *thread = exe_ctx->GetThreadPtr();
951 llvm::Expected<StoppedExecutionContext> exe_ctx =
956 if (exe_ctx->HasThreadScope()) {
957 Thread *thread = exe_ctx->GetThreadPtr();
958 sb_error.
SetError(thread->UnwindInnermostExpression());
960 thread->SetSelectedFrameByIndex(0,
false);
976 llvm::Expected<StoppedExecutionContext> exe_ctx =
984 if (exe_ctx->HasThreadScope()) {
1002 llvm::Expected<StoppedExecutionContext> exe_ctx =
1010 bool result =
false;
1011 if (exe_ctx->HasThreadScope()) {
1012 const bool override_suspend =
true;
1013 exe_ctx->GetThreadPtr()->SetResumeState(
eStateRunning, override_suspend);
1023 llvm::Expected<StoppedExecutionContext> exe_ctx =
1030 if (exe_ctx->HasThreadScope())
1038 llvm::Expected<StoppedExecutionContext> exe_ctx =
1045 if (exe_ctx->HasThreadScope())
1054 llvm::Expected<StoppedExecutionContext> exe_ctx =
1061 if (exe_ctx->HasThreadScope()) {
1064 sb_process.
SetSP(exe_ctx->GetProcessSP());
1073 llvm::Expected<StoppedExecutionContext> exe_ctx =
1080 if (exe_ctx->HasThreadScope())
1081 return exe_ctx->GetThreadPtr()->GetStackFrameCount();
1090 llvm::Expected<StoppedExecutionContext> exe_ctx =
1097 if (exe_ctx->HasThreadScope()) {
1098 StackFrameSP frame_sp = exe_ctx->GetThreadPtr()->GetStackFrameAtIndex(idx);
1109 llvm::Expected<StoppedExecutionContext> exe_ctx =
1116 if (exe_ctx->HasThreadScope()) {
1130 llvm::Expected<StoppedExecutionContext> exe_ctx =
1137 if (exe_ctx->HasThreadScope()) {
1138 Thread *thread = exe_ctx->GetThreadPtr();
1141 thread->SetSelectedFrame(frame_sp.get());
1186 llvm::Expected<StoppedExecutionContext> exe_ctx =
1193 if (exe_ctx->HasThreadScope()) {
1194 exe_ctx->GetThreadPtr()->GetStatus(strm, 0, 1, 1,
true,
1213 llvm::Expected<StoppedExecutionContext> exe_ctx =
1220 if (exe_ctx->HasThreadScope()) {
1221 exe_ctx->GetThreadPtr()->DumpUsingSettingsFormat(
1239 llvm::Expected<StoppedExecutionContext> exe_ctx =
1246 if (exe_ctx->HasThreadScope()) {
1247 if (exe_ctx->GetThreadPtr()->DumpUsingFormat(
1254 "It was not possible to generate a thread description with the given "
1255 "format string '%s'",
1263 llvm::Expected<StoppedExecutionContext> exe_ctx =
1267 if (exe_ctx->HasThreadScope()) {
1268 ThreadSP real_thread(exe_ctx->GetThreadSP());
1271 Process *process = exe_ctx->GetProcessPtr();
1277 if (new_thread_sp) {
1281 sb_origin_thread.
SetThread(new_thread_sp);
1291 return sb_origin_thread;
1299 return thread_sp->GetExtendedBacktraceOriginatingIndexID();
1310 return SBValue(thread_sp->GetCurrentException());
1320 return SBThread(thread_sp->GetCurrentExceptionBacktrace());
1328 return thread_sp->SafeToCallFunctions();
1348 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
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
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)
virtual lldb::StackFrameSP GetStackFrameAtIndex(uint32_t idx)
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
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,...