summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2018-01-20 17:37:55 -0500
committerGitHub <noreply@github.com>2018-01-20 17:37:55 -0500
commit6cccbf0eb365c9918e09a4965d46e9252c8ec6c4 (patch)
tree4d0cb1088d81c2115c2ad5ed53887681c0364b91 /src
parentff883cc56382425d4c4f572ff659ec7df6fc2cec (diff)
parentde7aa3106adcdc14ed5e09c653133115a83e512a (diff)
Merge pull request #120 from Rozelette/master
memory: Return false for large VAddr in IsValidVirtualAddress
Diffstat (limited to 'src')
-rw-r--r--src/core/memory.cpp3
1 files changed, 3 insertions, 0 deletions
diff --git a/src/core/memory.cpp b/src/core/memory.cpp
index 74a598852..a3d2d4951 100644
--- a/src/core/memory.cpp
+++ b/src/core/memory.cpp
@@ -219,6 +219,9 @@ void Write(const VAddr vaddr, const T data) {
bool IsValidVirtualAddress(const Kernel::Process& process, const VAddr vaddr) {
auto& page_table = process.vm_manager.page_table;
+ if ((vaddr >> PAGE_BITS) >= PAGE_TABLE_NUM_ENTRIES)
+ return false;
+
const u8* page_pointer = page_table.pointers[vaddr >> PAGE_BITS];
if (page_pointer)
return true;