diff --git a/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp b/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp --- a/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp +++ b/compiler-rt/lib/sanitizer_common/sanitizer_mac.cpp @@ -1185,25 +1185,40 @@ uptr GetMaxUserVirtualAddress() { static uptr max_vm = GetTaskInfoMaxAddress(); if (max_vm != 0) + CHECK_LE(max_vm, SANITIZER_MMAP_RANGE_SIZE); return max_vm - 1; // xnu cannot provide vm address limit # if SANITIZER_WORDSIZE == 32 - return 0xffe00000 - 1; + static constexpr uptr fallback_max_vm = 0xffe00000 - 1; # else - return 0x200000000 - 1; + static constexpr uptr fallback_max_vm = 0x200000000 - 1; # endif + static_assert( + fallback_max_vm <= SANITIZER_MMAP_RANGE_SIZE, + "Max virtual address must be less than mmap range size." + ); + return fallback_max_vm; } #else // !SANITIZER_IOS uptr GetMaxUserVirtualAddress() { # if SANITIZER_WORDSIZE == 64 - return (1ULL << 47) - 1; // 0x00007fffffffffffUL; + static constexpr uptr max_vm = (1ULL << 47) - 1; // 0x00007fffffffffffUL; + static_assert( + max_vm <= SANITIZER_MMAP_RANGE_SIZE, + "Max virtual address must be less than mmap range size for 64bit." + ); # else // SANITIZER_WORDSIZE == 32 static_assert(SANITIZER_WORDSIZE == 32, "Wrong wordsize"); - return (1ULL << 32) - 1; // 0xffffffff; + static constexpr uptr max_vm = (1ULL << 32) - 1; // 0xffffffff; + static_assert( + max_vm <= SANITIZER_MMAP_RANGE_SIZE, + "Max virtual address must be less than mmap range size for 32bit." + ); # endif + return max_vm; } #endif