RFR: JDK-8294266: Add a way to pre-touch java thread stacks
Aleksey Shipilev
shade at openjdk.org
Fri Sep 23 14:10:57 UTC 2022
On Fri, 23 Sep 2022 09:39:41 GMT, Thomas Stuefe <stuefe at openjdk.org> wrote:
> When doing performance- and memory analysis, `AlwaysPreTouch` option is very handy for reducing noise. It would be good to have a similar option for pre-touching thread stacks. In addition to reducing noise, it can serve as worst-case test for thread costs, as well as a test for NMT regressions.
>
> Patch adds a new diagnostic switch, `AlwaysPreTouchStacks`, as a companion switch to `AlwaysPreTouch`. Touching is super-simple using `alloca()`. Also, regression test.
>
> Examples:
>
> NMT, thread stacks, 10000 Threads, default:
>
>
> - Thread (reserved=10332400KB, committed=331828KB)
> (thread #10021)
> (stack: reserved=10301560KB, committed=300988KB)
> (malloc=19101KB #60755)
> (arena=11739KB #20037)
>
>
> NMT, thread stacks, 10000 Threads, +AlwaysPreTouchStacks:
>
>
> - Thread (reserved=10332400KB, committed=10284360KB)
> (thread #10021)
> (stack: reserved=10301560KB, committed=10253520KB)
> (malloc=19101KB #60755)
> (arena=11739KB #20037)
Drive-by comment: there is `os::pretouch_memory(void* start, void* end, size_t page_size)` ;)
-------------
PR: https://git.openjdk.org/jdk/pull/10403
More information about the hotspot-dev
mailing list