RFR: 8352414: JFR: JavaMonitorDeflateEvent crashes when deflated monitor object is dead [v2]
David Holmes
dholmes at openjdk.org
Fri Mar 21 12:08:11 UTC 2025
On Fri, 21 Mar 2025 08:10:27 GMT, Aleksey Shipilev <shade at openjdk.org> wrote:
>> src/hotspot/share/runtime/objectMonitor.cpp line 744:
>>
>>> 742: // Emit the event anyway, but without details.
>>> 743: event->set_monitorClass(nullptr);
>>> 744: event->set_address(0);
>>
>> Shouldn't this be the default state of the event?
>
> I looked at it before doing the patch, and I don't think the event-specific fields are default-initialized. In fact, if you skip these, JFR code would assert:
>
>
> # A fatal error has been detected by the Java Runtime Environment:
> #
> # Internal Error (/home/shade/trunks/jdk/build/linux-x86_64-server-fastdebug/hotspot/variant-server/gensrc/jfrfiles/jfrEventClasses.hpp:1181), pid=279828, tid=279849
> # assert(verify_field_bit(0)) failed: Attempting to write an uninitialized event field: _monitorClass
That seems like a bug in the event constructor to me.
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/24121#discussion_r2007453034
More information about the hotspot-dev
mailing list