mirror of
https://github.com/jakcron/nstool.git
synced 2025-01-10 11:45:28 +00:00
110 lines
2.1 KiB
C++
110 lines
2.1 KiB
C++
#include <nn/hac/MemoryPageEntry.h>
|
|
|
|
nn::hac::MemoryPageEntry::MemoryPageEntry() :
|
|
mCap(kc::KC_INVALID),
|
|
mPage(0),
|
|
mFlag(false),
|
|
mUseFlag(false)
|
|
{}
|
|
|
|
nn::hac::MemoryPageEntry::MemoryPageEntry(const KernelCapabilityEntry & kernel_cap) :
|
|
mCap(kc::KC_INVALID),
|
|
mPage(0),
|
|
mFlag(false),
|
|
mUseFlag(false)
|
|
{
|
|
setKernelCapability(kernel_cap);
|
|
}
|
|
|
|
nn::hac::MemoryPageEntry::MemoryPageEntry(uint32_t page) :
|
|
mCap(kc::KC_INVALID),
|
|
mPage(0),
|
|
mFlag(false),
|
|
mUseFlag(false)
|
|
{
|
|
setPage(page);
|
|
}
|
|
|
|
nn::hac::MemoryPageEntry::MemoryPageEntry(uint32_t page, bool flag) :
|
|
mCap(kc::KC_INVALID),
|
|
mPage(0),
|
|
mFlag(false),
|
|
mUseFlag(true)
|
|
{
|
|
setPage(page);
|
|
setFlag(flag);
|
|
}
|
|
|
|
void nn::hac::MemoryPageEntry::operator=(const MemoryPageEntry& other)
|
|
{
|
|
mPage = other.mPage;
|
|
mFlag = other.mFlag;
|
|
mUseFlag = other.mUseFlag;
|
|
updateCapField();
|
|
}
|
|
|
|
bool nn::hac::MemoryPageEntry::operator==(const MemoryPageEntry& other) const
|
|
{
|
|
return (mPage == other.mPage) \
|
|
&& (mFlag == other.mFlag) \
|
|
&& (mUseFlag == other.mUseFlag);
|
|
}
|
|
|
|
bool nn::hac::MemoryPageEntry::operator!=(const MemoryPageEntry& other) const
|
|
{
|
|
return !(*this == other);
|
|
}
|
|
|
|
const nn::hac::KernelCapabilityEntry & nn::hac::MemoryPageEntry::getKernelCapability() const
|
|
{
|
|
return mCap;
|
|
}
|
|
|
|
void nn::hac::MemoryPageEntry::setKernelCapability(const KernelCapabilityEntry & kernel_cap)
|
|
{
|
|
if (kernel_cap.getType() != kc::KC_MEMORY_MAP && kernel_cap.getType() != kc::KC_IO_MEMORY_MAP)
|
|
{
|
|
throw fnd::Exception(kModuleName, "KernelCapabilityEntry is not type 'MemoryMap' or 'IOMemoryMap");
|
|
}
|
|
|
|
mCap = kernel_cap;
|
|
processCapField();
|
|
}
|
|
|
|
uint32_t nn::hac::MemoryPageEntry::getPage() const
|
|
{
|
|
return mPage;
|
|
}
|
|
|
|
void nn::hac::MemoryPageEntry::setPage(uint32_t page)
|
|
{
|
|
if (page > kMaxPage)
|
|
{
|
|
throw fnd::Exception(kModuleName, "Illegal memory page. (range: 0x000000 - 0xFFFFFF)");
|
|
}
|
|
|
|
mPage = page;
|
|
updateCapField();
|
|
}
|
|
|
|
bool nn::hac::MemoryPageEntry::getFlag() const
|
|
{
|
|
return mFlag;
|
|
}
|
|
|
|
void nn::hac::MemoryPageEntry::setFlag(bool flag)
|
|
{
|
|
mFlag = flag;
|
|
updateCapField();
|
|
}
|
|
|
|
bool nn::hac::MemoryPageEntry::isMultiplePages() const
|
|
{
|
|
return mUseFlag;
|
|
}
|
|
|
|
void nn::hac::MemoryPageEntry::setMapMultiplePages(bool useFlag)
|
|
{
|
|
mUseFlag = useFlag;
|
|
}
|