libldi library to collect extended backtrace information; switch to the libBacktraceRecording library and its APIs. Complete the work of adding QueueItems to Queues and allow for the QueueItems to be interrogated about their extended backtraces in turn. There's still cleanup and documentation to do on this code but the code is functional and I it's a good time to get the work-in-progress checked in. <rdar://problem/15314027> llvm-svn: 200822
96 lines
2.8 KiB
C++
96 lines
2.8 KiB
C++
//===-- HistoryThread.cpp ---------------------------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/lldb-private.h"
|
|
|
|
#include "Plugins/Process/Utility/HistoryUnwind.h"
|
|
#include "Plugins/Process/Utility/HistoryThread.h"
|
|
#include "Plugins/Process/Utility/RegisterContextHistory.h"
|
|
|
|
#include "lldb/Core/Log.h"
|
|
#include "lldb/Target/StackFrameList.h"
|
|
#include "lldb/Target/Process.h"
|
|
|
|
using namespace lldb;
|
|
using namespace lldb_private;
|
|
|
|
HistoryThread::HistoryThread (lldb_private::Process &process,
|
|
lldb::tid_t tid,
|
|
std::vector<lldb::addr_t> pcs,
|
|
uint32_t stop_id,
|
|
bool stop_id_is_valid) :
|
|
Thread (process, tid),
|
|
m_framelist_mutex(),
|
|
m_framelist(),
|
|
m_pcs (pcs),
|
|
m_stop_id (stop_id),
|
|
m_stop_id_is_valid (stop_id_is_valid),
|
|
m_extended_unwind_token (LLDB_INVALID_ADDRESS),
|
|
m_queue_name (),
|
|
m_thread_name (),
|
|
m_originating_unique_thread_id (tid),
|
|
m_queue_id (LLDB_INVALID_QUEUE_ID)
|
|
{
|
|
m_unwinder_ap.reset (new HistoryUnwind (*this, pcs, stop_id, stop_id_is_valid));
|
|
Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
|
|
if (log)
|
|
log->Printf ("%p HistoryThread::HistoryThread", this);
|
|
}
|
|
|
|
HistoryThread::~HistoryThread ()
|
|
{
|
|
Log *log(lldb_private::GetLogIfAllCategoriesSet (LIBLLDB_LOG_OBJECT));
|
|
if (log)
|
|
log->Printf ("%p HistoryThread::~HistoryThread (tid=0x%" PRIx64 ")", this, GetID());
|
|
DestroyThread();
|
|
}
|
|
|
|
lldb::RegisterContextSP
|
|
HistoryThread::GetRegisterContext ()
|
|
{
|
|
RegisterContextSP rctx ;
|
|
if (m_pcs.size() > 0)
|
|
{
|
|
rctx.reset (new RegisterContextHistory (*this, 0, GetProcess()->GetAddressByteSize(), m_pcs[0]));
|
|
}
|
|
return rctx;
|
|
|
|
}
|
|
|
|
lldb::RegisterContextSP
|
|
HistoryThread::CreateRegisterContextForFrame (StackFrame *frame)
|
|
{
|
|
return m_unwinder_ap->CreateRegisterContextForFrame (frame);
|
|
}
|
|
|
|
lldb::StackFrameListSP
|
|
HistoryThread::GetStackFrameList ()
|
|
{
|
|
Mutex::Locker (m_framelist_mutex);
|
|
if (m_framelist.get() == NULL)
|
|
{
|
|
m_framelist.reset (new StackFrameList (*this, StackFrameListSP(), true));
|
|
}
|
|
|
|
return m_framelist;
|
|
}
|
|
|
|
uint32_t
|
|
HistoryThread::GetExtendedBacktraceOriginatingIndexID ()
|
|
{
|
|
if (m_originating_unique_thread_id != LLDB_INVALID_THREAD_ID)
|
|
{
|
|
if (GetProcess()->HasAssignedIndexIDToThread (m_originating_unique_thread_id))
|
|
{
|
|
return GetProcess()->AssignIndexIDToThread (m_originating_unique_thread_id);
|
|
}
|
|
}
|
|
return LLDB_INVALID_THREAD_ID;
|
|
}
|