RFR(S): 8221350 more monitor logging updates from Async Monitor Deflation project
coleen.phillimore at oracle.com
coleen.phillimore at oracle.com
Tue Mar 26 18:55:02 UTC 2019
http://cr.openjdk.java.net/~dcubed/8221350-webrev/3-for-jdk13.more_monitor_logging/src/hotspot/share/runtime/synchronizer.cpp.frames.html
1750 LogStreamHandle(Debug, monitorinflation) lsh_debug;
1751 LogStreamHandle(Info, monitorinflation) lsh_info;
1752 LogStream * ls = NULL;
1753 if (log_is_enabled(Debug, monitorinflation)) {
1754 ls = &lsh_debug;
1755 } else if (deflated_count != 0 && log_is_enabled(Info,
monitorinflation)) {
1756 ls = &lsh_info;
1757 }
1758 if (ls != NULL) {
1759 ls->print_cr("jt=" INTPTR_FORMAT ": deflating per-thread idle
monitors, %3.7f secs, %d monitors", p2i(thread), timer.seconds(),
deflated_count);
1760 }
This and the block above might be nicer as below, at risk of repeating
the print string.
1755 if (deflated_count != 0) {
1759 log_info("jt=" INTPTR_FORMAT ": deflating per-thread idle monitors,
%3.7f secs, %d monitors", p2i(thread), timer.seconds(), deflated_count);
1760 } else { 1759 log_debug("jt=" INTPTR_FORMAT ": deflating per-thread
idle monitors, %3.7f secs, %d monitors", p2i(thread), timer.seconds(),
deflated_count);
}
You can decide if you want to change this or not, though.
Coleen
On 3/25/19 8:45 PM, Daniel D. Daugherty wrote:
> Thanks! Don't think this one qualifies as trivial so I'll
> wait for another reviewer...
>
> Dan
>
>
> On 3/25/19 6:30 PM, David Holmes wrote:
>> Hi Dan,
>>
>> Your tweak looks good.
>>
>> Thanks,
>> David
>>
>> On 26/03/2019 7:25 am, Daniel D. Daugherty wrote:
>>> On 3/24/19 10:02 PM, David Holmes wrote:
>>>> Hi Dan,
>>>>
>>>> On 23/03/2019 6:23 am, Daniel D. Daugherty wrote:
>>>>> Greetings,
>>>>>
>>>>> I have a (S)mall patch extracted from the Async Monitor Deflation
>>>>> project
>>>>> that is ready for code review.
>>>>>
>>>>> The short version of what this patch is about:
>>>>>
>>>>> More monitor logging updates.
>>>>>
>>>>> The details are in the bug report:
>>>>>
>>>>> JDK-8221350 monitor logging updates from Async Monitor
>>>>> Deflation project
>>>>> https://bugs.openjdk.java.net/browse/JDK-8221350
>>>>>
>>>>> Here's the webrev:
>>>>>
>>>>> http://cr.openjdk.java.net/~dcubed/8221350-webrev/3-for-jdk13.more_monitor_logging/
>>>>
>>>>
>>>>
>>>>
>>>>
>>>> This mostly seems okay.
>>>
>>> Thanks.
>>>
>>>
>>>> One comment on the timer changes in synchronizer.cpp. Why not just
>>>> change this:
>>>>
>>>> 1711 timer.stop();
>>>> 1712
>>>> 1713 Thread::muxAcquire(&gListLock,
>>>> "deflate_thread_local_monitors");
>>>> 1714
>>>> 1715 // Adjust counters
>>>> 1716 counters->nInCirculation += thread->omInUseCount;
>>>> 1717 thread->omInUseCount -= deflated_count;
>>>> 1718 counters->nScavenged += deflated_count;
>>>> 1719 counters->nInuse += thread->omInUseCount;
>>>> 1720 counters->perThreadScavenged += deflated_count;
>>>> 1721 // For now, we only care about cumulative per-thread
>>>> deflation time.
>>>> 1722 counters->perThreadTimes += timer.seconds();
>>>>
>>>> to move the timer.stop() to after line 1720, rather than moving
>>>> outside the mux-block and reacquiring the mux again?
>>>
>>> How about a slight tweak to that:
>>>
>>> We'll move the timer.stop() and the perThreadTimes to just
>>> before the muxRelease():
>>>
>>> Diff relative to the baseline:
>>>
>>> ***************
>>> *** 1708,1715 ****
>>>
>>> int deflated_count =
>>> deflate_monitor_list(thread->omInUseList_addr(), &freeHeadp,
>>> &freeTailp);
>>>
>>> - timer.stop();
>>> -
>>> Thread::muxAcquire(&gListLock, "deflate_thread_local_monitors");
>>>
>>> // Adjust counters
>>> --- 1717,1722 ----
>>> ***************
>>> *** 1718,1725 ****
>>> counters->nScavenged += deflated_count;
>>> counters->nInuse += thread->omInUseCount;
>>> counters->perThreadScavenged += deflated_count;
>>> - // For now, we only care about cumulative per-thread deflation
>>> time.
>>> - counters->perThreadTimes += timer.seconds();
>>>
>>> // Move the scavenged monitors back to the global free list.
>>> if (freeHeadp != NULL) {
>>> --- 1725,1730 ----
>>> ***************
>>> *** 1730,1736 ****
>>> --- 1735,1760 ----
>>> freeTailp->FreeNext = gFreeList;
>>> gFreeList = freeHeadp;
>>> }
>>> +
>>> + timer.stop();
>>> + // Safepoint logging cares about cumulative perThreadTimes and
>>> + // we'll capture most of the cost, but not the muxRelease() which
>>> + // should be cheap.
>>> + counters->perThreadTimes += timer.seconds();
>>> +
>>> Thread::muxRelease(&gListLock);
>>>
>>>
>>> What do you think?
>>>
>>> Dan
>>>
>>>
>>>>
>>>> Thanks,
>>>> David
>>>> -----
>>>>
>>>>>
>>>>> This patch along with the current patch for Async Monitor Deflation
>>>>> project have been through Mach5 tier[1-8] testing.
>>>>>
>>>>> I have been actively using this new logging code while debugging and
>>>>> analyzing my port of the Async Monitor Deflation project code.
>>>>>
>>>>> Thanks, in advance, for any questions, comments or suggestions.
>>>>>
>>>>> Dan
>>>
>
More information about the hotspot-runtime-dev
mailing list