RFR: 8319048: Monitor deflation unlink phase prolongs time to safepoint [v6]
Aleksey Shipilev
shade at openjdk.org
Tue Nov 14 13:53:10 UTC 2023
> See the symptoms, reproducer, and analysis in the bug.
>
> This PR fixes the issue by providing a smaller batch size for unlinking. The unlinking batch size basically defines two things: a) how often do we check for safepoint (`ObjectSynchronizer::chk_for_block_req` in the method below); and b) how much overhead we have on mutating the monitor lists. If we unlink monitors one by one, then in a worst case, we would do a CAS on `head` for every monitor, which is bound to be expensive.
>
> There is a major problem in current code: we only check for safepoint every 1M monitors, which might take a while. Even if we spend 1ns per monitor, that's already +1ms in TTSP. There is a secondary problem that comes with searching for new `prev` if monitor insertion happened while we were preparing the batch for unlinking.
>
> The experiments with the reproducer from the bug shows that the threshold of 500 works well: it mitigates TTSP latencies nearly completely, while still providing the large enough batch size to absorb list mutation overheads. See how bad outliers are in baseline, and how outliers get lower with lower batch, and almost completely disappear at 500. I believe the difference between baseline and `MUB=1M` is short-cut-ting the search for new `prev`.
>
> 
>
> Additional testing:
> - [x] Linux AArch64 server fastdebug, `tier1 tier2 tier3`
> - [x] Ad-hoc performance tests, see above
Aleksey Shipilev has updated the pull request with a new target base due to a merge or a rebase. The incremental webrev excludes the unrelated changes brought in by the merge/rebase. The pull request contains 10 additional commits since the last revision:
- Merge branch 'master' into JDK-8319048-monitor-deflation-unlink
- Move unlink_batch init to proper place
- Add invariant checking
- Merge branch 'master' into JDK-8319048-monitor-deflation-unlink
- Fix test after recent test infra renames
- Merge branch 'master' into JDK-8319048-monitor-deflation-unlink
- Batch 500
- Pre-final touchups
- Option range and tests
- Fix
-------------
Changes:
- all: https://git.openjdk.org/jdk/pull/16412/files
- new: https://git.openjdk.org/jdk/pull/16412/files/a6a7c8df..e18a2477
Webrevs:
- full: https://webrevs.openjdk.org/?repo=jdk&pr=16412&range=05
- incr: https://webrevs.openjdk.org/?repo=jdk&pr=16412&range=04-05
Stats: 602795 lines in 743 files changed: 78190 ins; 465307 del; 59298 mod
Patch: https://git.openjdk.org/jdk/pull/16412.diff
Fetch: git fetch https://git.openjdk.org/jdk.git pull/16412/head:pull/16412
PR: https://git.openjdk.org/jdk/pull/16412
More information about the hotspot-runtime-dev
mailing list