diff options
author | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2015-07-10 03:52:15 +0200 |
---|---|---|
committer | Yuri Kunde Schlesner <yuriks@yuriks.net> | 2015-07-12 04:54:42 +0200 |
commit | 5c5cf2f8e000d1bf4fc12ff20351aa60367cb563 (patch) | |
tree | 2b233263cff7c001506f660373e2364c8e702637 /src/core/hle/kernel/vm_manager.cpp | |
parent | Memory: Fix unmapping of pages (diff) | |
download | yuzu-5c5cf2f8e000d1bf4fc12ff20351aa60367cb563.tar yuzu-5c5cf2f8e000d1bf4fc12ff20351aa60367cb563.tar.gz yuzu-5c5cf2f8e000d1bf4fc12ff20351aa60367cb563.tar.bz2 yuzu-5c5cf2f8e000d1bf4fc12ff20351aa60367cb563.tar.lz yuzu-5c5cf2f8e000d1bf4fc12ff20351aa60367cb563.tar.xz yuzu-5c5cf2f8e000d1bf4fc12ff20351aa60367cb563.tar.zst yuzu-5c5cf2f8e000d1bf4fc12ff20351aa60367cb563.zip |
Diffstat (limited to 'src/core/hle/kernel/vm_manager.cpp')
-rw-r--r-- | src/core/hle/kernel/vm_manager.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/core/hle/kernel/vm_manager.cpp b/src/core/hle/kernel/vm_manager.cpp index ec437cd61..205cc7b53 100644 --- a/src/core/hle/kernel/vm_manager.cpp +++ b/src/core/hle/kernel/vm_manager.cpp @@ -35,6 +35,10 @@ VMManager::VMManager() { Reset(); } +VMManager::~VMManager() { + Reset(); +} + void VMManager::Reset() { vma_map.clear(); @@ -130,6 +134,16 @@ void VMManager::Reprotect(VMAHandle vma_handle, VMAPermission new_perms) { MergeAdjacent(iter); } +void VMManager::LogLayout() const { + for (const auto& p : vma_map) { + const VirtualMemoryArea& vma = p.second; + LOG_DEBUG(Kernel, "%08X - %08X size: %8X %c%c%c", vma.base, vma.base + vma.size, vma.size, + (u8)vma.permissions & (u8)VMAPermission::Read ? 'R' : '-', + (u8)vma.permissions & (u8)VMAPermission::Write ? 'W' : '-', + (u8)vma.permissions & (u8)VMAPermission::Execute ? 'X' : '-'); + } +} + VMManager::VMAIter VMManager::StripIterConstness(const VMAHandle & iter) { // This uses a neat C++ trick to convert a const_iterator to a regular iterator, given // non-const access to its container. |