RFR: 8338383: Implement JEP 491: Synchronize Virtual Threads without Pinning [v12]
Patricio Chilano Mateo
pchilanomate at openjdk.org
Mon Oct 28 20:58:34 UTC 2024
On Mon, 28 Oct 2024 07:55:02 GMT, Richard Reingruber <rrich at openjdk.org> wrote:
>> Patricio Chilano Mateo has updated the pull request incrementally with two additional commits since the last revision:
>>
>> - Restore use of atPointA in test StopThreadTest.java
>> - remove interruptible check from conditional in Object::wait
>
> src/hotspot/cpu/x86/stubGenerator_x86_64.hpp line 602:
>
>> 600:
>> 601: address generate_cont_preempt_stub();
>> 602: address generate_cont_resume_monitor_operation();
>
> The declaration of `generate_cont_resume_monitor_operation` seems to be unused.
Removed.
> src/hotspot/share/runtime/synchronizer.cpp line 1559:
>
>> 1557: // and set the stack locker field in the monitor.
>> 1558: m->set_stack_locker(mark.locker());
>> 1559: m->set_anonymous_owner(); // second
>
> Is it important that this is done after the stack locker is set? I think I saw another comment that indicated that order is important but I cannot find it now.
No, I removed that comment. Both will be visible once we publish the monitor with `object->release_set_mark(markWord::encode(m))`. There was a "first" comment in method ObjectMonitor::set_owner_from_BasicLock() which I removed in [1]. Clearing _stack_locker now happens here in the `mark.has_monitor()` case. The order there doesn't matter either. If some other thread sees that the owner is anonymous and tries to check if he is the owner the comparison will always fail, regardless of reading the BasicLock* value or a nullptr value.
[1] https://github.com/pchilano/jdk/commit/13353fdd6ad3c509b82b1fb0b9a3d05284b592b7#diff-4707eeadeff2ce30c09c4ce8c5a987abf58ac06f7bf78e7717cffa9c36cc392fL195
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/21565#discussion_r1819746524
PR Review Comment: https://git.openjdk.org/jdk/pull/21565#discussion_r1819746309
More information about the nio-dev
mailing list