RFR: 8354145: G1GC: keep the CompressedOops same as before when not setting HeapRegionSize explicitly

Thomas Schatzl tschatzl at openjdk.org
Wed Apr 9 11:26:24 UTC 2025


On Wed, 9 Apr 2025 10:37:24 GMT, Tongbao Zhang <duke at openjdk.org> wrote:

> After [JDK-8275056](https://bugs.openjdk.org/browse/JDK-8275056), The max heap region size became 512M, and the calculation of CompressedOops based on the max_heap_size - max_heap_region_size.
> So before this patch, the CompressedOops will turn on below 32G - 32m, After this patch is 32G -512m.
> 
> When our Apps migrating from JDK11 to JDK21, the heap size parameters(Xmx32736m) will turn off the CompressedOops.
> 
> Since the current max ergonomics size is still 32m, We hoped that the original behavior will not be changed if HeapRegionSize is not explicitly set.
> 
> before this patch:
> 
> ./build/linux-x86_64-server-release/images/jdk/bin/java -Xmx32736m -XX:+PrintFlagsFinal -version | grep CompressedOops
>      bool UseCompressedOops                        = false                          {product lp64_product} {default}
> openjdk version "25-internal" 2025-09-16
> OpenJDK Runtime Environment (build 25-internal-adhoc.root.jdk)
> OpenJDK 64-Bit Server VM (build 25-internal-adhoc.root.jdk, mixed mode, sharing)
> 
> 
> after this patch:
> 
> ./build/linux-x86_64-server-release/images/jdk/bin/java -Xmx32736m -XX:+PrintFlagsFinal -version | grep CompressedOops
>      bool UseCompressedOops                        = true                           {product lp64_product} {ergonomic}
> openjdk version "25-internal" 2025-09-16
> OpenJDK Runtime Environment (build 25-internal-adhoc.root.jdk)
> OpenJDK 64-Bit Server VM (build 25-internal-adhoc.root.jdk, mixed mode, sharing)

Would it be possible to add a regression test that checks the value of the `UseCompressedOops` flag after running a VM with these settings?

-------------

PR Review: https://git.openjdk.org/jdk/pull/24541#pullrequestreview-2753132517


More information about the hotspot-gc-dev mailing list