RFR: 8253064: monitor list simplifications and getting rid of TSM [v5]
Robbin Ehn
rehn at openjdk.java.net
Tue Nov 10 20:37:01 UTC 2020
On Tue, 10 Nov 2020 17:39:25 GMT, Daniel D. Daugherty <dcubed at openjdk.org> wrote:
>> Changes from @fisk and @dcubed-ojdk to:
>>
>> - simplify ObjectMonitor list management
>> - get rid of Type-Stable Memory (TSM)
>>
>> This change has been tested with Mach5 Tier[1-3],4,5,6,7,8; no new regressions.
>> Aurora Perf runs have also been done (DaCapo-h2, Quick Startup/Footprint,
>> SPECjbb2015-Tuned-G1, SPECjbb2015-Tuned-ParGC, Volano)
>> - a few minor regressions (<= -0.24%)
>> - Volano is 6.8% better
>>
>> Eric C. has also done promotion perf runs on these bits and says "the results look fine".
>
> Daniel D. Daugherty has updated the pull request incrementally with one additional commit since the last revision:
>
> coleenp CR - refactor common ThreadBlockInVM code block into ObjectSynchronizer::chk_for_block_req().
Hi, thanks for fixing.
I had some comments nothing so approving.
src/hotspot/share/runtime/monitorDeflationThread.cpp line 92:
> 90: // We wait for GuaranteedSafepointInterval so that
> 91: // is_async_deflation_needed() is checked at the same interval.
> 92: ml.wait(GuaranteedSafepointInterval);
I don't like that we add a new global monitor just for the whitebox API.
Without WB poking this could just a plain sleep.
If we must have this new global monitor there seems be no reason for this to be no safepoint ?
So ThreadBlockInVM would not be needed if we did safepoint checks instead?
I would either skip WB notification and run the test with a very low GuaranteedSafepointInterval and just set flag and wait a second.
Or if this is really important use a local semaphore and skip the boolean, each increase on sema would result in a deflation pass.
src/hotspot/share/runtime/synchronizer.cpp line 1419:
> 1417: ", count=" SIZE_FORMAT ", max=" SIZE_FORMAT, op_name,
> 1418: in_use_list_ceiling(), _in_use_list.count(), _in_use_list.max());
> 1419: timer_p->start();
ThreadBlockInVM have a miss-feature: it safepoint polls on front-edge and back-edge.
It should only have that poll on backedge, once that is fixed, this will do the wrong thing.
Also you may safepoint on both front-edge and back-edge now, so the timer would show the wrong thing then.
So to get the timer correct you should use:
SafepointMechanism::process_if_requested(thread);
src/hotspot/share/runtime/synchronizer.cpp line 1532:
> 1530: // A JavaThread must check for a safepoint/handshake and honor it.
> 1531: chk_for_block_req(self->as_Java_thread(), "deletion", "deleted_count",
> 1532: deleted_count, ls, &timer);
If you release oopStorage when deflating you can do this entire loop while blocked instead, which will be faster.
src/hotspot/share/runtime/objectMonitor.hpp line 148:
> 146: DEFINE_PAD_MINUS_SIZE(0, OM_CACHE_LINE_SIZE, sizeof(volatile markWord) +
> 147: sizeof(WeakHandle));
> 148: // Used by async deflation as a marker in the _owner field:
I have test with and without padding, I saw no difference.
-------------
Marked as reviewed by rehn (Reviewer).
PR: https://git.openjdk.java.net/jdk/pull/642
More information about the hotspot-dev
mailing list