RFR: JDK-8292072: NMT: repurpose Tracking overhead counter as global malloc counter
Thomas Stuefe
stuefe at openjdk.org
Thu Aug 11 05:50:06 UTC 2022
I need a fast counter for global mallocs for [JDK-8291878](https://bugs.openjdk.org/browse/JDK-8291878). NMT does not keep a global counter, just category-specific counters. At the moment, `MallocMemorySummary::total()` iterates all these counters and adds them up, which is quite costly.
This patch makes `MallocMemorySummary::total()` fast by introducing a global malloc counter. However, we don't add a new counter, we just repurpose the tracking overhead counter.
The tracking overhead counter gets updated on every malloc and counts number and size of all malloc headers. But malloc headers have always the same size. This patch uses the former overhead counter to count number and size of all mallocs. So now we have a global malloc counter, at no additional cost, and the overhead gets calculated from the number of total mallocs * constant header size.
-------------
Commit messages:
- JDK-8292072-NMT-repurpose-Tracking-overhead-counter-as-global-malloc-counter
Changes: https://git.openjdk.org/jdk/pull/9804/files
Webrev: https://webrevs.openjdk.org/?repo=jdk&pr=9804&range=00
Issue: https://bugs.openjdk.org/browse/JDK-8292072
Stats: 51 lines in 4 files changed: 9 ins; 30 del; 12 mod
Patch: https://git.openjdk.org/jdk/pull/9804.diff
Fetch: git fetch https://git.openjdk.org/jdk pull/9804/head:pull/9804
PR: https://git.openjdk.org/jdk/pull/9804
More information about the hotspot-runtime-dev
mailing list