Files
clang-p2996/lldb/source/API/SBMemoryRegionInfo.cpp
Howard Hellyer 2603684372 Add MemoryRegionInfo to SB API
Summary:
This adds new SB API calls and classes to allow a user of the SB API to obtain a full list of memory regions accessible within the process. Adding this to the API makes it possible use the API for tasks like scanning memory for blocks allocated with a header and footer to track down memory leaks, otherwise just inspecting every address is impractical especially for 64 bit processes.

These changes only add the API itself and a base implementation of GetMemoryRegions() to lldb_private::Process::GetMemoryRegions.
I will submit separate patches to fill in lldb_private::Process::GetMemoryRegionInfoList and GetMemoryRegionInfo for individual platforms.

The original discussion about this is here:
http://lists.llvm.org/pipermail/lldb-dev/2016-May/010203.html

Reviewers: clayborg

Subscribers: lldb-commits

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

llvm-svn: 273547
2016-06-23 08:35:37 +00:00

122 lines
2.7 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::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;
}