< prev index next >
src/share/vm/runtime/synchronizer.cpp
Print this page
rev 8910 : full patch for jfr
*** 1,7 ****
/*
! * Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
--- 1,7 ----
/*
! * Copyright (c) 1998, 2019, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*** 1191,1207 ****
--- 1191,1222 ----
// Note that we could encounter some performance loss through false-sharing as
// multiple locks occupy the same $ line. Padding might be appropriate.
+ static void post_monitor_inflate_event(EventJavaMonitorInflate& event,
+ const oop obj,
+ //const ObjectSynchronizer::InflateCause cause) {
+ // unsupport cause
+ const u1 cause) {
+ #if INCLUDE_TRACE
+ assert(event.should_commit(), "check outside");
+ event.set_monitorClass(obj->klass());
+ event.set_address((TYPE_ADDRESS)(uintptr_t)(void*)obj);
+ event.set_cause((u1)cause);
+ event.commit();
+ #endif
+ }
ObjectMonitor * ATTR ObjectSynchronizer::inflate (Thread * Self, oop object) {
// 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 ****
--- 1343,1355 ----
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, (u1)0);
+ }
return m ;
}
// CASE: neutral
// TODO-FIXME: for entry we currently inflate and then try to CAS _owner.
*** 1378,1387 ****
--- 1396,1408 ----
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, (u1)0);
+ }
return m ;
}
}
// Note that we could encounter some performance loss through false-sharing as
< prev index next >