130fdc8d8SChris Lattner //===-- SBThread.cpp --------------------------------------------*- C++ -*-===// 230fdc8d8SChris Lattner // 330fdc8d8SChris Lattner // The LLVM Compiler Infrastructure 430fdc8d8SChris Lattner // 530fdc8d8SChris Lattner // This file is distributed under the University of Illinois Open Source 630fdc8d8SChris Lattner // License. See LICENSE.TXT for details. 730fdc8d8SChris Lattner // 830fdc8d8SChris Lattner //===----------------------------------------------------------------------===// 930fdc8d8SChris Lattner 104c5de699SEli Friedman #include "lldb/API/SBThread.h" 1130fdc8d8SChris Lattner 1230fdc8d8SChris Lattner #include "lldb/API/SBSymbolContext.h" 1330fdc8d8SChris Lattner #include "lldb/API/SBFileSpec.h" 14dde9cff3SCaroline Tice #include "lldb/API/SBStream.h" 156611103cSGreg Clayton #include "lldb/Core/Debugger.h" 1630fdc8d8SChris Lattner #include "lldb/Core/Stream.h" 1730fdc8d8SChris Lattner #include "lldb/Core/StreamFile.h" 186611103cSGreg Clayton #include "lldb/Interpreter/CommandInterpreter.h" 1930fdc8d8SChris Lattner #include "lldb/Target/Thread.h" 2030fdc8d8SChris Lattner #include "lldb/Target/Process.h" 2130fdc8d8SChris Lattner #include "lldb/Symbol/SymbolContext.h" 2230fdc8d8SChris Lattner #include "lldb/Symbol/CompileUnit.h" 23f4b47e15SGreg Clayton #include "lldb/Target/StopInfo.h" 2430fdc8d8SChris Lattner #include "lldb/Target/Target.h" 2530fdc8d8SChris Lattner #include "lldb/Target/ThreadPlan.h" 2630fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepInstruction.h" 2730fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepOut.h" 2830fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepRange.h" 2930fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanStepInRange.h" 3030fdc8d8SChris Lattner 3130fdc8d8SChris Lattner 324c5de699SEli Friedman #include "lldb/API/SBAddress.h" 334c5de699SEli Friedman #include "lldb/API/SBFrame.h" 344c5de699SEli Friedman #include "lldb/API/SBSourceManager.h" 354c5de699SEli Friedman #include "lldb/API/SBDebugger.h" 364c5de699SEli Friedman #include "lldb/API/SBProcess.h" 3730fdc8d8SChris Lattner 3830fdc8d8SChris Lattner using namespace lldb; 3930fdc8d8SChris Lattner using namespace lldb_private; 4030fdc8d8SChris Lattner 4130fdc8d8SChris Lattner SBThread::SBThread () : 426611103cSGreg Clayton m_opaque_sp () 4330fdc8d8SChris Lattner { 4430fdc8d8SChris Lattner } 4530fdc8d8SChris Lattner 4630fdc8d8SChris Lattner //---------------------------------------------------------------------- 4730fdc8d8SChris Lattner // Thread constructor 4830fdc8d8SChris Lattner //---------------------------------------------------------------------- 4930fdc8d8SChris Lattner SBThread::SBThread (const ThreadSP& lldb_object_sp) : 506611103cSGreg Clayton m_opaque_sp (lldb_object_sp) 5130fdc8d8SChris Lattner { 52750cd175SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 53ceb6b139SCaroline Tice 54ceb6b139SCaroline Tice if (log) 55750cd175SCaroline Tice { 56750cd175SCaroline Tice SBStream sstr; 57750cd175SCaroline Tice GetDescription (sstr); 58*93aa84e8SGreg Clayton log->Printf ("SBThread::SBThread (lldb_object_sp=%p) => SBThread(%p) :%s", 59750cd175SCaroline Tice lldb_object_sp.get(), m_opaque_sp.get(), sstr.GetData()); 60750cd175SCaroline Tice } 6130fdc8d8SChris Lattner } 6230fdc8d8SChris Lattner 6330fdc8d8SChris Lattner SBThread::SBThread (const SBThread &rhs) 6430fdc8d8SChris Lattner { 65750cd175SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 66ceb6b139SCaroline Tice 676611103cSGreg Clayton m_opaque_sp = rhs.m_opaque_sp; 68750cd175SCaroline Tice 69750cd175SCaroline Tice if (log) 70*93aa84e8SGreg Clayton log->Printf ("SBThread::SBThread (rhs.sp=%p) => SBThread(%p)", 71750cd175SCaroline Tice rhs.m_opaque_sp.get(), m_opaque_sp.get()); 72750cd175SCaroline Tice 7330fdc8d8SChris Lattner } 7430fdc8d8SChris Lattner 7530fdc8d8SChris Lattner //---------------------------------------------------------------------- 7630fdc8d8SChris Lattner // Destructor 7730fdc8d8SChris Lattner //---------------------------------------------------------------------- 7830fdc8d8SChris Lattner SBThread::~SBThread() 7930fdc8d8SChris Lattner { 8030fdc8d8SChris Lattner } 8130fdc8d8SChris Lattner 8230fdc8d8SChris Lattner bool 8330fdc8d8SChris Lattner SBThread::IsValid() const 8430fdc8d8SChris Lattner { 856611103cSGreg Clayton return m_opaque_sp != NULL; 8630fdc8d8SChris Lattner } 8730fdc8d8SChris Lattner 8848e42549SGreg Clayton void 8948e42549SGreg Clayton SBThread::Clear () 9048e42549SGreg Clayton { 9148e42549SGreg Clayton m_opaque_sp.reset(); 9248e42549SGreg Clayton } 9348e42549SGreg Clayton 9448e42549SGreg Clayton 9530fdc8d8SChris Lattner StopReason 9630fdc8d8SChris Lattner SBThread::GetStopReason() 9730fdc8d8SChris Lattner { 98ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 99ceb6b139SCaroline Tice 100ceb6b139SCaroline Tice StopReason reason = eStopReasonInvalid; 1016611103cSGreg Clayton if (m_opaque_sp) 10230fdc8d8SChris Lattner { 103b15bfc75SJim Ingham StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo (); 104b15bfc75SJim Ingham if (stop_info_sp) 105ceb6b139SCaroline Tice reason = stop_info_sp->GetStopReason(); 10630fdc8d8SChris Lattner } 107ceb6b139SCaroline Tice 108ceb6b139SCaroline Tice if (log) 109*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::GetStopReason () => '%s'", m_opaque_sp.get(), 110750cd175SCaroline Tice Thread::StopReasonAsCString (reason)); 111ceb6b139SCaroline Tice 112ceb6b139SCaroline Tice return reason; 11330fdc8d8SChris Lattner } 11430fdc8d8SChris Lattner 11530fdc8d8SChris Lattner size_t 11630fdc8d8SChris Lattner SBThread::GetStopDescription (char *dst, size_t dst_len) 11730fdc8d8SChris Lattner { 118ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 119ceb6b139SCaroline Tice 1206611103cSGreg Clayton if (m_opaque_sp) 12130fdc8d8SChris Lattner { 122b15bfc75SJim Ingham StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo (); 123b15bfc75SJim Ingham if (stop_info_sp) 12430fdc8d8SChris Lattner { 125b15bfc75SJim Ingham const char *stop_desc = stop_info_sp->GetDescription(); 12630fdc8d8SChris Lattner if (stop_desc) 12730fdc8d8SChris Lattner { 128ceb6b139SCaroline Tice if (log) 129*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::GetStopDescription (dst, dst_len) => '%s'", 130750cd175SCaroline Tice m_opaque_sp.get(), stop_desc); 13130fdc8d8SChris Lattner if (dst) 13230fdc8d8SChris Lattner return ::snprintf (dst, dst_len, "%s", stop_desc); 13330fdc8d8SChris Lattner else 13430fdc8d8SChris Lattner { 13530fdc8d8SChris Lattner // NULL dst passed in, return the length needed to contain the description 13630fdc8d8SChris Lattner return ::strlen (stop_desc) + 1; // Include the NULL byte for size 13730fdc8d8SChris Lattner } 13830fdc8d8SChris Lattner } 13930fdc8d8SChris Lattner else 14030fdc8d8SChris Lattner { 14130fdc8d8SChris Lattner size_t stop_desc_len = 0; 142b15bfc75SJim Ingham switch (stop_info_sp->GetStopReason()) 14330fdc8d8SChris Lattner { 14430fdc8d8SChris Lattner case eStopReasonTrace: 14530fdc8d8SChris Lattner case eStopReasonPlanComplete: 14630fdc8d8SChris Lattner { 14730fdc8d8SChris Lattner static char trace_desc[] = "step"; 14830fdc8d8SChris Lattner stop_desc = trace_desc; 14930fdc8d8SChris Lattner stop_desc_len = sizeof(trace_desc); // Include the NULL byte for size 15030fdc8d8SChris Lattner } 15130fdc8d8SChris Lattner break; 15230fdc8d8SChris Lattner 15330fdc8d8SChris Lattner case eStopReasonBreakpoint: 15430fdc8d8SChris Lattner { 15530fdc8d8SChris Lattner static char bp_desc[] = "breakpoint hit"; 15630fdc8d8SChris Lattner stop_desc = bp_desc; 15730fdc8d8SChris Lattner stop_desc_len = sizeof(bp_desc); // Include the NULL byte for size 15830fdc8d8SChris Lattner } 15930fdc8d8SChris Lattner break; 16030fdc8d8SChris Lattner 16130fdc8d8SChris Lattner case eStopReasonWatchpoint: 16230fdc8d8SChris Lattner { 16330fdc8d8SChris Lattner static char wp_desc[] = "watchpoint hit"; 16430fdc8d8SChris Lattner stop_desc = wp_desc; 16530fdc8d8SChris Lattner stop_desc_len = sizeof(wp_desc); // Include the NULL byte for size 16630fdc8d8SChris Lattner } 16730fdc8d8SChris Lattner break; 16830fdc8d8SChris Lattner 16930fdc8d8SChris Lattner case eStopReasonSignal: 17030fdc8d8SChris Lattner { 171b15bfc75SJim Ingham stop_desc = m_opaque_sp->GetProcess().GetUnixSignals ().GetSignalAsCString (stop_info_sp->GetValue()); 17230fdc8d8SChris Lattner if (stop_desc == NULL || stop_desc[0] == '\0') 17330fdc8d8SChris Lattner { 17430fdc8d8SChris Lattner static char signal_desc[] = "signal"; 17530fdc8d8SChris Lattner stop_desc = signal_desc; 17630fdc8d8SChris Lattner stop_desc_len = sizeof(signal_desc); // Include the NULL byte for size 17730fdc8d8SChris Lattner } 17830fdc8d8SChris Lattner } 17930fdc8d8SChris Lattner break; 18030fdc8d8SChris Lattner 18130fdc8d8SChris Lattner case eStopReasonException: 18230fdc8d8SChris Lattner { 18330fdc8d8SChris Lattner char exc_desc[] = "exception"; 18430fdc8d8SChris Lattner stop_desc = exc_desc; 18530fdc8d8SChris Lattner stop_desc_len = sizeof(exc_desc); // Include the NULL byte for size 18630fdc8d8SChris Lattner } 18730fdc8d8SChris Lattner break; 188c982c768SGreg Clayton 189c982c768SGreg Clayton default: 190c982c768SGreg Clayton break; 19130fdc8d8SChris Lattner } 19230fdc8d8SChris Lattner 19330fdc8d8SChris Lattner if (stop_desc && stop_desc[0]) 19430fdc8d8SChris Lattner { 195ceb6b139SCaroline Tice if (log) 196*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::GetStopDescription (dst, dst_len) => '%s'", 197750cd175SCaroline Tice m_opaque_sp.get(), stop_desc); 198ceb6b139SCaroline Tice 19930fdc8d8SChris Lattner if (dst) 20030fdc8d8SChris Lattner return ::snprintf (dst, dst_len, "%s", stop_desc) + 1; // Include the NULL byte 20130fdc8d8SChris Lattner 20230fdc8d8SChris Lattner if (stop_desc_len == 0) 20330fdc8d8SChris Lattner stop_desc_len = ::strlen (stop_desc) + 1; // Include the NULL byte 20430fdc8d8SChris Lattner 20530fdc8d8SChris Lattner return stop_desc_len; 20630fdc8d8SChris Lattner } 20730fdc8d8SChris Lattner } 20830fdc8d8SChris Lattner } 20930fdc8d8SChris Lattner } 21030fdc8d8SChris Lattner if (dst) 21130fdc8d8SChris Lattner *dst = 0; 21230fdc8d8SChris Lattner return 0; 21330fdc8d8SChris Lattner } 21430fdc8d8SChris Lattner 21530fdc8d8SChris Lattner void 21630fdc8d8SChris Lattner SBThread::SetThread (const ThreadSP& lldb_object_sp) 21730fdc8d8SChris Lattner { 2186611103cSGreg Clayton m_opaque_sp = lldb_object_sp; 21930fdc8d8SChris Lattner } 22030fdc8d8SChris Lattner 22130fdc8d8SChris Lattner 22230fdc8d8SChris Lattner lldb::tid_t 22330fdc8d8SChris Lattner SBThread::GetThreadID () const 22430fdc8d8SChris Lattner { 225ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 226ceb6b139SCaroline Tice 227750cd175SCaroline Tice //if (log) 228750cd175SCaroline Tice // log->Printf ("SBThread::GetThreadID()"); 229ceb6b139SCaroline Tice 230ceb6b139SCaroline Tice lldb::tid_t id = LLDB_INVALID_THREAD_ID; 2316611103cSGreg Clayton if (m_opaque_sp) 232ceb6b139SCaroline Tice id = m_opaque_sp->GetID(); 233ceb6b139SCaroline Tice 234ceb6b139SCaroline Tice if (log) 235750cd175SCaroline Tice log->Printf ("SBThread::GetThreadID (this.sp=%p) => %d", m_opaque_sp.get(), (uint32_t) id); 236ceb6b139SCaroline Tice 237ceb6b139SCaroline Tice return id; 23830fdc8d8SChris Lattner } 23930fdc8d8SChris Lattner 24030fdc8d8SChris Lattner uint32_t 24130fdc8d8SChris Lattner SBThread::GetIndexID () const 24230fdc8d8SChris Lattner { 2436611103cSGreg Clayton if (m_opaque_sp) 2446611103cSGreg Clayton return m_opaque_sp->GetIndexID(); 24530fdc8d8SChris Lattner return LLDB_INVALID_INDEX32; 24630fdc8d8SChris Lattner } 24730fdc8d8SChris Lattner const char * 24830fdc8d8SChris Lattner SBThread::GetName () const 24930fdc8d8SChris Lattner { 250ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 251ceb6b139SCaroline Tice 252750cd175SCaroline Tice //if (log) 253750cd175SCaroline Tice // log->Printf ("SBThread::GetName ()"); 254ceb6b139SCaroline Tice 2556611103cSGreg Clayton if (m_opaque_sp) 256ceb6b139SCaroline Tice { 257ceb6b139SCaroline Tice if (log) 258750cd175SCaroline Tice log->Printf ("SBThread::GetName (this.sp=%p) => '%s'", m_opaque_sp.get(), m_opaque_sp->GetName()); 2596611103cSGreg Clayton return m_opaque_sp->GetName(); 260ceb6b139SCaroline Tice } 261ceb6b139SCaroline Tice 262ceb6b139SCaroline Tice if (log) 263750cd175SCaroline Tice log->Printf ("SBThread::GetName (this.sp=%p) => NULL", m_opaque_sp.get()); 264ceb6b139SCaroline Tice 26530fdc8d8SChris Lattner return NULL; 26630fdc8d8SChris Lattner } 26730fdc8d8SChris Lattner 26830fdc8d8SChris Lattner const char * 26930fdc8d8SChris Lattner SBThread::GetQueueName () const 27030fdc8d8SChris Lattner { 271ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 272ceb6b139SCaroline Tice 273750cd175SCaroline Tice //if (log) 274750cd175SCaroline Tice // log->Printf ("SBThread::GetQueueName ()"); 275ceb6b139SCaroline Tice 2766611103cSGreg Clayton if (m_opaque_sp) 277ceb6b139SCaroline Tice { 278ceb6b139SCaroline Tice if (log) 279750cd175SCaroline Tice log->Printf ("SBThread::GetQueueName (this.sp=%p) => '%s'", m_opaque_sp.get(), 280750cd175SCaroline Tice m_opaque_sp->GetQueueName()); 2816611103cSGreg Clayton return m_opaque_sp->GetQueueName(); 282ceb6b139SCaroline Tice } 283ceb6b139SCaroline Tice 284ceb6b139SCaroline Tice if (log) 285750cd175SCaroline Tice log->Printf ("SBThread::GetQueueName (this.sp=%p) => NULL", m_opaque_sp.get()); 286ceb6b139SCaroline Tice 28730fdc8d8SChris Lattner return NULL; 28830fdc8d8SChris Lattner } 28930fdc8d8SChris Lattner 29030fdc8d8SChris Lattner 29130fdc8d8SChris Lattner void 29230fdc8d8SChris Lattner SBThread::StepOver (lldb::RunMode stop_other_threads) 29330fdc8d8SChris Lattner { 294ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 295ceb6b139SCaroline Tice 296ceb6b139SCaroline Tice if (log) 297*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::StepOver (stop_other_threads='%s')", m_opaque_sp.get(), 298ceb6b139SCaroline Tice Thread::RunModeAsCString (stop_other_threads)); 299ceb6b139SCaroline Tice 3006611103cSGreg Clayton if (m_opaque_sp) 30130fdc8d8SChris Lattner { 30230fdc8d8SChris Lattner bool abort_other_plans = true; 3036611103cSGreg Clayton StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0)); 30430fdc8d8SChris Lattner 30530fdc8d8SChris Lattner if (frame_sp) 30630fdc8d8SChris Lattner { 30730fdc8d8SChris Lattner if (frame_sp->HasDebugInformation ()) 30830fdc8d8SChris Lattner { 30930fdc8d8SChris Lattner SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything)); 3106611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans, 31130fdc8d8SChris Lattner eStepTypeOver, 31230fdc8d8SChris Lattner sc.line_entry.range, 31330fdc8d8SChris Lattner sc, 314474966a4SGreg Clayton stop_other_threads, 315474966a4SGreg Clayton false); 31630fdc8d8SChris Lattner 31730fdc8d8SChris Lattner } 31830fdc8d8SChris Lattner else 31930fdc8d8SChris Lattner { 3206611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepSingleInstruction (true, 32130fdc8d8SChris Lattner abort_other_plans, 32230fdc8d8SChris Lattner stop_other_threads); 32330fdc8d8SChris Lattner } 32430fdc8d8SChris Lattner } 32530fdc8d8SChris Lattner 3266611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 32730fdc8d8SChris Lattner // Why do we need to set the current thread by ID here??? 3282976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 3295d5028b5SGreg Clayton Error error (process.Resume()); 3305d5028b5SGreg Clayton if (error.Success()) 3315d5028b5SGreg Clayton { 3325d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 3335d5028b5SGreg Clayton // process to stop yet again! 3345d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 3355d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 3365d5028b5SGreg Clayton } 33730fdc8d8SChris Lattner } 33830fdc8d8SChris Lattner } 33930fdc8d8SChris Lattner 34030fdc8d8SChris Lattner void 34130fdc8d8SChris Lattner SBThread::StepInto (lldb::RunMode stop_other_threads) 34230fdc8d8SChris Lattner { 343ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 344ceb6b139SCaroline Tice 345ceb6b139SCaroline Tice if (log) 346*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::StepInto (stop_other_threads='%s')", m_opaque_sp.get(), 347ceb6b139SCaroline Tice Thread::RunModeAsCString (stop_other_threads)); 348ceb6b139SCaroline Tice 3496611103cSGreg Clayton if (m_opaque_sp) 35030fdc8d8SChris Lattner { 35130fdc8d8SChris Lattner bool abort_other_plans = true; 35230fdc8d8SChris Lattner 3536611103cSGreg Clayton StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0)); 35430fdc8d8SChris Lattner 35530fdc8d8SChris Lattner if (frame_sp && frame_sp->HasDebugInformation ()) 35630fdc8d8SChris Lattner { 357474966a4SGreg Clayton bool avoid_code_without_debug_info = true; 35830fdc8d8SChris Lattner SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything)); 3596611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans, 36030fdc8d8SChris Lattner eStepTypeInto, 36130fdc8d8SChris Lattner sc.line_entry.range, 36230fdc8d8SChris Lattner sc, 363474966a4SGreg Clayton stop_other_threads, 364474966a4SGreg Clayton avoid_code_without_debug_info); 36530fdc8d8SChris Lattner } 36630fdc8d8SChris Lattner else 36730fdc8d8SChris Lattner { 3686611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepSingleInstruction (false, 36930fdc8d8SChris Lattner abort_other_plans, 37030fdc8d8SChris Lattner stop_other_threads); 37130fdc8d8SChris Lattner } 37230fdc8d8SChris Lattner 3736611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 37430fdc8d8SChris Lattner // Why do we need to set the current thread by ID here??? 3752976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 3765d5028b5SGreg Clayton Error error (process.Resume()); 3775d5028b5SGreg Clayton if (error.Success()) 3785d5028b5SGreg Clayton { 3795d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 3805d5028b5SGreg Clayton // process to stop yet again! 3815d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 3825d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 3835d5028b5SGreg Clayton } 38430fdc8d8SChris Lattner } 38530fdc8d8SChris Lattner } 38630fdc8d8SChris Lattner 38730fdc8d8SChris Lattner void 38830fdc8d8SChris Lattner SBThread::StepOut () 38930fdc8d8SChris Lattner { 390ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 391ceb6b139SCaroline Tice 392ceb6b139SCaroline Tice if (log) 393750cd175SCaroline Tice log->Printf ("SBThread::StepOut (this.sp=%p)", m_opaque_sp.get()); 394ceb6b139SCaroline Tice 3956611103cSGreg Clayton if (m_opaque_sp) 39630fdc8d8SChris Lattner { 39730fdc8d8SChris Lattner bool abort_other_plans = true; 39830fdc8d8SChris Lattner bool stop_other_threads = true; 39930fdc8d8SChris Lattner 4006611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepOut (abort_other_plans, NULL, false, stop_other_threads, eVoteYes, eVoteNoOpinion); 40130fdc8d8SChris Lattner 4026611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 4032976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 4045d5028b5SGreg Clayton Error error (process.Resume()); 4055d5028b5SGreg Clayton if (error.Success()) 4065d5028b5SGreg Clayton { 4075d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 4085d5028b5SGreg Clayton // process to stop yet again! 4095d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 4105d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 4115d5028b5SGreg Clayton } 41230fdc8d8SChris Lattner } 41330fdc8d8SChris Lattner } 41430fdc8d8SChris Lattner 41530fdc8d8SChris Lattner void 41630fdc8d8SChris Lattner SBThread::StepInstruction (bool step_over) 41730fdc8d8SChris Lattner { 418ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 419ceb6b139SCaroline Tice 420ceb6b139SCaroline Tice if (log) 421*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::StepInstruction (step_over=%i)", m_opaque_sp.get(), step_over); 422ceb6b139SCaroline Tice 4236611103cSGreg Clayton if (m_opaque_sp) 42430fdc8d8SChris Lattner { 4256611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepSingleInstruction (step_over, true, true); 4266611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 4272976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 4285d5028b5SGreg Clayton Error error (process.Resume()); 4295d5028b5SGreg Clayton if (error.Success()) 4305d5028b5SGreg Clayton { 4315d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 4325d5028b5SGreg Clayton // process to stop yet again! 4335d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 4345d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 4355d5028b5SGreg Clayton } 43630fdc8d8SChris Lattner } 43730fdc8d8SChris Lattner } 43830fdc8d8SChris Lattner 43930fdc8d8SChris Lattner void 44030fdc8d8SChris Lattner SBThread::RunToAddress (lldb::addr_t addr) 44130fdc8d8SChris Lattner { 442ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 443ceb6b139SCaroline Tice 444ceb6b139SCaroline Tice if (log) 445*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::RunToAddress (addr=0x%llx)", m_opaque_sp.get(), addr); 446ceb6b139SCaroline Tice 4476611103cSGreg Clayton if (m_opaque_sp) 44830fdc8d8SChris Lattner { 44930fdc8d8SChris Lattner bool abort_other_plans = true; 45030fdc8d8SChris Lattner bool stop_other_threads = true; 45130fdc8d8SChris Lattner 45230fdc8d8SChris Lattner Address target_addr (NULL, addr); 45330fdc8d8SChris Lattner 4546611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForRunToAddress (abort_other_plans, target_addr, stop_other_threads); 4556611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 4562976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 4575d5028b5SGreg Clayton Error error (process.Resume()); 4585d5028b5SGreg Clayton if (error.Success()) 4595d5028b5SGreg Clayton { 4605d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 4615d5028b5SGreg Clayton // process to stop yet again! 4625d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 4635d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 4645d5028b5SGreg Clayton } 46530fdc8d8SChris Lattner } 46630fdc8d8SChris Lattner 46730fdc8d8SChris Lattner } 46830fdc8d8SChris Lattner 46930fdc8d8SChris Lattner SBProcess 47030fdc8d8SChris Lattner SBThread::GetProcess () 47130fdc8d8SChris Lattner { 472ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 473ceb6b139SCaroline Tice 47430fdc8d8SChris Lattner SBProcess process; 4756611103cSGreg Clayton if (m_opaque_sp) 47630fdc8d8SChris Lattner { 47730fdc8d8SChris Lattner // Have to go up to the target so we can get a shared pointer to our process... 4786611103cSGreg Clayton process.SetProcess(m_opaque_sp->GetProcess().GetTarget().GetProcessSP()); 47930fdc8d8SChris Lattner } 480ceb6b139SCaroline Tice 481ceb6b139SCaroline Tice if (log) 482ceb6b139SCaroline Tice { 483ceb6b139SCaroline Tice SBStream sstr; 484ceb6b139SCaroline Tice process.GetDescription (sstr); 485750cd175SCaroline Tice log->Printf ("SBThread::GetProcess (this.sp=%p) => SBProcess : this.sp = %p, '%s'", m_opaque_sp.get(), 486750cd175SCaroline Tice process.get(), sstr.GetData()); 487ceb6b139SCaroline Tice } 488ceb6b139SCaroline Tice 48930fdc8d8SChris Lattner return process; 49030fdc8d8SChris Lattner } 49130fdc8d8SChris Lattner 49230fdc8d8SChris Lattner uint32_t 49330fdc8d8SChris Lattner SBThread::GetNumFrames () 49430fdc8d8SChris Lattner { 495ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 496ceb6b139SCaroline Tice 497ceb6b139SCaroline Tice uint32_t num_frames = 0; 4986611103cSGreg Clayton if (m_opaque_sp) 499ceb6b139SCaroline Tice num_frames = m_opaque_sp->GetStackFrameCount(); 500ceb6b139SCaroline Tice 501ceb6b139SCaroline Tice if (log) 502750cd175SCaroline Tice log->Printf ("SBThread::GetNumFrames (this.sp=%p) => %d", m_opaque_sp.get(), num_frames); 503ceb6b139SCaroline Tice 504ceb6b139SCaroline Tice return num_frames; 50530fdc8d8SChris Lattner } 50630fdc8d8SChris Lattner 50730fdc8d8SChris Lattner SBFrame 50830fdc8d8SChris Lattner SBThread::GetFrameAtIndex (uint32_t idx) 50930fdc8d8SChris Lattner { 510ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 511ceb6b139SCaroline Tice 51230fdc8d8SChris Lattner SBFrame sb_frame; 5136611103cSGreg Clayton if (m_opaque_sp) 5146611103cSGreg Clayton sb_frame.SetFrame (m_opaque_sp->GetStackFrameAtIndex (idx)); 515ceb6b139SCaroline Tice 516ceb6b139SCaroline Tice if (log) 517ceb6b139SCaroline Tice { 518ceb6b139SCaroline Tice SBStream sstr; 519ceb6b139SCaroline Tice sb_frame.GetDescription (sstr); 520*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::GetFrameAtIndex (idx=%d) => SBFrame.sp : this = %p, '%s'", 521750cd175SCaroline Tice m_opaque_sp.get(), idx, sb_frame.get(), sstr.GetData()); 522ceb6b139SCaroline Tice } 523ceb6b139SCaroline Tice 52430fdc8d8SChris Lattner return sb_frame; 52530fdc8d8SChris Lattner } 52630fdc8d8SChris Lattner 52730fdc8d8SChris Lattner const lldb::SBThread & 52830fdc8d8SChris Lattner SBThread::operator = (const lldb::SBThread &rhs) 52930fdc8d8SChris Lattner { 530ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 531ceb6b139SCaroline Tice 532ceb6b139SCaroline Tice if (log) 533*93aa84e8SGreg Clayton log->Printf ("SBThread(%p)::operator= (rhs.sp=%p)", m_opaque_sp.get(), rhs.m_opaque_sp.get()); 534ceb6b139SCaroline Tice 5356611103cSGreg Clayton m_opaque_sp = rhs.m_opaque_sp; 53630fdc8d8SChris Lattner return *this; 53730fdc8d8SChris Lattner } 53830fdc8d8SChris Lattner 53930fdc8d8SChris Lattner bool 54030fdc8d8SChris Lattner SBThread::operator == (const SBThread &rhs) const 54130fdc8d8SChris Lattner { 5426611103cSGreg Clayton return m_opaque_sp.get() == rhs.m_opaque_sp.get(); 54330fdc8d8SChris Lattner } 54430fdc8d8SChris Lattner 54530fdc8d8SChris Lattner bool 54630fdc8d8SChris Lattner SBThread::operator != (const SBThread &rhs) const 54730fdc8d8SChris Lattner { 5486611103cSGreg Clayton return m_opaque_sp.get() != rhs.m_opaque_sp.get(); 54930fdc8d8SChris Lattner } 55030fdc8d8SChris Lattner 55130fdc8d8SChris Lattner lldb_private::Thread * 55230fdc8d8SChris Lattner SBThread::GetLLDBObjectPtr () 55330fdc8d8SChris Lattner { 5546611103cSGreg Clayton return m_opaque_sp.get(); 55530fdc8d8SChris Lattner } 55630fdc8d8SChris Lattner 55730fdc8d8SChris Lattner const lldb_private::Thread * 55830fdc8d8SChris Lattner SBThread::operator->() const 55930fdc8d8SChris Lattner { 5606611103cSGreg Clayton return m_opaque_sp.get(); 56130fdc8d8SChris Lattner } 56230fdc8d8SChris Lattner 56330fdc8d8SChris Lattner const lldb_private::Thread & 56430fdc8d8SChris Lattner SBThread::operator*() const 56530fdc8d8SChris Lattner { 5666611103cSGreg Clayton return *m_opaque_sp; 56730fdc8d8SChris Lattner } 56830fdc8d8SChris Lattner 56930fdc8d8SChris Lattner lldb_private::Thread * 57030fdc8d8SChris Lattner SBThread::operator->() 57130fdc8d8SChris Lattner { 5726611103cSGreg Clayton return m_opaque_sp.get(); 57330fdc8d8SChris Lattner } 57430fdc8d8SChris Lattner 57530fdc8d8SChris Lattner lldb_private::Thread & 57630fdc8d8SChris Lattner SBThread::operator*() 57730fdc8d8SChris Lattner { 5786611103cSGreg Clayton return *m_opaque_sp; 57930fdc8d8SChris Lattner } 580dde9cff3SCaroline Tice 581dde9cff3SCaroline Tice bool 582dde9cff3SCaroline Tice SBThread::GetDescription (SBStream &description) 583dde9cff3SCaroline Tice { 584dde9cff3SCaroline Tice if (m_opaque_sp) 58505faeb71SGreg Clayton { 58605faeb71SGreg Clayton StreamString strm; 58705faeb71SGreg Clayton description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID()); 58805faeb71SGreg Clayton } 589dde9cff3SCaroline Tice else 590dde9cff3SCaroline Tice description.Printf ("No value"); 591dde9cff3SCaroline Tice 592dde9cff3SCaroline Tice return true; 593dde9cff3SCaroline Tice } 594ceb6b139SCaroline Tice 595ceb6b139SCaroline Tice bool 596ceb6b139SCaroline Tice SBThread::GetDescription (SBStream &description) const 597ceb6b139SCaroline Tice { 598ceb6b139SCaroline Tice if (m_opaque_sp) 599ceb6b139SCaroline Tice { 600ceb6b139SCaroline Tice StreamString strm; 601ceb6b139SCaroline Tice description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID()); 602ceb6b139SCaroline Tice } 603ceb6b139SCaroline Tice else 604ceb6b139SCaroline Tice description.Printf ("No value"); 605ceb6b139SCaroline Tice 606ceb6b139SCaroline Tice return true; 607ceb6b139SCaroline Tice } 608