From 8bb6c0ddf0faed9f77611f3c5e48571bf03a24c5 Mon Sep 17 00:00:00 2001 From: IndecisiveTurtle <47210458+raphaelthegreat@users.noreply.github.com> Date: Wed, 24 Jul 2024 22:59:56 +0300 Subject: [PATCH 1/2] address_space: Fix windows placeholder mapping --- src/core/address_space.cpp | 8 +++----- src/core/address_space.h | 2 +- 2 files changed, 4 insertions(+), 6 deletions(-) diff --git a/src/core/address_space.cpp b/src/core/address_space.cpp index 1bc803a1..42c16c60 100644 --- a/src/core/address_space.cpp +++ b/src/core/address_space.cpp @@ -59,10 +59,10 @@ struct AddressSpace::Impl { static constexpr size_t MaxReductions = 10; size_t reduction = 0; + size_t virtual_size = SystemManagedSize + SystemReservedSize + UserSize; for (u32 i = 0; i < MaxReductions; i++) { - req.LowestStartingAddress = reinterpret_cast(SYSTEM_MANAGED_MIN + reduction); virtual_base = static_cast(VirtualAlloc2( - process, NULL, SystemManagedSize + SystemReservedSize + UserSize - reduction, + process, NULL, virtual_size - reduction, MEM_RESERVE | MEM_RESERVE_PLACEHOLDER, PAGE_NOACCESS, ¶m, 1)); if (virtual_base) { break; @@ -92,9 +92,7 @@ struct AddressSpace::Impl { const uintptr_t system_managed_addr = reinterpret_cast(system_managed_base); const uintptr_t system_reserved_addr = reinterpret_cast(system_reserved_base); const uintptr_t user_addr = reinterpret_cast(user_base); - placeholders.insert({system_managed_addr, system_managed_addr + system_managed_size}); - placeholders.insert({system_reserved_addr, system_reserved_addr + system_reserved_size}); - placeholders.insert({user_addr, user_addr + user_size}); + placeholders.insert({system_managed_addr, virtual_size - reduction}); // Allocate backing file that represents the total physical memory. backing_handle = diff --git a/src/core/address_space.h b/src/core/address_space.h index c181b362..e2515902 100644 --- a/src/core/address_space.h +++ b/src/core/address_space.h @@ -22,7 +22,7 @@ constexpr VAddr CODE_BASE_OFFSET = 0x100000000ULL; constexpr VAddr SYSTEM_MANAGED_MIN = 0x00000400000ULL; constexpr VAddr SYSTEM_MANAGED_MAX = 0x07FFFFBFFFULL; -constexpr VAddr SYSTEM_RESERVED_MIN = 0x800000000ULL; +constexpr VAddr SYSTEM_RESERVED_MIN = 0x07FFFFC000ULL; #ifdef __APPLE__ // Can only comfortably reserve the first 0x7C0000000 of system reserved space. constexpr VAddr SYSTEM_RESERVED_MAX = 0xFBFFFFFFFULL; From 8fa6a8c036a89fae77a580a0338a45394d200566 Mon Sep 17 00:00:00 2001 From: georgemoralis Date: Thu, 25 Jul 2024 11:59:39 +0300 Subject: [PATCH 2/2] clang fix --- src/core/address_space.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/core/address_space.cpp b/src/core/address_space.cpp index 42c16c60..c3e0d77a 100644 --- a/src/core/address_space.cpp +++ b/src/core/address_space.cpp @@ -61,9 +61,9 @@ struct AddressSpace::Impl { size_t reduction = 0; size_t virtual_size = SystemManagedSize + SystemReservedSize + UserSize; for (u32 i = 0; i < MaxReductions; i++) { - virtual_base = static_cast(VirtualAlloc2( - process, NULL, virtual_size - reduction, - MEM_RESERVE | MEM_RESERVE_PLACEHOLDER, PAGE_NOACCESS, ¶m, 1)); + virtual_base = static_cast(VirtualAlloc2(process, NULL, virtual_size - reduction, + MEM_RESERVE | MEM_RESERVE_PLACEHOLDER, + PAGE_NOACCESS, ¶m, 1)); if (virtual_base) { break; }