From ac2b1ae5e2c8a9854bce4f483109fb89492e107a Mon Sep 17 00:00:00 2001 From: Stefan Karlsson Date: Wed, 2 Sep 2020 11:13:09 +0200 Subject: [PATCH] 8252513: ZGC: Contiguous memory reservation probing is broken for TB heap sizes Reviewed-by: eosterlund, pliden --- src/hotspot/share/gc/z/zVirtualMemory.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/hotspot/share/gc/z/zVirtualMemory.cpp b/src/hotspot/share/gc/z/zVirtualMemory.cpp index d4598a478d1..61660c2da0c 100644 --- a/src/hotspot/share/gc/z/zVirtualMemory.cpp +++ b/src/hotspot/share/gc/z/zVirtualMemory.cpp @@ -101,10 +101,10 @@ size_t ZVirtualMemoryManager::reserve_discontiguous(size_t size) { bool ZVirtualMemoryManager::reserve_contiguous(size_t size) { // Allow at most 8192 attempts spread evenly across [0, ZAddressOffsetMax) - const size_t end = ZAddressOffsetMax - size; - const size_t increment = align_up(end / 8192, ZGranuleSize); + const size_t unused = ZAddressOffsetMax - size; + const size_t increment = MAX2(align_up(unused / 8192, ZGranuleSize), ZGranuleSize); - for (size_t start = 0; start <= end; start += increment) { + for (size_t start = 0; start + size <= ZAddressOffsetMax; start += increment) { if (reserve_contiguous_platform(start, size)) { // Make the address range free _manager.free(start, size);