8202415: Incorrect time logged for monitor deflation

Add support for "deflating per-thread idle monitors" log mesgs.

Reviewed-by: dholmes, coleenp
This commit is contained in:
Daniel D. Daugherty 2018-11-27 18:35:16 -05:00
parent bc215804a4
commit 8e4e1a91c0
4 changed files with 30 additions and 9 deletions

View File

@ -616,7 +616,7 @@ public:
Threads::possibly_parallel_threads_do(true, &_cleanup_threads_cl); Threads::possibly_parallel_threads_do(true, &_cleanup_threads_cl);
if (_subtasks.try_claim_task(SafepointSynchronize::SAFEPOINT_CLEANUP_DEFLATE_MONITORS)) { if (_subtasks.try_claim_task(SafepointSynchronize::SAFEPOINT_CLEANUP_DEFLATE_MONITORS)) {
const char* name = "deflating idle monitors"; const char* name = "deflating global idle monitors";
EventSafepointCleanupTask event; EventSafepointCleanupTask event;
TraceTime timer(name, TRACETIME_LOG(Info, safepoint, cleanup)); TraceTime timer(name, TRACETIME_LOG(Info, safepoint, cleanup));
ObjectSynchronizer::deflate_idle_monitors(_counters); ObjectSynchronizer::deflate_idle_monitors(_counters);

View File

@ -45,6 +45,7 @@
#include "runtime/stubRoutines.hpp" #include "runtime/stubRoutines.hpp"
#include "runtime/synchronizer.hpp" #include "runtime/synchronizer.hpp"
#include "runtime/thread.inline.hpp" #include "runtime/thread.inline.hpp"
#include "runtime/timer.hpp"
#include "runtime/vframe.hpp" #include "runtime/vframe.hpp"
#include "runtime/vmThread.hpp" #include "runtime/vmThread.hpp"
#include "utilities/align.hpp" #include "utilities/align.hpp"
@ -1621,6 +1622,7 @@ void ObjectSynchronizer::prepare_deflate_idle_monitors(DeflateMonitorCounters* c
counters->nInuse = 0; // currently associated with objects counters->nInuse = 0; // currently associated with objects
counters->nInCirculation = 0; // extant counters->nInCirculation = 0; // extant
counters->nScavenged = 0; // reclaimed counters->nScavenged = 0; // reclaimed
counters->perThreadTimes = 0.0; // per-thread scavenge times
} }
void ObjectSynchronizer::deflate_idle_monitors(DeflateMonitorCounters* counters) { void ObjectSynchronizer::deflate_idle_monitors(DeflateMonitorCounters* counters) {
@ -1660,6 +1662,14 @@ void ObjectSynchronizer::deflate_idle_monitors(DeflateMonitorCounters* counters)
} }
void ObjectSynchronizer::finish_deflate_idle_monitors(DeflateMonitorCounters* counters) { void ObjectSynchronizer::finish_deflate_idle_monitors(DeflateMonitorCounters* counters) {
if (log_is_enabled(Info, safepoint, cleanup)) {
// Report the cumulative time for deflating each thread's idle
// monitors. Note: if the work is split among more than one
// worker thread, then the reported time will likely be more
// than a beginning to end measurement of the phase.
log_info(safepoint, cleanup)("deflating per-thread idle monitors, %3.7f secs", counters->perThreadTimes);
}
gMonitorFreeCount += counters->nScavenged; gMonitorFreeCount += counters->nScavenged;
// Consider: audit gFreeList to ensure that gMonitorFreeCount and list agree. // Consider: audit gFreeList to ensure that gMonitorFreeCount and list agree.
@ -1680,9 +1690,16 @@ void ObjectSynchronizer::deflate_thread_local_monitors(Thread* thread, DeflateMo
ObjectMonitor * freeHeadp = NULL; // Local SLL of scavenged monitors ObjectMonitor * freeHeadp = NULL; // Local SLL of scavenged monitors
ObjectMonitor * freeTailp = NULL; ObjectMonitor * freeTailp = NULL;
elapsedTimer timer;
if (log_is_enabled(Info, safepoint, cleanup)) {
timer.start();
}
int deflated_count = deflate_monitor_list(thread->omInUseList_addr(), &freeHeadp, &freeTailp); int deflated_count = deflate_monitor_list(thread->omInUseList_addr(), &freeHeadp, &freeTailp);
timer.stop();
Thread::muxAcquire(&gListLock, "scavenge - return"); Thread::muxAcquire(&gListLock, "scavenge - return");
// Adjust counters // Adjust counters
@ -1690,6 +1707,8 @@ void ObjectSynchronizer::deflate_thread_local_monitors(Thread* thread, DeflateMo
thread->omInUseCount -= deflated_count; thread->omInUseCount -= deflated_count;
counters->nScavenged += deflated_count; counters->nScavenged += deflated_count;
counters->nInuse += thread->omInUseCount; counters->nInuse += thread->omInUseCount;
// 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. // Move the scavenged monitors back to the global free list.
if (freeHeadp != NULL) { if (freeHeadp != NULL) {

View File

@ -38,6 +38,7 @@ struct DeflateMonitorCounters {
int nInuse; // currently associated with objects int nInuse; // currently associated with objects
int nInCirculation; // extant int nInCirculation; // extant
int nScavenged; // reclaimed int nScavenged; // reclaimed
double perThreadTimes; // per-thread scavenge times
}; };
class ObjectSynchronizer : AllStatic { class ObjectSynchronizer : AllStatic {

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2016, 2018, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -39,7 +39,8 @@ public class SafepointCleanupTest {
OutputAnalyzer output = new OutputAnalyzer(pb.start()); OutputAnalyzer output = new OutputAnalyzer(pb.start());
output.shouldContain("[safepoint,cleanup]"); output.shouldContain("[safepoint,cleanup]");
output.shouldContain("safepoint cleanup tasks"); output.shouldContain("safepoint cleanup tasks");
output.shouldContain("deflating idle monitors"); output.shouldContain("deflating global idle monitors");
output.shouldContain("deflating per-thread idle monitors");
output.shouldContain("updating inline caches"); output.shouldContain("updating inline caches");
output.shouldContain("compilation policy safepoint handler"); output.shouldContain("compilation policy safepoint handler");
output.shouldContain("purging class loader data graph"); output.shouldContain("purging class loader data graph");