RFR: 8286957: Held monitor count [v2]
Johan Sjölén
duke at openjdk.org
Tue Jun 28 12:06:45 UTC 2022
On Thu, 23 Jun 2022 09:42:24 GMT, Robbin Ehn <rehn at openjdk.org> wrote:
>> The current implementation do not count all monitor enter, counts high up in abstraction and causes a performance regression on aarch64 with some benchmarks due to C2 changes.
>>
>> This change makes the counting exact by pushing the counting down in the abstraction.
>> The additional JNI counter is strictly not needed, but enables us to figure out if we have monitors "on stack".
>>
>> An uncontended lock plus unlock is 1 ns (21.5 -> 22.5) slower in C2 compiled code on x64 with the additional increment and decrement.
>>
>> Fixed aarch64, x64, x86 and zero.
>>
>> Passes t1-8
>
> Robbin Ehn has updated the pull request with a new target base due to a merge or a rebase. The pull request now contains two commits:
>
> - Merge branch 'master' into held-mon-count
> - 8286957 - PR Baseline
src/hotspot/share/interpreter/zero/bytecodeInterpreter.cpp line 629:
> 627: mon->lock()->set_displaced_header(displaced);
> 628: bool call_vm = UseHeavyMonitors;
> 629: bool inc_mon_count = true;
Should be inc_mon**t**_count? We're consistent with `dec_mont_count`.
-------------
PR: https://git.openjdk.org/jdk/pull/8945
More information about the hotspot-dev
mailing list