RFR: JDK-8220671: Initialization race for non-JavaThread PtrQueues
Per Liden
per.liden at oracle.com
Tue Mar 26 11:24:14 UTC 2019
Hi,
On 3/26/19 11:43 AM, Roman Kennke wrote:
>>> This thread went a bit off. May I propose this for review:
>>>
>>> http://cr.openjdk.java.net/~rkennke/JDK-8220671/webrev.07/
>>>
>>> it passes tier1 tests locally, and I submitted it to jdk/submit but
>>> that seems to have other hiccups.
>>>
>>> WDYT?
>>
>> I'm still not convinced the activation predicates for the STS joiners
>> are correct here. And I'm not what the right predicate might be or if
>> it even exists.
>>
>> Also, STS is presently a "GC" thing, and this would insinuate it into
>> non-GC code, and affect non-GC threads (such as the WatcherThread and
>> the JfrThreadSampler).
>>
>> I still prefer using the NonJavaThreadsList_lock in NJT::pre/post_run
>> and around the the relevant state changes, such as setting the SATB
>> qset's _all_active member.
>
> Ok, let's go with your patch:
>
> http://cr.openjdk.java.net/~kbarrett/8220671/use_njtlock.00/
Looks good to me. I also think this is the better approach, as I would
also feel uncomfortable with exposing the STS outside of GC.
>
> I've tested it against my stress test and Shenandoah test suite, and all
> seems fine.
>
> Is the extra locking around assignment of global state needed? I think
> the locking in threads_do() is sufficient?
The locking over "_all_active = active;" looks sane to me. This patch
has no locking in threads_do(), or am I missing something?
cheers,
Per
>
> Roman
More information about the hotspot-gc-dev
mailing list