< prev index next >
src/share/vm/runtime/synchronizer.cpp
Print this page
*** 22,31 ****
--- 22,32 ----
*
*/
#include "precompiled.hpp"
#include "classfile/vmSymbols.hpp"
+ #include "jfr/jfrEvents.hpp"
#include "memory/resourceArea.hpp"
#include "oops/markOop.hpp"
#include "oops/oop.inline.hpp"
#include "runtime/biasedLocking.hpp"
#include "runtime/handles.inline.hpp"
*** 1176,1185 ****
--- 1177,1197 ----
Thread::muxRelease (&ListLock) ;
TEVENT (omFlush) ;
}
+ static void post_monitor_inflate_event(EventJavaMonitorInflate* event,
+ const oop obj) {
+ assert(event != NULL, "invariant");
+ assert(event->should_commit(), "invariant");
+ event->set_monitorClass(obj->klass());
+ event->set_address((uintptr_t)(void*)obj);
+ // XXX no such counters. implement?
+ // event->set_cause((u1)cause);
+ event->commit();
+ }
+
// Fast path code shared by multiple functions
ObjectMonitor* ObjectSynchronizer::inflate_helper(oop obj) {
markOop mark = obj->mark();
if (mark->has_monitor()) {
assert(ObjectSynchronizer::verify_objmon_isinpool(mark->monitor()), "monitor is invalid");
*** 1198,1207 ****
--- 1210,1221 ----
// Inflate mutates the heap ...
// Relaxing assertion for bug 6320749.
assert (Universe::verify_in_progress() ||
!SafepointSynchronize::is_at_safepoint(), "invariant") ;
+ EventJavaMonitorInflate event;
+
for (;;) {
const markOop mark = object->mark() ;
assert (!mark->has_bias_pattern(), "invariant") ;
// The mark can be in one of the following states:
*** 1328,1337 ****
--- 1342,1354 ----
tty->print_cr("Inflating object " INTPTR_FORMAT " , mark " INTPTR_FORMAT " , type %s",
(void *) object, (intptr_t) object->mark(),
object->klass()->external_name());
}
}
+ if (event.should_commit()) {
+ post_monitor_inflate_event(&event, object);
+ }
return m ;
}
// CASE: neutral
// TODO-FIXME: for entry we currently inflate and then try to CAS _owner.
*** 1378,1387 ****
--- 1395,1407 ----
tty->print_cr("Inflating object " INTPTR_FORMAT " , mark " INTPTR_FORMAT " , type %s",
(void *) object, (intptr_t) object->mark(),
object->klass()->external_name());
}
}
+ if (event.should_commit()) {
+ post_monitor_inflate_event(&event, object);
+ }
return m ;
}
}
// Note that we could encounter some performance loss through false-sharing as
< prev index next >