< prev index next >
src/hotspot/share/runtime/vmThread.cpp
Print this page
rev 56635 : v2.00 -> v2.05 (CR5/v2.05/8-for-jdk13) patches combined into one; merge with 8229212.patch; merge with jdk-14+11; merge with 8230184.patch; merge with 8230876.patch; merge with jdk-14+15; merge with jdk-14+18.
@@ -38,10 +38,11 @@
#include "runtime/handles.inline.hpp"
#include "runtime/interfaceSupport.inline.hpp"
#include "runtime/mutexLocker.hpp"
#include "runtime/os.hpp"
#include "runtime/safepoint.hpp"
+#include "runtime/synchronizer.hpp"
#include "runtime/thread.inline.hpp"
#include "runtime/vmThread.hpp"
#include "runtime/vmOperations.hpp"
#include "services/runtimeService.hpp"
#include "utilities/dtrace.hpp"
@@ -308,10 +309,18 @@
xtty->stamp();
xtty->end_elem();
assert(should_terminate(), "termination flag must be set");
}
+ if (AsyncDeflateIdleMonitors && log_is_enabled(Info, monitorinflation)) {
+ // AsyncDeflateIdleMonitors does a special deflation at the final
+ // safepoint in order to reduce the in-use monitor population that
+ // is reported by ObjectSynchronizer::log_in_use_monitor_details()
+ // at VM exit.
+ ObjectSynchronizer::set_is_special_deflation_requested(true);
+ }
+
// 4526887 let VM thread exit at Safepoint
_cur_vm_operation = &halt_op;
SafepointSynchronize::begin();
if (VerifyBeforeExit) {
< prev index next >