diff options
| author | bunnei <bunneidev@gmail.com> | 2018-10-19 22:58:57 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-10-19 22:58:57 -0400 |
| commit | 60317e630619ff5942fcb4b16cf1b3a0b2791cc2 (patch) | |
| tree | 5fb63e418bc7af69c9d06f7fc4ae3980e7d60aee /src/core/hle/kernel/vm_manager.cpp | |
| parent | 48495695655210c91a36a4e847aaa73278949991 (diff) | |
| parent | 33830aa65ac58a03a91de9ac4fc8d91fe28f6d4e (diff) | |
Merge pull request #1520 from lioncash/san
svc: Add missing sanitizing checks for MapSharedMemory/UnmapSharedMemory
Diffstat (limited to 'src/core/hle/kernel/vm_manager.cpp')
| -rw-r--r-- | src/core/hle/kernel/vm_manager.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/core/hle/kernel/vm_manager.cpp b/src/core/hle/kernel/vm_manager.cpp index 1e28ccbda..e1a34eef1 100644 --- a/src/core/hle/kernel/vm_manager.cpp +++ b/src/core/hle/kernel/vm_manager.cpp @@ -507,6 +507,26 @@ u64 VMManager::GetASLRRegionSize() const { return aslr_region_end - aslr_region_base; } +bool VMManager::IsWithinASLRRegion(VAddr begin, u64 size) const { + const VAddr range_end = begin + size; + const VAddr aslr_start = GetASLRRegionBaseAddress(); + const VAddr aslr_end = GetASLRRegionEndAddress(); + + if (aslr_start > begin || begin > range_end || range_end - 1 > aslr_end - 1) { + return false; + } + + if (range_end > heap_region_base && heap_region_end > begin) { + return false; + } + + if (range_end > map_region_base && map_region_end > begin) { + return false; + } + + return true; +} + VAddr VMManager::GetCodeRegionBaseAddress() const { return code_region_base; } |
