RFR (L, tedious) 8222811: Consolidate MutexLockerEx and MutexLocker
Robbin Ehn
robbin.ehn at oracle.com
Wed Apr 24 11:37:46 UTC 2019
>> MonitorLocker ml(&_monitor, Monitor::_no_safepoint_check_flag);
>> ...
>> ml.wait();
>>
>> Where wait() does the right thing, i.e. use the flag we passed into the
>> constructor. Since all of MonitorLocker will be inlined, a flag check in
>> wait() would be constant folded, so there's no overhead to worry about here.
>>
>> Can we please have this?
I totally agree, having to supply it twice is just error prone.
If it always is constant folded, e.g. known in compile time, it could be a
template parameter instead:
MonitorLocker<SafepointChecked> ml(&_monitor);
Also if we remove the 3 sometimes lock and only have 'always' and 'never' locks,
having the two version as different types would give you compile errors instead
of runtime asserts.
Thanks, Robbin
>
> So I have a follow on patch wrt MonitorLocker. Actually I've removed it. Erik
> thought having a NULL monitor wait was crazy, even though we have a case of that
> in the GC. The code is split whether it uses the MonitorLocker local variable
> vs. the actual lock.
>
> The only code that consistently uses the MonitorLocker local like this is ZGC,
> so I was going to discuss the next change with you first anyway.
>
> I see your point about not having to say whether you're safepoint checking twice
> though. People I've been talking to on the project are of two minds. One set
> wants it always explicit, the other implicit. I personally want consistency
> over all else, which is why I added wait_without_safepoint_check to MonitorLocker.
>
> I could change this with this patch. It's easy enough to do, especially if you
> see value in MonitorLocker, which was going to be my next discussion with you.
>
> Thanks,
> Coleen
>
>
>>
>> cheers,
>> Per
>>
>> On 4/23/19 5:06 PM, coleen.phillimore at oracle.com wrote:
>>> Summary: Make MutexLocker be MutexLockerEx implementation, remove
>>> MutexLockerEx calls. Also added wait_without_safepoint_check().
>>>
>>> Also made safepoint_check_flag an enum, renamed MonitorLockerEx to
>>> MonitorLocker, removed MutexUnlockerEx, and fixed formatting where affected
>>> by this change.
>>>
>>> There's a MutexLocker constructor with a Thread parameter that would actually
>>> be more performant if the thread is passed from the current context rather
>>> than calling Thread::current() in Monitor::lock. I think the Thread
>>> parameter should be moved to first so that we can have MutexLocker look like
>>> the Handle constructor calls, for example. I didn't make this change in this.
>>>
>>> MutexLocker ml(THREAD, Monitor_lock).
>>>
>>> The interesting changes are in:
>>>
>>> http://cr.openjdk.java.net/~coleenp/2019/8222811.01/webrev/src/hotspot/share/runtime/mutexLocker.hpp.udiff.html
>>>
>>> http://cr.openjdk.java.net/~coleenp/2019/8222811.01/webrev/src/hotspot/share/runtime/mutex.hpp.udiff.html
>>>
>>> http://cr.openjdk.java.net/~coleenp/2019/8222811.01/webrev/src/hotspot/share/runtime/mutex.cpp.udiff.html
>>>
>>>
>>> The rest is pattern substitution.
>>>
>>> Ran mach5 tier1-6 tests.
>>>
>>> open webrev at http://cr.openjdk.java.net/~coleenp/2019/8222811.01/webrev
>>> bug link https://bugs.openjdk.java.net/browse/JDK-8222811
>>>
>>> Thanks!
>>> Coleen
>>>
>>>
>
More information about the hotspot-dev
mailing list