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())
258 std::string thread_stop_desc = exe_ctx->GetThreadPtr()->GetStopDescription();
259 if (thread_stop_desc.empty())
263 return ::snprintf(dst, dst_len,
"%s", thread_stop_desc.c_str()) + 1;
267 return thread_stop_desc.size() + 1;
274 llvm::Expected<StoppedExecutionContext> exe_ctx =
281 if (exe_ctx->HasThreadScope()) {
282 StopInfoSP stop_info_sp = exe_ctx->GetThreadPtr()->GetStopInfo();
288 return SBValue(return_valobj_sp);
300 return thread_sp->GetID();
309 return thread_sp->GetIndexID();
316 llvm::Expected<StoppedExecutionContext> exe_ctx =
323 if (!exe_ctx->HasThreadScope())
332 llvm::Expected<StoppedExecutionContext> exe_ctx =
339 if (!exe_ctx->HasThreadScope())
349 llvm::Expected<StoppedExecutionContext> exe_ctx =
356 if (exe_ctx->HasThreadScope()) {
357 id = exe_ctx->GetThreadPtr()->GetQueueID();
366 bool success =
false;
367 llvm::Expected<StoppedExecutionContext> exe_ctx =
370 if (exe_ctx->HasThreadScope()) {
371 Thread *thread = exe_ctx->GetThreadPtr();
375 info_root_sp->GetObjectForDotSeparatedPath(path);
378 strm.
ref() << node->GetAsString()->GetValue();
382 strm.Printf(
"0x%" PRIx64, node->GetUnsignedIntegerValue());
386 strm.Printf(
"0x%f", node->GetAsFloat()->GetValue());
390 if (node->GetAsBoolean()->GetValue())
393 strm.Printf(
"false");
419 if (new_plan !=
nullptr) {
429 std::unique_lock<std::recursive_mutex> api_lock = exe_ctx.
AllowResume();
445 llvm::Expected<StoppedExecutionContext> exe_ctx =
452 if (!exe_ctx->HasThreadScope()) {
457 Thread *thread = exe_ctx->GetThreadPtr();
458 bool abort_other_plans =
false;
464 if (frame_sp->HasDebugInformation()) {
466 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
467 new_plan_sp = thread->QueueThreadPlanForStepOverRange(
468 abort_other_plans, sc.
line_entry, sc, stop_other_threads,
469 new_plan_status, avoid_no_debug);
471 new_plan_sp = thread->QueueThreadPlanForStepSingleInstruction(
472 true, abort_other_plans, stop_other_threads, new_plan_status);
481 StepInto(
nullptr, stop_other_threads);
496 llvm::Expected<StoppedExecutionContext> exe_ctx =
503 if (!exe_ctx->HasThreadScope()) {
508 bool abort_other_plans =
false;
510 Thread *thread = exe_ctx->GetThreadPtr();
515 if (frame_sp && frame_sp->HasDebugInformation()) {
516 SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything));
528 const LazyBool step_out_avoids_code_without_debug_info =
530 const LazyBool step_in_avoids_code_without_debug_info =
532 new_plan_sp = thread->QueueThreadPlanForStepInRange(
533 abort_other_plans, range, sc, target_name, stop_other_threads,
534 new_plan_status, step_in_avoids_code_without_debug_info,
535 step_out_avoids_code_without_debug_info);
537 new_plan_sp = thread->QueueThreadPlanForStepSingleInstruction(
538 false, abort_other_plans, stop_other_threads, new_plan_status);
557 llvm::Expected<StoppedExecutionContext> exe_ctx =
564 if (!exe_ctx->HasThreadScope()) {
569 bool abort_other_plans =
false;
570 bool stop_other_threads =
false;
572 Thread *thread = exe_ctx->GetThreadPtr();
576 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepOut(
577 abort_other_plans,
nullptr,
false, stop_other_threads,
eVoteYes,
596 llvm::Expected<StoppedExecutionContext> exe_ctx =
610 if (!exe_ctx->HasThreadScope()) {
615 bool abort_other_plans =
false;
616 bool stop_other_threads =
false;
617 Thread *thread = exe_ctx->GetThreadPtr();
624 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepOut(
625 abort_other_plans,
nullptr,
false, stop_other_threads,
eVoteYes,
644 llvm::Expected<StoppedExecutionContext> exe_ctx =
651 if (!exe_ctx->HasThreadScope()) {
656 Thread *thread = exe_ctx->GetThreadPtr();
658 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepSingleInstruction(
659 step_over,
false,
true, new_plan_status));
677 llvm::Expected<StoppedExecutionContext> exe_ctx =
684 if (!exe_ctx->HasThreadScope()) {
689 bool abort_other_plans =
false;
690 bool stop_other_threads =
true;
694 Thread *thread = exe_ctx->GetThreadPtr();
697 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForRunToAddress(
698 abort_other_plans, target_addr, stop_other_threads, new_plan_status));
713 llvm::Expected<StoppedExecutionContext> exe_ctx =
720 if (exe_ctx->HasThreadScope()) {
721 Target *target = exe_ctx->GetTargetPtr();
722 Thread *thread = exe_ctx->GetThreadPtr();
736 frame_sp = thread->GetStackFrameAtIndex(0);
746 frame_sc = frame_sp->GetSymbolContext(
747 eSymbolContextCompUnit | eSymbolContextFunction |
748 eSymbolContextLineEntry | eSymbolContextSymbol);
752 "frame %u doesn't have debug information", frame_sp->GetFrameIndex());
759 step_file_spec = sb_file_spec.
ref();
765 "invalid file argument or no file for frame");
775 bool all_in_function =
true;
777 std::vector<addr_t> step_over_until_addrs;
778 const bool abort_other_plans =
false;
779 const bool stop_other_threads =
false;
782 step_file_spec, line, std::nullopt,
true,
787 eSymbolContextLineEntry, sc_list);
790 sc.line_entry.range.GetBaseAddress().GetLoadAddress(target);
795 step_over_until_addrs.push_back(step_addr);
797 all_in_function =
false;
801 if (step_over_until_addrs.empty()) {
802 if (all_in_function) {
803 step_file_spec.
GetPath(path,
sizeof(path));
805 "No line entries for %s:%u", path, line);
808 "step until target not in current function");
811 ThreadPlanSP new_plan_sp(thread->QueueThreadPlanForStepUntil(
812 abort_other_plans, &step_over_until_addrs[0],
813 step_over_until_addrs.size(), stop_other_threads,
814 frame_sp->GetFrameIndex(), new_plan_status));
817 sb_error =
ResumeNewPlan(std::move(*exe_ctx), new_plan_sp.get());
834 bool resume_immediately) {
844 bool resume_immediately) {
849 llvm::Expected<StoppedExecutionContext> exe_ctx =
854 if (!exe_ctx->HasThreadScope()) {
859 Thread *thread = exe_ctx->GetThreadPtr();
863 ThreadPlanSP new_plan_sp = thread->QueueThreadPlanForStepScripted(
864 false, script_class_name, obj_sp,
false, new_plan_status);
866 if (new_plan_status.
Fail()) {
871 if (!resume_immediately)
887 llvm::Expected<StoppedExecutionContext> exe_ctx =
892 if (!exe_ctx->HasThreadScope()) {
897 Thread *thread = exe_ctx->GetThreadPtr();
899 Status err = thread->JumpToLine(file_spec.
ref(), line,
true);
909 llvm::Expected<StoppedExecutionContext> exe_ctx =
914 if (exe_ctx->HasThreadScope()) {
915 Thread *thread = exe_ctx->GetThreadPtr();
928 llvm::Expected<StoppedExecutionContext> exe_ctx =
933 if (exe_ctx->HasThreadScope()) {
934 Thread *thread = exe_ctx->GetThreadPtr();
935 sb_error.
SetError(thread->UnwindInnermostExpression());
937 thread->SetSelectedFrameByIndex(0,
false);
953 llvm::Expected<StoppedExecutionContext> exe_ctx =
961 if (exe_ctx->HasThreadScope()) {
979 llvm::Expected<StoppedExecutionContext> exe_ctx =
988 if (exe_ctx->HasThreadScope()) {
989 const bool override_suspend =
true;
990 exe_ctx->GetThreadPtr()->SetResumeState(
eStateRunning, override_suspend);
1000 llvm::Expected<StoppedExecutionContext> exe_ctx =
1007 if (exe_ctx->HasThreadScope())
1015 llvm::Expected<StoppedExecutionContext> exe_ctx =
1022 if (exe_ctx->HasThreadScope())
1031 llvm::Expected<StoppedExecutionContext> exe_ctx =
1038 if (exe_ctx->HasThreadScope()) {
1041 sb_process.
SetSP(exe_ctx->GetProcessSP());
1050 llvm::Expected<StoppedExecutionContext> exe_ctx =
1057 if (exe_ctx->HasThreadScope())
1058 return exe_ctx->GetThreadPtr()->GetStackFrameCount();
1067 llvm::Expected<StoppedExecutionContext> exe_ctx =
1074 if (exe_ctx->HasThreadScope()) {
1075 StackFrameSP frame_sp = exe_ctx->GetThreadPtr()->GetStackFrameAtIndex(idx);
1086 llvm::Expected<StoppedExecutionContext> exe_ctx =
1093 if (exe_ctx->HasThreadScope()) {
1107 llvm::Expected<StoppedExecutionContext> exe_ctx =
1114 if (exe_ctx->HasThreadScope()) {
1115 Thread *thread = exe_ctx->GetThreadPtr();
1118 thread->SetSelectedFrame(frame_sp.get());
1163 llvm::Expected<StoppedExecutionContext> exe_ctx =
1170 if (exe_ctx->HasThreadScope()) {
1171 exe_ctx->GetThreadPtr()->GetStatus(strm, 0, 1, 1,
true,
1190 llvm::Expected<StoppedExecutionContext> exe_ctx =
1197 if (exe_ctx->HasThreadScope()) {
1198 exe_ctx->GetThreadPtr()->DumpUsingSettingsFormat(
1216 llvm::Expected<StoppedExecutionContext> exe_ctx =
1223 if (exe_ctx->HasThreadScope()) {
1224 if (exe_ctx->GetThreadPtr()->DumpUsingFormat(
1231 "It was not possible to generate a thread description with the given "
1232 "format string '%s'",
1240 llvm::Expected<StoppedExecutionContext> exe_ctx =
1244 if (exe_ctx->HasThreadScope()) {
1245 ThreadSP real_thread(exe_ctx->GetThreadSP());
1248 Process *process = exe_ctx->GetProcessPtr();
1254 if (new_thread_sp) {
1258 sb_origin_thread.
SetThread(new_thread_sp);
1268 return sb_origin_thread;
1276 return thread_sp->GetExtendedBacktraceOriginatingIndexID();
1287 return SBValue(thread_sp->GetCurrentException());
1297 return SBThread(thread_sp->GetCurrentExceptionBacktrace());
1305 return thread_sp->SafeToCallFunctions();
1325 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
size_t GetStopDescription(char *dst_or_null, size_t dst_len)
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
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,...