RFR (L, tedious) 8222811: Consolidate MutexLockerEx and MutexLocker
Per Liden
per.liden at oracle.com
Wed Apr 24 17:19:43 UTC 2019
Hi Coleen,
On 04/24/2019 01:18 PM, coleen.phillimore at oracle.com wrote:
>
>
> On 4/24/19 3:57 AM, Per Liden wrote:
>> Hi Coleen,
>>
>> I like this clean up. However, one thing that always bothered me is
>> this pattern:
>
> Hi Per, Erik said you would like it.
>>
>> MonitorLockerEx ml(&_monitor, Monitor::_no_safepoint_check_flag);
>> ...
>> ml.wait(Monitor::_no_safepoint_check_flag);
>>
>> And with your patch it becomes:
>>
>> MonitorLocker ml(&_monitor, Monitor::_no_safepoint_check_flag);
>> ...
>> ml.wait_without_safepoint_check();
>>
>> Now, it seems a bit silly, and potentially error prone, to always have
>> to say "don't safepoint check" twice. We already told the
>> MonitorLocker what to do when it was constructed, so can't we just
>> have this:
>>
>> 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?
>
> 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.
I've also noticed that there's a slit in the code, some use the lock
directly for wait/notify, and some use them via the MonitorLocker. I see
a value in keeping MonitorLocker, especially if we can leave out the
safepoint_check argument in wait(). Using the MonitorLocker tends to
simplify code IMHO.
cheers,
Per
>
> 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