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 { 52*750cd175SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 53ceb6b139SCaroline Tice 54ceb6b139SCaroline Tice if (log) 55*750cd175SCaroline Tice { 56*750cd175SCaroline Tice SBStream sstr; 57*750cd175SCaroline Tice GetDescription (sstr); 58*750cd175SCaroline Tice log->Printf ("SBThread::SBThread (lldb_object_sp=%p) => this.sp = %p (%s)", 59*750cd175SCaroline Tice lldb_object_sp.get(), m_opaque_sp.get(), sstr.GetData()); 60*750cd175SCaroline Tice } 6130fdc8d8SChris Lattner } 6230fdc8d8SChris Lattner 6330fdc8d8SChris Lattner SBThread::SBThread (const SBThread &rhs) 6430fdc8d8SChris Lattner { 65*750cd175SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 66ceb6b139SCaroline Tice 676611103cSGreg Clayton m_opaque_sp = rhs.m_opaque_sp; 68*750cd175SCaroline Tice 69*750cd175SCaroline Tice if (log) 70*750cd175SCaroline Tice log->Printf ("SBThread::SBThread (rhs.sp=%p) => this.sp = %p", 71*750cd175SCaroline Tice rhs.m_opaque_sp.get(), m_opaque_sp.get()); 72*750cd175SCaroline 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 100*750cd175SCaroline Tice //if (log) 101*750cd175SCaroline Tice // log->Printf ("SBThread::GetStopReason ()"); 102ceb6b139SCaroline Tice 103ceb6b139SCaroline Tice StopReason reason = eStopReasonInvalid; 1046611103cSGreg Clayton if (m_opaque_sp) 10530fdc8d8SChris Lattner { 106b15bfc75SJim Ingham StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo (); 107b15bfc75SJim Ingham if (stop_info_sp) 108ceb6b139SCaroline Tice reason = stop_info_sp->GetStopReason(); 10930fdc8d8SChris Lattner } 110ceb6b139SCaroline Tice 111ceb6b139SCaroline Tice if (log) 112*750cd175SCaroline Tice log->Printf ("SBThread::GetStopReason (this.sp=%p) => '%s'", m_opaque_sp.get(), 113*750cd175SCaroline Tice Thread::StopReasonAsCString (reason)); 114ceb6b139SCaroline Tice 115ceb6b139SCaroline Tice return reason; 11630fdc8d8SChris Lattner } 11730fdc8d8SChris Lattner 11830fdc8d8SChris Lattner size_t 11930fdc8d8SChris Lattner SBThread::GetStopDescription (char *dst, size_t dst_len) 12030fdc8d8SChris Lattner { 121ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 122ceb6b139SCaroline Tice 123*750cd175SCaroline Tice //if (log) 124*750cd175SCaroline Tice // log->Printf ("SBThread::GetStopDescription (char *dst, size_t dst_len)"); 125ceb6b139SCaroline Tice 1266611103cSGreg Clayton if (m_opaque_sp) 12730fdc8d8SChris Lattner { 128b15bfc75SJim Ingham StopInfoSP stop_info_sp = m_opaque_sp->GetStopInfo (); 129b15bfc75SJim Ingham if (stop_info_sp) 13030fdc8d8SChris Lattner { 131b15bfc75SJim Ingham const char *stop_desc = stop_info_sp->GetDescription(); 13230fdc8d8SChris Lattner if (stop_desc) 13330fdc8d8SChris Lattner { 134ceb6b139SCaroline Tice if (log) 135*750cd175SCaroline Tice log->Printf ("SBThread::GetStopDescription (this.sp=%p, dst, dst_len) => '%s'", 136*750cd175SCaroline Tice m_opaque_sp.get(), stop_desc); 13730fdc8d8SChris Lattner if (dst) 13830fdc8d8SChris Lattner return ::snprintf (dst, dst_len, "%s", stop_desc); 13930fdc8d8SChris Lattner else 14030fdc8d8SChris Lattner { 14130fdc8d8SChris Lattner // NULL dst passed in, return the length needed to contain the description 14230fdc8d8SChris Lattner return ::strlen (stop_desc) + 1; // Include the NULL byte for size 14330fdc8d8SChris Lattner } 14430fdc8d8SChris Lattner } 14530fdc8d8SChris Lattner else 14630fdc8d8SChris Lattner { 14730fdc8d8SChris Lattner size_t stop_desc_len = 0; 148b15bfc75SJim Ingham switch (stop_info_sp->GetStopReason()) 14930fdc8d8SChris Lattner { 15030fdc8d8SChris Lattner case eStopReasonTrace: 15130fdc8d8SChris Lattner case eStopReasonPlanComplete: 15230fdc8d8SChris Lattner { 15330fdc8d8SChris Lattner static char trace_desc[] = "step"; 15430fdc8d8SChris Lattner stop_desc = trace_desc; 15530fdc8d8SChris Lattner stop_desc_len = sizeof(trace_desc); // Include the NULL byte for size 15630fdc8d8SChris Lattner } 15730fdc8d8SChris Lattner break; 15830fdc8d8SChris Lattner 15930fdc8d8SChris Lattner case eStopReasonBreakpoint: 16030fdc8d8SChris Lattner { 16130fdc8d8SChris Lattner static char bp_desc[] = "breakpoint hit"; 16230fdc8d8SChris Lattner stop_desc = bp_desc; 16330fdc8d8SChris Lattner stop_desc_len = sizeof(bp_desc); // Include the NULL byte for size 16430fdc8d8SChris Lattner } 16530fdc8d8SChris Lattner break; 16630fdc8d8SChris Lattner 16730fdc8d8SChris Lattner case eStopReasonWatchpoint: 16830fdc8d8SChris Lattner { 16930fdc8d8SChris Lattner static char wp_desc[] = "watchpoint hit"; 17030fdc8d8SChris Lattner stop_desc = wp_desc; 17130fdc8d8SChris Lattner stop_desc_len = sizeof(wp_desc); // Include the NULL byte for size 17230fdc8d8SChris Lattner } 17330fdc8d8SChris Lattner break; 17430fdc8d8SChris Lattner 17530fdc8d8SChris Lattner case eStopReasonSignal: 17630fdc8d8SChris Lattner { 177b15bfc75SJim Ingham stop_desc = m_opaque_sp->GetProcess().GetUnixSignals ().GetSignalAsCString (stop_info_sp->GetValue()); 17830fdc8d8SChris Lattner if (stop_desc == NULL || stop_desc[0] == '\0') 17930fdc8d8SChris Lattner { 18030fdc8d8SChris Lattner static char signal_desc[] = "signal"; 18130fdc8d8SChris Lattner stop_desc = signal_desc; 18230fdc8d8SChris Lattner stop_desc_len = sizeof(signal_desc); // Include the NULL byte for size 18330fdc8d8SChris Lattner } 18430fdc8d8SChris Lattner } 18530fdc8d8SChris Lattner break; 18630fdc8d8SChris Lattner 18730fdc8d8SChris Lattner case eStopReasonException: 18830fdc8d8SChris Lattner { 18930fdc8d8SChris Lattner char exc_desc[] = "exception"; 19030fdc8d8SChris Lattner stop_desc = exc_desc; 19130fdc8d8SChris Lattner stop_desc_len = sizeof(exc_desc); // Include the NULL byte for size 19230fdc8d8SChris Lattner } 19330fdc8d8SChris Lattner break; 194c982c768SGreg Clayton 195c982c768SGreg Clayton default: 196c982c768SGreg Clayton break; 19730fdc8d8SChris Lattner } 19830fdc8d8SChris Lattner 19930fdc8d8SChris Lattner if (stop_desc && stop_desc[0]) 20030fdc8d8SChris Lattner { 201ceb6b139SCaroline Tice if (log) 202*750cd175SCaroline Tice log->Printf ("SBThread::GetStopDescription (this.sp=%p, dst, dst_len) => '%s'", 203*750cd175SCaroline Tice m_opaque_sp.get(), stop_desc); 204ceb6b139SCaroline Tice 20530fdc8d8SChris Lattner if (dst) 20630fdc8d8SChris Lattner return ::snprintf (dst, dst_len, "%s", stop_desc) + 1; // Include the NULL byte 20730fdc8d8SChris Lattner 20830fdc8d8SChris Lattner if (stop_desc_len == 0) 20930fdc8d8SChris Lattner stop_desc_len = ::strlen (stop_desc) + 1; // Include the NULL byte 21030fdc8d8SChris Lattner 21130fdc8d8SChris Lattner return stop_desc_len; 21230fdc8d8SChris Lattner } 21330fdc8d8SChris Lattner } 21430fdc8d8SChris Lattner } 21530fdc8d8SChris Lattner } 21630fdc8d8SChris Lattner if (dst) 21730fdc8d8SChris Lattner *dst = 0; 21830fdc8d8SChris Lattner return 0; 21930fdc8d8SChris Lattner } 22030fdc8d8SChris Lattner 22130fdc8d8SChris Lattner void 22230fdc8d8SChris Lattner SBThread::SetThread (const ThreadSP& lldb_object_sp) 22330fdc8d8SChris Lattner { 2246611103cSGreg Clayton m_opaque_sp = lldb_object_sp; 22530fdc8d8SChris Lattner } 22630fdc8d8SChris Lattner 22730fdc8d8SChris Lattner 22830fdc8d8SChris Lattner lldb::tid_t 22930fdc8d8SChris Lattner SBThread::GetThreadID () const 23030fdc8d8SChris Lattner { 231ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 232ceb6b139SCaroline Tice 233*750cd175SCaroline Tice //if (log) 234*750cd175SCaroline Tice // log->Printf ("SBThread::GetThreadID()"); 235ceb6b139SCaroline Tice 236ceb6b139SCaroline Tice lldb::tid_t id = LLDB_INVALID_THREAD_ID; 2376611103cSGreg Clayton if (m_opaque_sp) 238ceb6b139SCaroline Tice id = m_opaque_sp->GetID(); 239ceb6b139SCaroline Tice 240ceb6b139SCaroline Tice if (log) 241*750cd175SCaroline Tice log->Printf ("SBThread::GetThreadID (this.sp=%p) => %d", m_opaque_sp.get(), (uint32_t) id); 242ceb6b139SCaroline Tice 243ceb6b139SCaroline Tice return id; 24430fdc8d8SChris Lattner } 24530fdc8d8SChris Lattner 24630fdc8d8SChris Lattner uint32_t 24730fdc8d8SChris Lattner SBThread::GetIndexID () const 24830fdc8d8SChris Lattner { 2496611103cSGreg Clayton if (m_opaque_sp) 2506611103cSGreg Clayton return m_opaque_sp->GetIndexID(); 25130fdc8d8SChris Lattner return LLDB_INVALID_INDEX32; 25230fdc8d8SChris Lattner } 25330fdc8d8SChris Lattner const char * 25430fdc8d8SChris Lattner SBThread::GetName () const 25530fdc8d8SChris Lattner { 256ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 257ceb6b139SCaroline Tice 258*750cd175SCaroline Tice //if (log) 259*750cd175SCaroline Tice // log->Printf ("SBThread::GetName ()"); 260ceb6b139SCaroline Tice 2616611103cSGreg Clayton if (m_opaque_sp) 262ceb6b139SCaroline Tice { 263ceb6b139SCaroline Tice if (log) 264*750cd175SCaroline Tice log->Printf ("SBThread::GetName (this.sp=%p) => '%s'", m_opaque_sp.get(), m_opaque_sp->GetName()); 2656611103cSGreg Clayton return m_opaque_sp->GetName(); 266ceb6b139SCaroline Tice } 267ceb6b139SCaroline Tice 268ceb6b139SCaroline Tice if (log) 269*750cd175SCaroline Tice log->Printf ("SBThread::GetName (this.sp=%p) => NULL", m_opaque_sp.get()); 270ceb6b139SCaroline Tice 27130fdc8d8SChris Lattner return NULL; 27230fdc8d8SChris Lattner } 27330fdc8d8SChris Lattner 27430fdc8d8SChris Lattner const char * 27530fdc8d8SChris Lattner SBThread::GetQueueName () const 27630fdc8d8SChris Lattner { 277ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 278ceb6b139SCaroline Tice 279*750cd175SCaroline Tice //if (log) 280*750cd175SCaroline Tice // log->Printf ("SBThread::GetQueueName ()"); 281ceb6b139SCaroline Tice 2826611103cSGreg Clayton if (m_opaque_sp) 283ceb6b139SCaroline Tice { 284ceb6b139SCaroline Tice if (log) 285*750cd175SCaroline Tice log->Printf ("SBThread::GetQueueName (this.sp=%p) => '%s'", m_opaque_sp.get(), 286*750cd175SCaroline Tice m_opaque_sp->GetQueueName()); 2876611103cSGreg Clayton return m_opaque_sp->GetQueueName(); 288ceb6b139SCaroline Tice } 289ceb6b139SCaroline Tice 290ceb6b139SCaroline Tice if (log) 291*750cd175SCaroline Tice log->Printf ("SBThread::GetQueueName (this.sp=%p) => NULL", m_opaque_sp.get()); 292ceb6b139SCaroline Tice 29330fdc8d8SChris Lattner return NULL; 29430fdc8d8SChris Lattner } 29530fdc8d8SChris Lattner 29630fdc8d8SChris Lattner 29730fdc8d8SChris Lattner void 29830fdc8d8SChris Lattner SBThread::StepOver (lldb::RunMode stop_other_threads) 29930fdc8d8SChris Lattner { 300ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 301ceb6b139SCaroline Tice 302ceb6b139SCaroline Tice if (log) 303*750cd175SCaroline Tice log->Printf ("SBThread::StepOver (this.sp=%p, stop_other_threads='%s')", m_opaque_sp.get(), 304ceb6b139SCaroline Tice Thread::RunModeAsCString (stop_other_threads)); 305ceb6b139SCaroline Tice 3066611103cSGreg Clayton if (m_opaque_sp) 30730fdc8d8SChris Lattner { 30830fdc8d8SChris Lattner bool abort_other_plans = true; 3096611103cSGreg Clayton StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0)); 31030fdc8d8SChris Lattner 31130fdc8d8SChris Lattner if (frame_sp) 31230fdc8d8SChris Lattner { 31330fdc8d8SChris Lattner if (frame_sp->HasDebugInformation ()) 31430fdc8d8SChris Lattner { 31530fdc8d8SChris Lattner SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything)); 3166611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans, 31730fdc8d8SChris Lattner eStepTypeOver, 31830fdc8d8SChris Lattner sc.line_entry.range, 31930fdc8d8SChris Lattner sc, 320474966a4SGreg Clayton stop_other_threads, 321474966a4SGreg Clayton false); 32230fdc8d8SChris Lattner 32330fdc8d8SChris Lattner } 32430fdc8d8SChris Lattner else 32530fdc8d8SChris Lattner { 3266611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepSingleInstruction (true, 32730fdc8d8SChris Lattner abort_other_plans, 32830fdc8d8SChris Lattner stop_other_threads); 32930fdc8d8SChris Lattner } 33030fdc8d8SChris Lattner } 33130fdc8d8SChris Lattner 3326611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 33330fdc8d8SChris Lattner // Why do we need to set the current thread by ID here??? 3342976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 3355d5028b5SGreg Clayton Error error (process.Resume()); 3365d5028b5SGreg Clayton if (error.Success()) 3375d5028b5SGreg Clayton { 3385d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 3395d5028b5SGreg Clayton // process to stop yet again! 3405d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 3415d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 3425d5028b5SGreg Clayton } 34330fdc8d8SChris Lattner } 34430fdc8d8SChris Lattner } 34530fdc8d8SChris Lattner 34630fdc8d8SChris Lattner void 34730fdc8d8SChris Lattner SBThread::StepInto (lldb::RunMode stop_other_threads) 34830fdc8d8SChris Lattner { 349ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 350ceb6b139SCaroline Tice 351ceb6b139SCaroline Tice if (log) 352*750cd175SCaroline Tice log->Printf ("SBThread::StepInto (this.sp=%p, stop_other_threads='%s')", m_opaque_sp.get(), 353ceb6b139SCaroline Tice Thread::RunModeAsCString (stop_other_threads)); 354ceb6b139SCaroline Tice 3556611103cSGreg Clayton if (m_opaque_sp) 35630fdc8d8SChris Lattner { 35730fdc8d8SChris Lattner bool abort_other_plans = true; 35830fdc8d8SChris Lattner 3596611103cSGreg Clayton StackFrameSP frame_sp(m_opaque_sp->GetStackFrameAtIndex (0)); 36030fdc8d8SChris Lattner 36130fdc8d8SChris Lattner if (frame_sp && frame_sp->HasDebugInformation ()) 36230fdc8d8SChris Lattner { 363474966a4SGreg Clayton bool avoid_code_without_debug_info = true; 36430fdc8d8SChris Lattner SymbolContext sc(frame_sp->GetSymbolContext(eSymbolContextEverything)); 3656611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepRange (abort_other_plans, 36630fdc8d8SChris Lattner eStepTypeInto, 36730fdc8d8SChris Lattner sc.line_entry.range, 36830fdc8d8SChris Lattner sc, 369474966a4SGreg Clayton stop_other_threads, 370474966a4SGreg Clayton avoid_code_without_debug_info); 37130fdc8d8SChris Lattner } 37230fdc8d8SChris Lattner else 37330fdc8d8SChris Lattner { 3746611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepSingleInstruction (false, 37530fdc8d8SChris Lattner abort_other_plans, 37630fdc8d8SChris Lattner stop_other_threads); 37730fdc8d8SChris Lattner } 37830fdc8d8SChris Lattner 3796611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 38030fdc8d8SChris Lattner // Why do we need to set the current thread by ID here??? 3812976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 3825d5028b5SGreg Clayton Error error (process.Resume()); 3835d5028b5SGreg Clayton if (error.Success()) 3845d5028b5SGreg Clayton { 3855d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 3865d5028b5SGreg Clayton // process to stop yet again! 3875d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 3885d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 3895d5028b5SGreg Clayton } 39030fdc8d8SChris Lattner } 39130fdc8d8SChris Lattner } 39230fdc8d8SChris Lattner 39330fdc8d8SChris Lattner void 39430fdc8d8SChris Lattner SBThread::StepOut () 39530fdc8d8SChris Lattner { 396ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 397ceb6b139SCaroline Tice 398ceb6b139SCaroline Tice if (log) 399*750cd175SCaroline Tice log->Printf ("SBThread::StepOut (this.sp=%p)", m_opaque_sp.get()); 400ceb6b139SCaroline Tice 4016611103cSGreg Clayton if (m_opaque_sp) 40230fdc8d8SChris Lattner { 40330fdc8d8SChris Lattner bool abort_other_plans = true; 40430fdc8d8SChris Lattner bool stop_other_threads = true; 40530fdc8d8SChris Lattner 4066611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepOut (abort_other_plans, NULL, false, stop_other_threads, eVoteYes, eVoteNoOpinion); 40730fdc8d8SChris Lattner 4086611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 4092976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 4105d5028b5SGreg Clayton Error error (process.Resume()); 4115d5028b5SGreg Clayton if (error.Success()) 4125d5028b5SGreg Clayton { 4135d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 4145d5028b5SGreg Clayton // process to stop yet again! 4155d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 4165d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 4175d5028b5SGreg Clayton } 41830fdc8d8SChris Lattner } 41930fdc8d8SChris Lattner } 42030fdc8d8SChris Lattner 42130fdc8d8SChris Lattner void 42230fdc8d8SChris Lattner SBThread::StepInstruction (bool step_over) 42330fdc8d8SChris Lattner { 424ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 425ceb6b139SCaroline Tice 426ceb6b139SCaroline Tice if (log) 427*750cd175SCaroline Tice log->Printf ("SBThread::StepInstruction (this.sp=%p, step_over=%s)", m_opaque_sp.get(), 428*750cd175SCaroline Tice (step_over ? "true" : "false")); 429ceb6b139SCaroline Tice 4306611103cSGreg Clayton if (m_opaque_sp) 43130fdc8d8SChris Lattner { 4326611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForStepSingleInstruction (step_over, true, true); 4336611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 4342976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 4355d5028b5SGreg Clayton Error error (process.Resume()); 4365d5028b5SGreg Clayton if (error.Success()) 4375d5028b5SGreg Clayton { 4385d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 4395d5028b5SGreg Clayton // process to stop yet again! 4405d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 4415d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 4425d5028b5SGreg Clayton } 44330fdc8d8SChris Lattner } 44430fdc8d8SChris Lattner } 44530fdc8d8SChris Lattner 44630fdc8d8SChris Lattner void 44730fdc8d8SChris Lattner SBThread::RunToAddress (lldb::addr_t addr) 44830fdc8d8SChris Lattner { 449ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 450ceb6b139SCaroline Tice 451ceb6b139SCaroline Tice if (log) 452*750cd175SCaroline Tice log->Printf ("SBThread::RunToAddress (this.sp=%p, addr=%p)", m_opaque_sp.get(), addr); 453ceb6b139SCaroline Tice 4546611103cSGreg Clayton if (m_opaque_sp) 45530fdc8d8SChris Lattner { 45630fdc8d8SChris Lattner bool abort_other_plans = true; 45730fdc8d8SChris Lattner bool stop_other_threads = true; 45830fdc8d8SChris Lattner 45930fdc8d8SChris Lattner Address target_addr (NULL, addr); 46030fdc8d8SChris Lattner 4616611103cSGreg Clayton m_opaque_sp->QueueThreadPlanForRunToAddress (abort_other_plans, target_addr, stop_other_threads); 4626611103cSGreg Clayton Process &process = m_opaque_sp->GetProcess(); 4632976d00aSJim Ingham process.GetThreadList().SetSelectedThreadByID (m_opaque_sp->GetID()); 4645d5028b5SGreg Clayton Error error (process.Resume()); 4655d5028b5SGreg Clayton if (error.Success()) 4665d5028b5SGreg Clayton { 4675d5028b5SGreg Clayton // If we are doing synchronous mode, then wait for the 4685d5028b5SGreg Clayton // process to stop yet again! 4695d5028b5SGreg Clayton if (process.GetTarget().GetDebugger().GetAsyncExecution () == false) 4705d5028b5SGreg Clayton process.WaitForProcessToStop (NULL); 4715d5028b5SGreg Clayton } 47230fdc8d8SChris Lattner } 47330fdc8d8SChris Lattner 47430fdc8d8SChris Lattner } 47530fdc8d8SChris Lattner 47630fdc8d8SChris Lattner SBProcess 47730fdc8d8SChris Lattner SBThread::GetProcess () 47830fdc8d8SChris Lattner { 479ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 480ceb6b139SCaroline Tice 481*750cd175SCaroline Tice //if (log) 482*750cd175SCaroline Tice // log->Printf ("SBThread::GetProcess ()"); 483ceb6b139SCaroline Tice 48430fdc8d8SChris Lattner SBProcess process; 4856611103cSGreg Clayton if (m_opaque_sp) 48630fdc8d8SChris Lattner { 48730fdc8d8SChris Lattner // Have to go up to the target so we can get a shared pointer to our process... 4886611103cSGreg Clayton process.SetProcess(m_opaque_sp->GetProcess().GetTarget().GetProcessSP()); 48930fdc8d8SChris Lattner } 490ceb6b139SCaroline Tice 491ceb6b139SCaroline Tice if (log) 492ceb6b139SCaroline Tice { 493ceb6b139SCaroline Tice SBStream sstr; 494ceb6b139SCaroline Tice process.GetDescription (sstr); 495*750cd175SCaroline Tice log->Printf ("SBThread::GetProcess (this.sp=%p) => SBProcess : this.sp = %p, '%s'", m_opaque_sp.get(), 496*750cd175SCaroline Tice process.get(), sstr.GetData()); 497ceb6b139SCaroline Tice } 498ceb6b139SCaroline Tice 49930fdc8d8SChris Lattner return process; 50030fdc8d8SChris Lattner } 50130fdc8d8SChris Lattner 50230fdc8d8SChris Lattner uint32_t 50330fdc8d8SChris Lattner SBThread::GetNumFrames () 50430fdc8d8SChris Lattner { 505ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 506ceb6b139SCaroline Tice 507*750cd175SCaroline Tice //if (log) 508*750cd175SCaroline Tice // log->Printf ("SBThread::GetNumFrames ()"); 509ceb6b139SCaroline Tice 510ceb6b139SCaroline Tice uint32_t num_frames = 0; 5116611103cSGreg Clayton if (m_opaque_sp) 512ceb6b139SCaroline Tice num_frames = m_opaque_sp->GetStackFrameCount(); 513ceb6b139SCaroline Tice 514ceb6b139SCaroline Tice if (log) 515*750cd175SCaroline Tice log->Printf ("SBThread::GetNumFrames (this.sp=%p) => %d", m_opaque_sp.get(), num_frames); 516ceb6b139SCaroline Tice 517ceb6b139SCaroline Tice return num_frames; 51830fdc8d8SChris Lattner } 51930fdc8d8SChris Lattner 52030fdc8d8SChris Lattner SBFrame 52130fdc8d8SChris Lattner SBThread::GetFrameAtIndex (uint32_t idx) 52230fdc8d8SChris Lattner { 523ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 524ceb6b139SCaroline Tice 525*750cd175SCaroline Tice //if (log) 526*750cd175SCaroline Tice // log->Printf ("SBThread::GetFrameAtIndex (uint32_t idx) idx = %d", idx); 527ceb6b139SCaroline Tice 52830fdc8d8SChris Lattner SBFrame sb_frame; 5296611103cSGreg Clayton if (m_opaque_sp) 5306611103cSGreg Clayton sb_frame.SetFrame (m_opaque_sp->GetStackFrameAtIndex (idx)); 531ceb6b139SCaroline Tice 532ceb6b139SCaroline Tice if (log) 533ceb6b139SCaroline Tice { 534ceb6b139SCaroline Tice SBStream sstr; 535ceb6b139SCaroline Tice sb_frame.GetDescription (sstr); 536*750cd175SCaroline Tice log->Printf ("SBThread::GetFrameAtIndex (this.sp=%p, idx=%d) => SBFrame.sp : this = %p, '%s'", 537*750cd175SCaroline Tice m_opaque_sp.get(), idx, sb_frame.get(), sstr.GetData()); 538ceb6b139SCaroline Tice } 539ceb6b139SCaroline Tice 54030fdc8d8SChris Lattner return sb_frame; 54130fdc8d8SChris Lattner } 54230fdc8d8SChris Lattner 54330fdc8d8SChris Lattner const lldb::SBThread & 54430fdc8d8SChris Lattner SBThread::operator = (const lldb::SBThread &rhs) 54530fdc8d8SChris Lattner { 546ceb6b139SCaroline Tice Log *log = lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_API); 547ceb6b139SCaroline Tice 548ceb6b139SCaroline Tice if (log) 549*750cd175SCaroline Tice log->Printf ("SBThread::operator= (this.sp=%p, rhs.sp=%p)", m_opaque_sp.get(), rhs.m_opaque_sp.get()); 550ceb6b139SCaroline Tice 5516611103cSGreg Clayton m_opaque_sp = rhs.m_opaque_sp; 55230fdc8d8SChris Lattner return *this; 55330fdc8d8SChris Lattner } 55430fdc8d8SChris Lattner 55530fdc8d8SChris Lattner bool 55630fdc8d8SChris Lattner SBThread::operator == (const SBThread &rhs) const 55730fdc8d8SChris Lattner { 5586611103cSGreg Clayton return m_opaque_sp.get() == rhs.m_opaque_sp.get(); 55930fdc8d8SChris Lattner } 56030fdc8d8SChris Lattner 56130fdc8d8SChris Lattner bool 56230fdc8d8SChris Lattner SBThread::operator != (const SBThread &rhs) const 56330fdc8d8SChris Lattner { 5646611103cSGreg Clayton return m_opaque_sp.get() != rhs.m_opaque_sp.get(); 56530fdc8d8SChris Lattner } 56630fdc8d8SChris Lattner 56730fdc8d8SChris Lattner lldb_private::Thread * 56830fdc8d8SChris Lattner SBThread::GetLLDBObjectPtr () 56930fdc8d8SChris Lattner { 5706611103cSGreg Clayton return m_opaque_sp.get(); 57130fdc8d8SChris Lattner } 57230fdc8d8SChris Lattner 57330fdc8d8SChris Lattner const lldb_private::Thread * 57430fdc8d8SChris Lattner SBThread::operator->() const 57530fdc8d8SChris Lattner { 5766611103cSGreg Clayton return m_opaque_sp.get(); 57730fdc8d8SChris Lattner } 57830fdc8d8SChris Lattner 57930fdc8d8SChris Lattner const lldb_private::Thread & 58030fdc8d8SChris Lattner SBThread::operator*() const 58130fdc8d8SChris Lattner { 5826611103cSGreg Clayton return *m_opaque_sp; 58330fdc8d8SChris Lattner } 58430fdc8d8SChris Lattner 58530fdc8d8SChris Lattner lldb_private::Thread * 58630fdc8d8SChris Lattner SBThread::operator->() 58730fdc8d8SChris Lattner { 5886611103cSGreg Clayton return m_opaque_sp.get(); 58930fdc8d8SChris Lattner } 59030fdc8d8SChris Lattner 59130fdc8d8SChris Lattner lldb_private::Thread & 59230fdc8d8SChris Lattner SBThread::operator*() 59330fdc8d8SChris Lattner { 5946611103cSGreg Clayton return *m_opaque_sp; 59530fdc8d8SChris Lattner } 596dde9cff3SCaroline Tice 597dde9cff3SCaroline Tice bool 598dde9cff3SCaroline Tice SBThread::GetDescription (SBStream &description) 599dde9cff3SCaroline Tice { 600dde9cff3SCaroline Tice if (m_opaque_sp) 60105faeb71SGreg Clayton { 60205faeb71SGreg Clayton StreamString strm; 60305faeb71SGreg Clayton description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID()); 60405faeb71SGreg Clayton } 605dde9cff3SCaroline Tice else 606dde9cff3SCaroline Tice description.Printf ("No value"); 607dde9cff3SCaroline Tice 608dde9cff3SCaroline Tice return true; 609dde9cff3SCaroline Tice } 610ceb6b139SCaroline Tice 611ceb6b139SCaroline Tice bool 612ceb6b139SCaroline Tice SBThread::GetDescription (SBStream &description) const 613ceb6b139SCaroline Tice { 614ceb6b139SCaroline Tice if (m_opaque_sp) 615ceb6b139SCaroline Tice { 616ceb6b139SCaroline Tice StreamString strm; 617ceb6b139SCaroline Tice description.Printf("SBThread: tid = 0x%4.4x", m_opaque_sp->GetID()); 618ceb6b139SCaroline Tice } 619ceb6b139SCaroline Tice else 620ceb6b139SCaroline Tice description.Printf ("No value"); 621ceb6b139SCaroline Tice 622ceb6b139SCaroline Tice return true; 623ceb6b139SCaroline Tice } 624