nstool/lib/libnx/source/MemoryPageEntry.cpp
2018-03-22 13:26:22 +08:00

91 lines
1.7 KiB
C++

#include <nx/MemoryPageEntry.h>
nx::MemoryPageEntry::MemoryPageEntry() :
mCap(KernelCapability::KC_INVALID),
mPage(0),
mFlag(false),
mUseFlag(false)
{}
nx::MemoryPageEntry::MemoryPageEntry(const KernelCapability & kernel_cap) :
mCap(KernelCapability::KC_INVALID),
mPage(0),
mFlag(false),
mUseFlag(false)
{
setKernelCapability(kernel_cap);
}
nx::MemoryPageEntry::MemoryPageEntry(uint32_t page) :
mCap(KernelCapability::KC_INVALID),
mPage(0),
mFlag(false),
mUseFlag(false)
{
setPage(page);
}
nx::MemoryPageEntry::MemoryPageEntry(uint32_t page, bool flag) :
mCap(KernelCapability::KC_INVALID),
mPage(0),
mFlag(false),
mUseFlag(true)
{
setPage(page);
setFlag(flag);
}
const nx::KernelCapability & nx::MemoryPageEntry::getKernelCapability() const
{
return mCap;
}
void nx::MemoryPageEntry::setKernelCapability(const KernelCapability & kernel_cap)
{
if (kernel_cap.getType() != KernelCapability::KC_MEMORY_MAP && kernel_cap.getType() != KernelCapability::KC_IO_MEMORY_MAP)
{
throw fnd::Exception(kModuleName, "KernelCapability is not type 'MemoryMap' or 'IOMemoryMap");
}
mCap = kernel_cap;
processCapField();
}
uint32_t nx::MemoryPageEntry::getPage() const
{
return mPage;
}
void nx::MemoryPageEntry::setPage(uint32_t page)
{
if (page > kMaxPage)
{
throw fnd::Exception(kModuleName, "Illegal memory page. (range: 0x000000 - 0xFFFFFF)");
}
mPage = page;
updateCapField();
}
bool nx::MemoryPageEntry::getFlag() const
{
return mFlag;
}
void nx::MemoryPageEntry::setFlag(bool flag)
{
mFlag = flag;
updateCapField();
}
bool nx::MemoryPageEntry::isMultiplePages() const
{
return mUseFlag;
}
void nx::MemoryPageEntry::setMapMultiplePages(bool useFlag)
{
mUseFlag = useFlag;
}