| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 
 | //===-- HistoryUnwind.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/RegisterContextHistory.h"
#include "Plugins/Process/Utility/HistoryUnwind.h"
#include "lldb/Target/StackFrame.h"
#include "lldb/Target/Thread.h"
#include "lldb/Target/Process.h"
#include "lldb/Target/Target.h"
using namespace lldb;
using namespace lldb_private;
// Constructor 
HistoryUnwind::HistoryUnwind (Thread &thread,
                              std::vector<lldb::addr_t> pcs,
                              bool stop_id_is_valid) :
        Unwind (thread),
        m_pcs (pcs),
        m_stop_id_is_valid (stop_id_is_valid)
{
}
// Destructor
HistoryUnwind::~HistoryUnwind ()
{
}
void
HistoryUnwind::DoClear ()
{
    std::lock_guard<std::recursive_mutex> guard(m_unwind_mutex);
    m_pcs.clear();
    m_stop_id_is_valid = false;
}
lldb::RegisterContextSP
HistoryUnwind::DoCreateRegisterContextForFrame (StackFrame *frame)
{
    RegisterContextSP rctx;
    if (frame)
    {
        addr_t pc = frame->GetFrameCodeAddress().GetLoadAddress (&frame->GetThread()->GetProcess()->GetTarget());
        if (pc != LLDB_INVALID_ADDRESS)
        {
            rctx.reset (new RegisterContextHistory (*frame->GetThread().get(), frame->GetConcreteFrameIndex(), 
                        frame->GetThread()->GetProcess()->GetAddressByteSize(), pc));
        }
    }
    return rctx;
}
bool
HistoryUnwind::DoGetFrameInfoAtIndex (uint32_t frame_idx, lldb::addr_t& cfa, lldb::addr_t& pc)
{
    // FIXME do not throw away the lock after we acquire it..
    std::unique_lock<std::recursive_mutex> guard(m_unwind_mutex);
    guard.unlock();
    if (frame_idx < m_pcs.size())
    {
        cfa = frame_idx;
        pc = m_pcs[frame_idx];
        return true;
    }
    return false;
}
uint32_t
HistoryUnwind::DoGetFrameCount ()
{
    return m_pcs.size();
}
 |