130fdc8d8SChris Lattner //===-- ThreadPlanBase.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 1030fdc8d8SChris Lattner #include "lldb/Target/ThreadPlanBase.h" 1130fdc8d8SChris Lattner 1230fdc8d8SChris Lattner // C Includes 1330fdc8d8SChris Lattner // C++ Includes 1430fdc8d8SChris Lattner // Other libraries and framework includes 1530fdc8d8SChris Lattner // Project includes 1630fdc8d8SChris Lattner // 1730fdc8d8SChris Lattner #include "lldb/Breakpoint/StoppointCallbackContext.h" 1830fdc8d8SChris Lattner #include "lldb/Breakpoint/BreakpointSite.h" 1930fdc8d8SChris Lattner #include "lldb/Breakpoint/BreakpointLocation.h" 2030fdc8d8SChris Lattner #include "lldb/Breakpoint/Breakpoint.h" 2130fdc8d8SChris Lattner #include "lldb/Core/Stream.h" 2230fdc8d8SChris Lattner #include "lldb/Target/Process.h" 2330fdc8d8SChris Lattner #include "lldb/Target/RegisterContext.h" 24f4b47e15SGreg Clayton #include "lldb/Target/StopInfo.h" 2530fdc8d8SChris Lattner 2630fdc8d8SChris Lattner using namespace lldb; 2730fdc8d8SChris Lattner using namespace lldb_private; 2830fdc8d8SChris Lattner 2930fdc8d8SChris Lattner //---------------------------------------------------------------------- 3030fdc8d8SChris Lattner // ThreadPlanBase: This one always stops, and never has anything particular 3130fdc8d8SChris Lattner // to do. 3230fdc8d8SChris Lattner // FIXME: The "signal handling" policies should probably go here. 3330fdc8d8SChris Lattner //---------------------------------------------------------------------- 3430fdc8d8SChris Lattner 3530fdc8d8SChris Lattner ThreadPlanBase::ThreadPlanBase (Thread &thread) : 36b01e742aSJim Ingham ThreadPlan(ThreadPlan::eKindBase, "base plan", thread, eVoteYes, eVoteNoOpinion) 3730fdc8d8SChris Lattner { 3806e827ccSJim Ingham // Set the tracer to a default tracer. 39773d981cSJim Ingham // FIXME: need to add a thread settings variable to pix various tracers... 40773d981cSJim Ingham #define THREAD_PLAN_USE_ASSEMBLY_TRACER 1 41773d981cSJim Ingham 42773d981cSJim Ingham #ifdef THREAD_PLAN_USE_ASSEMBLY_TRACER 43773d981cSJim Ingham ThreadPlanTracerSP new_tracer_sp (new ThreadPlanAssemblyTracer (m_thread)); 44773d981cSJim Ingham #else 4506e827ccSJim Ingham ThreadPlanTracerSP new_tracer_sp (new ThreadPlanTracer (m_thread)); 46773d981cSJim Ingham #endif 4706e827ccSJim Ingham new_tracer_sp->EnableTracing (m_thread.GetTraceEnabledState()); 4806e827ccSJim Ingham SetThreadPlanTracer(new_tracer_sp); 4930fdc8d8SChris Lattner } 5030fdc8d8SChris Lattner 5130fdc8d8SChris Lattner ThreadPlanBase::~ThreadPlanBase () 5230fdc8d8SChris Lattner { 5330fdc8d8SChris Lattner 5430fdc8d8SChris Lattner } 5530fdc8d8SChris Lattner 5630fdc8d8SChris Lattner void 5730fdc8d8SChris Lattner ThreadPlanBase::GetDescription (Stream *s, lldb::DescriptionLevel level) 5830fdc8d8SChris Lattner { 5930fdc8d8SChris Lattner s->Printf ("Base thread plan."); 6030fdc8d8SChris Lattner } 6130fdc8d8SChris Lattner 6230fdc8d8SChris Lattner bool 6330fdc8d8SChris Lattner ThreadPlanBase::ValidatePlan (Stream *error) 6430fdc8d8SChris Lattner { 6530fdc8d8SChris Lattner return true; 6630fdc8d8SChris Lattner } 6730fdc8d8SChris Lattner 6830fdc8d8SChris Lattner bool 6930fdc8d8SChris Lattner ThreadPlanBase::PlanExplainsStop () 7030fdc8d8SChris Lattner { 7106e827ccSJim Ingham // The base plan should defer to its tracer, since by default it 7206e827ccSJim Ingham // always handles the stop. 7306e827ccSJim Ingham if (TracerExplainsStop()) 7406e827ccSJim Ingham return false; 7506e827ccSJim Ingham else 7630fdc8d8SChris Lattner return true; 7730fdc8d8SChris Lattner } 7830fdc8d8SChris Lattner 7930fdc8d8SChris Lattner bool 8030fdc8d8SChris Lattner ThreadPlanBase::ShouldStop (Event *event_ptr) 8130fdc8d8SChris Lattner { 8230fdc8d8SChris Lattner m_stop_vote = eVoteYes; 8330fdc8d8SChris Lattner m_run_vote = eVoteYes; 8430fdc8d8SChris Lattner 85b15bfc75SJim Ingham StopInfoSP stop_info_sp = GetPrivateStopReason(); 86b15bfc75SJim Ingham if (stop_info_sp) 8730fdc8d8SChris Lattner { 88b15bfc75SJim Ingham StopReason reason = stop_info_sp->GetStopReason(); 8930fdc8d8SChris Lattner switch (reason) 9030fdc8d8SChris Lattner { 9130fdc8d8SChris Lattner case eStopReasonInvalid: 9230fdc8d8SChris Lattner case eStopReasonNone: 93*444586b5SJim Ingham // This 94*444586b5SJim Ingham m_run_vote = eVoteNoOpinion; 9530fdc8d8SChris Lattner m_stop_vote = eVoteNo; 9630fdc8d8SChris Lattner return false; 97f4b47e15SGreg Clayton 9830fdc8d8SChris Lattner case eStopReasonBreakpoint: 99b15bfc75SJim Ingham if (stop_info_sp->ShouldStop(event_ptr)) 10030fdc8d8SChris Lattner { 10130fdc8d8SChris Lattner // If we are going to stop for a breakpoint, then unship the other plans 10230fdc8d8SChris Lattner // at this point. Don't force the discard, however, so Master plans can stay 10330fdc8d8SChris Lattner // in place if they want to. 10430fdc8d8SChris Lattner m_thread.DiscardThreadPlans(false); 105f4b47e15SGreg Clayton return true; 10630fdc8d8SChris Lattner } 107f4b47e15SGreg Clayton // If we aren't going to stop at this breakpoint, and it is internal, 108f4b47e15SGreg Clayton // don't report this stop or the subsequent running event. 109f4b47e15SGreg Clayton // Otherwise we will post the stopped & running, but the stopped event will get marked 110f4b47e15SGreg Clayton // with "restarted" so the UI will know to wait and expect the consequent "running". 111b15bfc75SJim Ingham if (stop_info_sp->ShouldNotify (event_ptr)) 112f4b47e15SGreg Clayton { 113f4b47e15SGreg Clayton m_stop_vote = eVoteYes; 114f4b47e15SGreg Clayton m_run_vote = eVoteYes; 115f4b47e15SGreg Clayton } 116f4b47e15SGreg Clayton else 117f4b47e15SGreg Clayton { 118f4b47e15SGreg Clayton m_stop_vote = eVoteNo; 119f4b47e15SGreg Clayton m_run_vote = eVoteNo; 120f4b47e15SGreg Clayton } 121f4b47e15SGreg Clayton return false; 12230fdc8d8SChris Lattner 123f4b47e15SGreg Clayton // TODO: the break below was missing, was this intentional??? If so 124f4b47e15SGreg Clayton // please mention it 125f4b47e15SGreg Clayton break; 126f4b47e15SGreg Clayton 12730fdc8d8SChris Lattner case eStopReasonException: 12830fdc8d8SChris Lattner // If we crashed, discard thread plans and stop. Don't force the discard, however, 12930fdc8d8SChris Lattner // since on rerun the target may clean up this exception and continue normally from there. 13030fdc8d8SChris Lattner m_thread.DiscardThreadPlans(false); 13130fdc8d8SChris Lattner return true; 132f4b47e15SGreg Clayton 13330fdc8d8SChris Lattner case eStopReasonSignal: 134b15bfc75SJim Ingham if (stop_info_sp->ShouldStop(event_ptr)) 13530fdc8d8SChris Lattner { 13630fdc8d8SChris Lattner m_thread.DiscardThreadPlans(false); 13730fdc8d8SChris Lattner return true; 13830fdc8d8SChris Lattner } 13930fdc8d8SChris Lattner else 14030fdc8d8SChris Lattner { 14130fdc8d8SChris Lattner // We're not going to stop, but while we are here, let's figure out 14230fdc8d8SChris Lattner // whether to report this. 143b15bfc75SJim Ingham if (stop_info_sp->ShouldNotify(event_ptr)) 14430fdc8d8SChris Lattner m_stop_vote = eVoteYes; 14530fdc8d8SChris Lattner else 14630fdc8d8SChris Lattner m_stop_vote = eVoteNo; 147f4b47e15SGreg Clayton } 14830fdc8d8SChris Lattner return false; 149f4b47e15SGreg Clayton 15030fdc8d8SChris Lattner default: 15130fdc8d8SChris Lattner return true; 15230fdc8d8SChris Lattner } 15330fdc8d8SChris Lattner 15430fdc8d8SChris Lattner } 155f4b47e15SGreg Clayton else 156f4b47e15SGreg Clayton { 157*444586b5SJim Ingham m_run_vote = eVoteNoOpinion; 158f4b47e15SGreg Clayton m_stop_vote = eVoteNo; 159f4b47e15SGreg Clayton } 16030fdc8d8SChris Lattner 16130fdc8d8SChris Lattner // If there's no explicit reason to stop, then we will continue. 16230fdc8d8SChris Lattner return false; 16330fdc8d8SChris Lattner } 16430fdc8d8SChris Lattner 16530fdc8d8SChris Lattner bool 16630fdc8d8SChris Lattner ThreadPlanBase::StopOthers () 16730fdc8d8SChris Lattner { 16830fdc8d8SChris Lattner return false; 16930fdc8d8SChris Lattner } 17030fdc8d8SChris Lattner 17130fdc8d8SChris Lattner StateType 17206e827ccSJim Ingham ThreadPlanBase::GetPlanRunState () 17330fdc8d8SChris Lattner { 17430fdc8d8SChris Lattner return eStateRunning; 17530fdc8d8SChris Lattner } 17630fdc8d8SChris Lattner 17730fdc8d8SChris Lattner bool 17830fdc8d8SChris Lattner ThreadPlanBase::WillStop () 17930fdc8d8SChris Lattner { 18030fdc8d8SChris Lattner return true; 18130fdc8d8SChris Lattner } 18230fdc8d8SChris Lattner 183*444586b5SJim Ingham bool 184*444586b5SJim Ingham ThreadPlanBase::WillResume (lldb::StateType resume_state, bool current_plan) 185*444586b5SJim Ingham { 186*444586b5SJim Ingham // Reset these to the default values so we don't set them wrong, then not get asked 187*444586b5SJim Ingham // for a while, then return the wrong answer. 188*444586b5SJim Ingham m_run_vote = eVoteNoOpinion; 189*444586b5SJim Ingham m_stop_vote = eVoteNo; 190*444586b5SJim Ingham return true; 191*444586b5SJim Ingham } 192*444586b5SJim Ingham 193*444586b5SJim Ingham 19430fdc8d8SChris Lattner // The base plan is never done. 19530fdc8d8SChris Lattner bool 19630fdc8d8SChris Lattner ThreadPlanBase::MischiefManaged () 19730fdc8d8SChris Lattner { 19830fdc8d8SChris Lattner // The base plan is never done. 19930fdc8d8SChris Lattner return false; 20030fdc8d8SChris Lattner } 20130fdc8d8SChris Lattner 202