130fdc8d8SChris Lattner //===-- ThreadPlan.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 1093a64300SDaniel Malea #include "lldb/lldb-python.h" 1193a64300SDaniel Malea 1230fdc8d8SChris Lattner #include "lldb/Target/ThreadPlan.h" 1330fdc8d8SChris Lattner 1430fdc8d8SChris Lattner // C Includes 1530fdc8d8SChris Lattner // C++ Includes 1630fdc8d8SChris Lattner // Other libraries and framework includes 1730fdc8d8SChris Lattner // Project includes 1806e827ccSJim Ingham #include "lldb/Core/Debugger.h" 1930fdc8d8SChris Lattner #include "lldb/Core/Log.h" 2030fdc8d8SChris Lattner #include "lldb/Core/State.h" 212cad65a5SGreg Clayton #include "lldb/Target/RegisterContext.h" 222cad65a5SGreg Clayton #include "lldb/Target/Thread.h" 2306e827ccSJim Ingham #include "lldb/Target/Process.h" 2406e827ccSJim Ingham #include "lldb/Target/Target.h" 2530fdc8d8SChris Lattner 2630fdc8d8SChris Lattner using namespace lldb; 2730fdc8d8SChris Lattner using namespace lldb_private; 2830fdc8d8SChris Lattner 2930fdc8d8SChris Lattner //---------------------------------------------------------------------- 3030fdc8d8SChris Lattner // ThreadPlan constructor 3130fdc8d8SChris Lattner //---------------------------------------------------------------------- 32b01e742aSJim Ingham ThreadPlan::ThreadPlan(ThreadPlanKind kind, const char *name, Thread &thread, Vote stop_vote, Vote run_vote) : 3330fdc8d8SChris Lattner m_thread (thread), 3430fdc8d8SChris Lattner m_stop_vote (stop_vote), 3530fdc8d8SChris Lattner m_run_vote (run_vote), 361ee0d4f7SBenjamin Kramer m_kind (kind), 371ee0d4f7SBenjamin Kramer m_name (name), 381ee0d4f7SBenjamin Kramer m_plan_complete_mutex (Mutex::eMutexTypeRecursive), 391ee0d4f7SBenjamin Kramer m_plan_complete (false), 401ee0d4f7SBenjamin Kramer m_plan_private (false), 4164e7ead1SJim Ingham m_okay_to_discard (true), 42fbbfe6ecSJim Ingham m_is_master_plan (false), 43fbbfe6ecSJim Ingham m_plan_succeeded(true) 4430fdc8d8SChris Lattner { 4530fdc8d8SChris Lattner SetID (GetNextID()); 4630fdc8d8SChris Lattner } 4730fdc8d8SChris Lattner 4830fdc8d8SChris Lattner //---------------------------------------------------------------------- 4930fdc8d8SChris Lattner // Destructor 5030fdc8d8SChris Lattner //---------------------------------------------------------------------- 5130fdc8d8SChris Lattner ThreadPlan::~ThreadPlan() 5230fdc8d8SChris Lattner { 5330fdc8d8SChris Lattner } 5430fdc8d8SChris Lattner 5530fdc8d8SChris Lattner bool 5630fdc8d8SChris Lattner ThreadPlan::IsPlanComplete () 5730fdc8d8SChris Lattner { 58b132097bSGreg Clayton Mutex::Locker locker(m_plan_complete_mutex); 5930fdc8d8SChris Lattner return m_plan_complete; 6030fdc8d8SChris Lattner } 6130fdc8d8SChris Lattner 6230fdc8d8SChris Lattner void 63fbbfe6ecSJim Ingham ThreadPlan::SetPlanComplete (bool success) 6430fdc8d8SChris Lattner { 65b132097bSGreg Clayton Mutex::Locker locker(m_plan_complete_mutex); 6630fdc8d8SChris Lattner m_plan_complete = true; 67fbbfe6ecSJim Ingham m_plan_succeeded = success; 6830fdc8d8SChris Lattner } 6930fdc8d8SChris Lattner 7030fdc8d8SChris Lattner bool 7130fdc8d8SChris Lattner ThreadPlan::MischiefManaged () 7230fdc8d8SChris Lattner { 73b132097bSGreg Clayton Mutex::Locker locker(m_plan_complete_mutex); 7418de2fdcSJim Ingham // Mark the plan is complete, but don't override the success flag. 7530fdc8d8SChris Lattner m_plan_complete = true; 7630fdc8d8SChris Lattner return true; 7730fdc8d8SChris Lattner } 7830fdc8d8SChris Lattner 7930fdc8d8SChris Lattner Vote 8030fdc8d8SChris Lattner ThreadPlan::ShouldReportStop (Event *event_ptr) 8130fdc8d8SChris Lattner { 82*5160ce5cSGreg Clayton Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_STEP)); 832cad65a5SGreg Clayton 8430fdc8d8SChris Lattner if (m_stop_vote == eVoteNoOpinion) 8530fdc8d8SChris Lattner { 8630fdc8d8SChris Lattner ThreadPlan *prev_plan = GetPreviousPlan (); 8730fdc8d8SChris Lattner if (prev_plan) 882cad65a5SGreg Clayton { 892cad65a5SGreg Clayton Vote prev_vote = prev_plan->ShouldReportStop (event_ptr); 902cad65a5SGreg Clayton if (log) 91b5c0d1ccSJim Ingham log->Printf ("ThreadPlan::ShouldReportStop() returning previous thread plan vote: %s", 92b5c0d1ccSJim Ingham GetVoteAsCString (prev_vote)); 932cad65a5SGreg Clayton return prev_vote; 9430fdc8d8SChris Lattner } 952cad65a5SGreg Clayton } 962cad65a5SGreg Clayton if (log) 971346f7e0SGreg Clayton log->Printf ("ThreadPlan::ShouldReportStop() returning vote: %s", GetVoteAsCString (m_stop_vote)); 9830fdc8d8SChris Lattner return m_stop_vote; 9930fdc8d8SChris Lattner } 10030fdc8d8SChris Lattner 10130fdc8d8SChris Lattner Vote 10230fdc8d8SChris Lattner ThreadPlan::ShouldReportRun (Event *event_ptr) 10330fdc8d8SChris Lattner { 10430fdc8d8SChris Lattner if (m_run_vote == eVoteNoOpinion) 10530fdc8d8SChris Lattner { 10630fdc8d8SChris Lattner ThreadPlan *prev_plan = GetPreviousPlan (); 10730fdc8d8SChris Lattner if (prev_plan) 10830fdc8d8SChris Lattner return prev_plan->ShouldReportRun (event_ptr); 10930fdc8d8SChris Lattner } 11030fdc8d8SChris Lattner return m_run_vote; 11130fdc8d8SChris Lattner } 11230fdc8d8SChris Lattner 11330fdc8d8SChris Lattner bool 11430fdc8d8SChris Lattner ThreadPlan::StopOthers () 11530fdc8d8SChris Lattner { 11630fdc8d8SChris Lattner ThreadPlan *prev_plan; 11730fdc8d8SChris Lattner prev_plan = GetPreviousPlan (); 11830fdc8d8SChris Lattner if (prev_plan == NULL) 11930fdc8d8SChris Lattner return false; 12030fdc8d8SChris Lattner else 12130fdc8d8SChris Lattner return prev_plan->StopOthers(); 12230fdc8d8SChris Lattner } 12330fdc8d8SChris Lattner 124f48169bbSJim Ingham void 125f48169bbSJim Ingham ThreadPlan::SetStopOthers (bool new_value) 126f48169bbSJim Ingham { 127f48169bbSJim Ingham // SetStopOthers doesn't work up the hierarchy. You have to set the 128f48169bbSJim Ingham // explicit ThreadPlan you want to affect. 129f48169bbSJim Ingham } 130f48169bbSJim Ingham 13130fdc8d8SChris Lattner bool 13230fdc8d8SChris Lattner ThreadPlan::WillResume (StateType resume_state, bool current_plan) 13330fdc8d8SChris Lattner { 13430fdc8d8SChris Lattner if (current_plan) 13530fdc8d8SChris Lattner { 136*5160ce5cSGreg Clayton Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_STEP)); 13730fdc8d8SChris Lattner 13830fdc8d8SChris Lattner if (log) 1392cad65a5SGreg Clayton { 1405ccbd294SGreg Clayton RegisterContext *reg_ctx = m_thread.GetRegisterContext().get(); 1412cad65a5SGreg Clayton addr_t pc = reg_ctx->GetPC(); 1422cad65a5SGreg Clayton addr_t sp = reg_ctx->GetSP(); 1432cad65a5SGreg Clayton addr_t fp = reg_ctx->GetFP(); 144d01b2953SDaniel Malea log->Printf("%s Thread #%u: tid = 0x%4.4" PRIx64 ", pc = 0x%8.8" PRIx64 ", sp = 0x%8.8" PRIx64 ", fp = 0x%8.8" PRIx64 ", " 145b5c0d1ccSJim Ingham "plan = '%s', state = %s, stop others = %d", 1461346f7e0SGreg Clayton __FUNCTION__, 1472cad65a5SGreg Clayton m_thread.GetIndexID(), 1482cad65a5SGreg Clayton m_thread.GetID(), 1492cad65a5SGreg Clayton (uint64_t)pc, 1502cad65a5SGreg Clayton (uint64_t)sp, 1512cad65a5SGreg Clayton (uint64_t)fp, 1522cad65a5SGreg Clayton m_name.c_str(), 1532cad65a5SGreg Clayton StateAsCString(resume_state), 1542cad65a5SGreg Clayton StopOthers()); 1552cad65a5SGreg Clayton } 15630fdc8d8SChris Lattner } 15730fdc8d8SChris Lattner return true; 15830fdc8d8SChris Lattner } 15930fdc8d8SChris Lattner 16030fdc8d8SChris Lattner lldb::user_id_t 16130fdc8d8SChris Lattner ThreadPlan::GetNextID() 16230fdc8d8SChris Lattner { 16330fdc8d8SChris Lattner static uint32_t g_nextPlanID = 0; 16430fdc8d8SChris Lattner return ++g_nextPlanID; 16530fdc8d8SChris Lattner } 16630fdc8d8SChris Lattner 16730fdc8d8SChris Lattner void 16830fdc8d8SChris Lattner ThreadPlan::DidPush() 16930fdc8d8SChris Lattner { 17030fdc8d8SChris Lattner } 17130fdc8d8SChris Lattner 17230fdc8d8SChris Lattner void 17330fdc8d8SChris Lattner ThreadPlan::WillPop() 17430fdc8d8SChris Lattner { 17530fdc8d8SChris Lattner } 17630fdc8d8SChris Lattner 17730fdc8d8SChris Lattner bool 17830fdc8d8SChris Lattner ThreadPlan::OkayToDiscard() 17930fdc8d8SChris Lattner { 18030fdc8d8SChris Lattner if (!IsMasterPlan()) 18130fdc8d8SChris Lattner return true; 18230fdc8d8SChris Lattner else 18330fdc8d8SChris Lattner return m_okay_to_discard; 18430fdc8d8SChris Lattner } 18530fdc8d8SChris Lattner 18606e827ccSJim Ingham lldb::StateType 18706e827ccSJim Ingham ThreadPlan::RunState () 18806e827ccSJim Ingham { 18906e827ccSJim Ingham if (m_tracer_sp && m_tracer_sp->TracingEnabled() && m_tracer_sp->SingleStepEnabled()) 19006e827ccSJim Ingham return eStateStepping; 19106e827ccSJim Ingham else 19206e827ccSJim Ingham return GetPlanRunState(); 19306e827ccSJim Ingham } 194