Files
clang-p2996/lldb/source/API/SBMemoryRegionInfo.cpp
Howard Hellyer ad00756301 Implement GetMemoryRegions() for Linux and Mac OSX core files.
Summary:
This patch fills in the implementation of GetMemoryRegions() on the Linux and Mac OS core file implementations of lldb_private::Process (ProcessElfCore::GetMemoryRegions and ProcessMachCore::GetMemoryRegions.) The GetMemoryRegions API was added under: http://reviews.llvm.org/D20565

The patch re-uses the m_core_range_infos list that was recently added to implement GetMemoryRegionInfo in both ProcessElfCore and ProcessMachCore to ensure the returned regions match the regions returned by Process::GetMemoryRegionInfo(addr_t load_addr, MemoryRegionInfo &region_info).

Reviewers: clayborg

Subscribers: labath, lldb-commits

Differential Revision: http://reviews.llvm.org/D21751

llvm-svn: 274741
2016-07-07 08:21:28 +00:00

127 lines
2.8 KiB
C++

//===-- SBMemoryRegionInfo.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/API/SBDefines.h"
#include "lldb/API/SBError.h"
#include "lldb/API/SBMemoryRegionInfo.h"
#include "lldb/API/SBStream.h"
#include "lldb/Core/StreamString.h"
#include "lldb/Target/MemoryRegionInfo.h"
using namespace lldb;
using namespace lldb_private;
SBMemoryRegionInfo::SBMemoryRegionInfo () :
m_opaque_ap (new MemoryRegionInfo())
{
}
SBMemoryRegionInfo::SBMemoryRegionInfo (const MemoryRegionInfo *lldb_object_ptr) :
m_opaque_ap (new MemoryRegionInfo())
{
if (lldb_object_ptr)
ref() = *lldb_object_ptr;
}
SBMemoryRegionInfo::SBMemoryRegionInfo(const SBMemoryRegionInfo &rhs) :
m_opaque_ap (new MemoryRegionInfo())
{
ref() = rhs.ref();
}
const SBMemoryRegionInfo &
SBMemoryRegionInfo::operator = (const SBMemoryRegionInfo &rhs)
{
if (this != &rhs)
{
ref() = rhs.ref();
}
return *this;
}
SBMemoryRegionInfo::~SBMemoryRegionInfo ()
{
}
void
SBMemoryRegionInfo::Clear()
{
m_opaque_ap->Clear();
}
bool
SBMemoryRegionInfo::operator == (const SBMemoryRegionInfo &rhs) const
{
return ref() == rhs.ref();
}
bool
SBMemoryRegionInfo::operator != (const SBMemoryRegionInfo &rhs) const
{
return ref() != rhs.ref();
}
MemoryRegionInfo &
SBMemoryRegionInfo::ref()
{
return *m_opaque_ap;
}
const MemoryRegionInfo &
SBMemoryRegionInfo::ref() const
{
return *m_opaque_ap;
}
lldb::addr_t
SBMemoryRegionInfo::GetRegionBase () {
return m_opaque_ap->GetRange().GetRangeBase();
}
lldb::addr_t
SBMemoryRegionInfo::GetRegionEnd () {
return m_opaque_ap->GetRange().GetRangeEnd();
}
bool
SBMemoryRegionInfo::IsReadable () {
return m_opaque_ap->GetReadable() == MemoryRegionInfo::eYes;
}
bool
SBMemoryRegionInfo::IsWritable () {
return m_opaque_ap->GetWritable() == MemoryRegionInfo::eYes;
}
bool
SBMemoryRegionInfo::IsExecutable () {
return m_opaque_ap->GetExecutable() == MemoryRegionInfo::eYes;
}
bool
SBMemoryRegionInfo::IsMapped () {
return m_opaque_ap->GetMapped() == MemoryRegionInfo::eYes;
}
bool
SBMemoryRegionInfo::GetDescription (SBStream &description)
{
Stream &strm = description.ref();
const addr_t load_addr = m_opaque_ap->GetRange().base;
strm.Printf ("[0x%16.16" PRIx64 "-0x%16.16" PRIx64 " ", load_addr, load_addr + m_opaque_ap->GetRange().size);
strm.Printf (m_opaque_ap->GetReadable() ? "R" : "-");
strm.Printf (m_opaque_ap->GetWritable() ? "W" : "-");
strm.Printf (m_opaque_ap->GetExecutable() ? "X" : "-");
strm.Printf ("]");
return true;
}