RFR: 8319795: Static huge pages are not used for CodeCache
Evgeny Astigeevich
eastigeevich at openjdk.org
Thu Nov 9 15:28:20 UTC 2023
This is a fix of a regression introduced by [JDK-8261894](https://bugs.openjdk.org/browse/JDK-8261894).
After JDK-8261894, `os::can_execute_large_page_memory()` returns `true` only if `UseTransparentHugePages` is true. As CodeCache uses `os::can_execute_large_page_memory()` when it detects a page size. CodeCache cannot use static huge pages.
Before JDK-8261894, `os::can_execute_large_page_memory()` returned `true` when either `UseTransparentHugePages` or `UseHugeTLBFS` was true.
After JDK-8261894, `XX:+UseLargePages XX:-UseTransparentHugePages` means to use static huge pages: aka `UseHugeTLBFS` is `true`. If `UseLargePages` is not set to `true` via the option, it will be set to `true` if `UseTransparentHugePages` is `true`.
`os::can_execute_large_page_memory()` is modified to return `UseLargePages`. A regression gtest is added.
Tested fastdebug and release builds:
- [x] tier1
- [x] gtest
- [x] test/hotspot/jtreg/gtest/LargePageGtests.java
-------------
Commit messages:
- 8319795: Static huge pages are not used for CodeCache
Changes: https://git.openjdk.org/jdk/pull/16582/files
Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=16582&range=00
Issue: https://bugs.openjdk.org/browse/JDK-8319795
Stats: 9 lines in 2 files changed: 8 ins; 0 del; 1 mod
Patch: https://git.openjdk.org/jdk/pull/16582.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/16582/head:pull/16582
PR: https://git.openjdk.org/jdk/pull/16582
More information about the hotspot-runtime-dev
mailing list