From 6977cb24f54bcff5546d5eea8f09c52bf5524737 Mon Sep 17 00:00:00 2001 From: plutooo <plutooo@users.noreply.github.com> Date: Tue, 23 Oct 2018 04:07:01 +0200 Subject: [PATCH] virtmem: Fix minor regression We need to fetch alias region to make sure virtmemReserve() avoids returning addresses inside of it --- nx/source/kernel/virtmem.c | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/nx/source/kernel/virtmem.c b/nx/source/kernel/virtmem.c index 7c08fcab..5dc7dd15 100644 --- a/nx/source/kernel/virtmem.c +++ b/nx/source/kernel/virtmem.c @@ -14,6 +14,7 @@ typedef struct { enum { REGION_STACK=0, REGION_HEAP=1, + REGION_LEGACY_ALIAS=2, REGION_MAX }; @@ -82,6 +83,8 @@ void virtmemSetup(void) { if (R_FAILED(_GetRegionFromInfo(&g_Region[REGION_HEAP], 4, 5))) { fatalSimple(MAKERESULT(Module_Libnx, LibnxError_BadGetInfo_Heap)); } + + _GetRegionFromInfo(&g_Region[REGION_LEGACY_ALIAS], 2, 3); } void* virtmemReserve(size_t size) { @@ -128,11 +131,7 @@ void* virtmemReserve(size_t size) { { u64 end = addr + size - 1; - if (_InRegion(&g_Region[i], addr)) { - break; - } - - if (_InRegion(&g_Region[i], end)) { + if (_InRegion(&g_Region[i], addr) || _InRegion(&g_Region[i], end)) { break; } }