RFR (S) 8074355: make MutexLocker smarter about non-JavaThreads

coleen.phillimore at oracle.com coleen.phillimore at oracle.com
Mon Apr 29 11:44:59 UTC 2019



On 4/27/19 4:49 PM, Per Liden wrote:
> Hi Coleen,
>
> Not a review, just a comment on your comment:
>
> +  // There are a couple of existing locks that will sometimes have a 
> safepoint check and
> +  // sometimes not when acquired by a JavaThread, but these locks are 
> set up carefully
> +  // to avoid deadlocks. TODO: Fix these locks and remove 
> _safepoint_check_sometimes.
>
> Once _safepoint_check_sometimes is gone, we can simplify things even 
> further and remove the {lock,wait}_without_safepoint_check() 
> functions, and ditch the Mutex::SafepointCheckFlag argument in the 
> constructors for MutexLocker and MonitorLocker. Everyone can just call 
> lock()/wait(), and the lock itself knows what to do. That would be great!

Yes, I happen to agree with you.
Thanks!
Coleen
>
> cheers,
> Per
>
> On 04/26/2019 06:10 PM, coleen.phillimore at oracle.com wrote:
>> Summary: Use safepoint_check_always/safepoint_check_never instead of 
>> safepoint_check_sometimes for locks that are taken by JavaThreads and 
>> non-JavaThreads
>>
>> This patch moves all but 3 of the locks to not be 
>> safepoint_check_sometimes.  We have plans to fix these three. Also, 
>> this patch allows for being explicit about safepoint checking or not 
>> when the thread is a non-java thread, which is something that Kim 
>> objected to in my first patch.
>>
>> Tested with mach5 tier1-3.
>>
>> open webrev at 
>> http://cr.openjdk.java.net/~coleenp/2019/8074355.03/webrev
>> bug link https://bugs.openjdk.java.net/browse/JDK-8074355
>>
>> Thanks,
>> Coleen



More information about the hotspot-dev mailing list