RFR: 8253064: monitor list simplifications and getting rid of TSM [v4]

Coleen Phillimore coleenp at openjdk.java.net
Tue Nov 10 14:18:00 UTC 2020


On Sat, 7 Nov 2020 17:17:01 GMT, Daniel D. Daugherty <dcubed at openjdk.org> wrote:

>> src/hotspot/share/runtime/synchronizer.cpp line 136:
>> 
>>> 134: 
>>> 135:       // Honor block request.
>>> 136:       ThreadBlockInVM tbivm(self->as_Java_thread());
>> 
>> ThreadBlockInVM is generally used to wrap blocking code, not to cause the current thread to block (which it will do as a side-effect if a safepoint/handshake is requested). Surely this should just be call to `process_if_requested` (or the new `process_if_requested_with_exit_check`)?
>
> This kind of use of ThreadBlockInVM predates this changeset so while
> the location is new, then code style is old, very old... I'll hold off changing
> this for now.

I'd rather see ThreadBlockInVM as the convention of allowing the thread to block if a safepoint is requested.  The calls like process_if_requested are becoming alphabet soup and keep changing, so having TBIVM is better in my opinion.
That said, this is a strange usage.  This code appears three times.  It should be a function like allow_safepoint_block(LogStream* ls, timer), with some comment above.  Then it's clear that it's checking for a safepoint in a loop that could take a long time and the logging is ancillary.

-------------

PR: https://git.openjdk.java.net/jdk/pull/642


More information about the hotspot-dev mailing list