8252981: ObjectMonitor::object() cleanup changes extracted from JDK-8247281
Co-authored-by: Erik Österlund <erik.osterlund@oracle.com> Co-authored-by: Daniel Daugherty <daniel.daugherty@oracle.com> Reviewed-by: rehn, coleenp, eosterlund
This commit is contained in:
parent
040c8f58e5
commit
e7a1b9bf81
@ -663,13 +663,13 @@ JvmtiEnvBase::get_current_contended_monitor(JavaThread *calling_thread, JavaThre
|
|||||||
mon = java_thread->current_pending_monitor();
|
mon = java_thread->current_pending_monitor();
|
||||||
if (mon != NULL) {
|
if (mon != NULL) {
|
||||||
// The thread is trying to enter() an ObjectMonitor.
|
// The thread is trying to enter() an ObjectMonitor.
|
||||||
obj = (oop)mon->object();
|
obj = mon->object();
|
||||||
assert(obj != NULL, "ObjectMonitor should have a valid object!");
|
assert(obj != NULL, "ObjectMonitor should have a valid object!");
|
||||||
}
|
}
|
||||||
// implied else: no contended ObjectMonitor
|
// implied else: no contended ObjectMonitor
|
||||||
} else {
|
} else {
|
||||||
// thread is doing an Object.wait() call
|
// thread is doing an Object.wait() call
|
||||||
obj = (oop)mon->object();
|
obj = mon->object();
|
||||||
assert(obj != NULL, "Object.wait() should have an object");
|
assert(obj != NULL, "Object.wait() should have an object");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -741,7 +741,7 @@ JvmtiEnvBase::get_locked_objects_in_frame(JavaThread* calling_thread, JavaThread
|
|||||||
// Save object of current wait() call (if any) for later comparison.
|
// Save object of current wait() call (if any) for later comparison.
|
||||||
ObjectMonitor *mon = java_thread->current_waiting_monitor();
|
ObjectMonitor *mon = java_thread->current_waiting_monitor();
|
||||||
if (mon != NULL) {
|
if (mon != NULL) {
|
||||||
wait_obj = (oop)mon->object();
|
wait_obj = mon->object();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
oop pending_obj = NULL;
|
oop pending_obj = NULL;
|
||||||
@ -752,7 +752,7 @@ JvmtiEnvBase::get_locked_objects_in_frame(JavaThread* calling_thread, JavaThread
|
|||||||
// Save object of current enter() call (if any) for later comparison.
|
// Save object of current enter() call (if any) for later comparison.
|
||||||
ObjectMonitor *mon = java_thread->current_pending_monitor();
|
ObjectMonitor *mon = java_thread->current_pending_monitor();
|
||||||
if (mon != NULL) {
|
if (mon != NULL) {
|
||||||
pending_obj = (oop)mon->object();
|
pending_obj = mon->object();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1434,7 +1434,7 @@ JvmtiMonitorClosure::do_monitor(ObjectMonitor* mon) {
|
|||||||
}
|
}
|
||||||
if (mon->owner() == _java_thread ) {
|
if (mon->owner() == _java_thread ) {
|
||||||
// Filter out on stack monitors collected during stack walk.
|
// Filter out on stack monitors collected during stack walk.
|
||||||
oop obj = (oop)mon->object();
|
oop obj = mon->object();
|
||||||
bool found = false;
|
bool found = false;
|
||||||
for (int j = 0; j < _owned_monitors_list->length(); j++) {
|
for (int j = 0; j < _owned_monitors_list->length(); j++) {
|
||||||
jobject jobj = ((jvmtiMonitorStackDepthInfo*)_owned_monitors_list->at(j))->monitor;
|
jobject jobj = ((jvmtiMonitorStackDepthInfo*)_owned_monitors_list->at(j))->monitor;
|
||||||
|
@ -2407,7 +2407,7 @@ void JvmtiExport::post_data_dump() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void JvmtiExport::post_monitor_contended_enter(JavaThread *thread, ObjectMonitor *obj_mntr) {
|
void JvmtiExport::post_monitor_contended_enter(JavaThread *thread, ObjectMonitor *obj_mntr) {
|
||||||
oop object = (oop)obj_mntr->object();
|
oop object = obj_mntr->object();
|
||||||
JvmtiThreadState *state = thread->jvmti_thread_state();
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
||||||
if (state == NULL) {
|
if (state == NULL) {
|
||||||
return;
|
return;
|
||||||
@ -2438,7 +2438,7 @@ void JvmtiExport::post_monitor_contended_enter(JavaThread *thread, ObjectMonitor
|
|||||||
}
|
}
|
||||||
|
|
||||||
void JvmtiExport::post_monitor_contended_entered(JavaThread *thread, ObjectMonitor *obj_mntr) {
|
void JvmtiExport::post_monitor_contended_entered(JavaThread *thread, ObjectMonitor *obj_mntr) {
|
||||||
oop object = (oop)obj_mntr->object();
|
oop object = obj_mntr->object();
|
||||||
JvmtiThreadState *state = thread->jvmti_thread_state();
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
||||||
if (state == NULL) {
|
if (state == NULL) {
|
||||||
return;
|
return;
|
||||||
@ -2501,7 +2501,7 @@ void JvmtiExport::post_monitor_wait(JavaThread *thread, oop object,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void JvmtiExport::post_monitor_waited(JavaThread *thread, ObjectMonitor *obj_mntr, jboolean timed_out) {
|
void JvmtiExport::post_monitor_waited(JavaThread *thread, ObjectMonitor *obj_mntr, jboolean timed_out) {
|
||||||
oop object = (oop)obj_mntr->object();
|
oop object = obj_mntr->object();
|
||||||
JvmtiThreadState *state = thread->jvmti_thread_state();
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
||||||
if (state == NULL) {
|
if (state == NULL) {
|
||||||
return;
|
return;
|
||||||
|
@ -276,9 +276,9 @@ bool ObjectMonitor::enter(TRAPS) {
|
|||||||
if (TrySpin(Self) > 0) {
|
if (TrySpin(Self) > 0) {
|
||||||
assert(_owner == Self, "must be Self: owner=" INTPTR_FORMAT, p2i(_owner));
|
assert(_owner == Self, "must be Self: owner=" INTPTR_FORMAT, p2i(_owner));
|
||||||
assert(_recursions == 0, "must be 0: recursions=" INTX_FORMAT, _recursions);
|
assert(_recursions == 0, "must be 0: recursions=" INTX_FORMAT, _recursions);
|
||||||
assert(((oop)object())->mark() == markWord::encode(this),
|
assert(object()->mark() == markWord::encode(this),
|
||||||
"object mark must match encoded this: mark=" INTPTR_FORMAT
|
"object mark must match encoded this: mark=" INTPTR_FORMAT
|
||||||
", encoded this=" INTPTR_FORMAT, ((oop)object())->mark().value(),
|
", encoded this=" INTPTR_FORMAT, object()->mark().value(),
|
||||||
markWord::encode(this).value());
|
markWord::encode(this).value());
|
||||||
Self->_Stalled = 0;
|
Self->_Stalled = 0;
|
||||||
return true;
|
return true;
|
||||||
@ -296,7 +296,7 @@ bool ObjectMonitor::enter(TRAPS) {
|
|||||||
// Async deflation is in progress and our contentions increment
|
// Async deflation is in progress and our contentions increment
|
||||||
// above lost the race to async deflation. Undo the work and
|
// above lost the race to async deflation. Undo the work and
|
||||||
// force the caller to retry.
|
// force the caller to retry.
|
||||||
const oop l_object = (oop)object();
|
const oop l_object = object();
|
||||||
if (l_object != NULL) {
|
if (l_object != NULL) {
|
||||||
// Attempt to restore the header/dmw to the object's header so that
|
// Attempt to restore the header/dmw to the object's header so that
|
||||||
// we only retry once if the deflater thread happens to be slow.
|
// we only retry once if the deflater thread happens to be slow.
|
||||||
@ -310,8 +310,8 @@ bool ObjectMonitor::enter(TRAPS) {
|
|||||||
JFR_ONLY(JfrConditionalFlushWithStacktrace<EventJavaMonitorEnter> flush(jt);)
|
JFR_ONLY(JfrConditionalFlushWithStacktrace<EventJavaMonitorEnter> flush(jt);)
|
||||||
EventJavaMonitorEnter event;
|
EventJavaMonitorEnter event;
|
||||||
if (event.should_commit()) {
|
if (event.should_commit()) {
|
||||||
event.set_monitorClass(((oop)this->object())->klass());
|
event.set_monitorClass(object()->klass());
|
||||||
event.set_address((uintptr_t)(this->object_addr()));
|
event.set_address((uintptr_t)object_addr());
|
||||||
}
|
}
|
||||||
|
|
||||||
{ // Change java thread status to indicate blocked on monitor enter.
|
{ // Change java thread status to indicate blocked on monitor enter.
|
||||||
@ -374,7 +374,7 @@ bool ObjectMonitor::enter(TRAPS) {
|
|||||||
assert(_recursions == 0, "invariant");
|
assert(_recursions == 0, "invariant");
|
||||||
assert(_owner == Self, "invariant");
|
assert(_owner == Self, "invariant");
|
||||||
assert(_succ != Self, "invariant");
|
assert(_succ != Self, "invariant");
|
||||||
assert(((oop)(object()))->mark() == markWord::encode(this), "invariant");
|
assert(object()->mark() == markWord::encode(this), "invariant");
|
||||||
|
|
||||||
// The thread -- now the owner -- is back in vm mode.
|
// The thread -- now the owner -- is back in vm mode.
|
||||||
// Report the glorious news via TI,DTrace and jvmstat.
|
// Report the glorious news via TI,DTrace and jvmstat.
|
||||||
@ -446,7 +446,7 @@ void ObjectMonitor::install_displaced_markword_in_object(const oop obj) {
|
|||||||
OrderAccess::loadload();
|
OrderAccess::loadload();
|
||||||
}
|
}
|
||||||
|
|
||||||
const oop l_object = (oop)object();
|
const oop l_object = object();
|
||||||
if (l_object == NULL) {
|
if (l_object == NULL) {
|
||||||
// ObjectMonitor's object ref has already been cleared by async
|
// ObjectMonitor's object ref has already been cleared by async
|
||||||
// deflation so we're done here.
|
// deflation so we're done here.
|
||||||
@ -770,7 +770,7 @@ void ObjectMonitor::ReenterI(Thread * Self, ObjectWaiter * SelfNode) {
|
|||||||
assert(SelfNode != NULL, "invariant");
|
assert(SelfNode != NULL, "invariant");
|
||||||
assert(SelfNode->_thread == Self, "invariant");
|
assert(SelfNode->_thread == Self, "invariant");
|
||||||
assert(_waiters > 0, "invariant");
|
assert(_waiters > 0, "invariant");
|
||||||
assert(((oop)(object()))->mark() == markWord::encode(this), "invariant");
|
assert(object()->mark() == markWord::encode(this), "invariant");
|
||||||
|
|
||||||
JavaThread * jt = Self->as_Java_thread();
|
JavaThread * jt = Self->as_Java_thread();
|
||||||
assert(jt->thread_state() != _thread_blocked, "invariant");
|
assert(jt->thread_state() != _thread_blocked, "invariant");
|
||||||
@ -839,7 +839,7 @@ void ObjectMonitor::ReenterI(Thread * Self, ObjectWaiter * SelfNode) {
|
|||||||
// In addition, Self.TState is stable.
|
// In addition, Self.TState is stable.
|
||||||
|
|
||||||
assert(_owner == Self, "invariant");
|
assert(_owner == Self, "invariant");
|
||||||
assert(((oop)(object()))->mark() == markWord::encode(this), "invariant");
|
assert(object()->mark() == markWord::encode(this), "invariant");
|
||||||
UnlinkAfterAcquire(Self, SelfNode);
|
UnlinkAfterAcquire(Self, SelfNode);
|
||||||
if (_succ == Self) _succ = NULL;
|
if (_succ == Self) _succ = NULL;
|
||||||
assert(_succ != Self, "invariant");
|
assert(_succ != Self, "invariant");
|
||||||
@ -1301,7 +1301,7 @@ static void post_monitor_wait_event(EventJavaMonitorWait* event,
|
|||||||
bool timedout) {
|
bool timedout) {
|
||||||
assert(event != NULL, "invariant");
|
assert(event != NULL, "invariant");
|
||||||
assert(monitor != NULL, "invariant");
|
assert(monitor != NULL, "invariant");
|
||||||
event->set_monitorClass(((oop)monitor->object())->klass());
|
event->set_monitorClass(monitor->object()->klass());
|
||||||
event->set_timeout(timeout);
|
event->set_timeout(timeout);
|
||||||
event->set_address((uintptr_t)monitor->object_addr());
|
event->set_address((uintptr_t)monitor->object_addr());
|
||||||
event->set_notifier(notifier_tid);
|
event->set_notifier(notifier_tid);
|
||||||
@ -1519,7 +1519,7 @@ void ObjectMonitor::wait(jlong millis, bool interruptible, TRAPS) {
|
|||||||
// Verify a few postconditions
|
// Verify a few postconditions
|
||||||
assert(_owner == Self, "invariant");
|
assert(_owner == Self, "invariant");
|
||||||
assert(_succ != Self, "invariant");
|
assert(_succ != Self, "invariant");
|
||||||
assert(((oop)(object()))->mark() == markWord::encode(this), "invariant");
|
assert(object()->mark() == markWord::encode(this), "invariant");
|
||||||
|
|
||||||
// check if the notification happened
|
// check if the notification happened
|
||||||
if (!WasNotified) {
|
if (!WasNotified) {
|
||||||
@ -2103,7 +2103,7 @@ void ObjectMonitor::print() const { print_on(tty); }
|
|||||||
void ObjectMonitor::print_debug_style_on(outputStream* st) const {
|
void ObjectMonitor::print_debug_style_on(outputStream* st) const {
|
||||||
st->print_cr("(ObjectMonitor*) " INTPTR_FORMAT " = {", p2i(this));
|
st->print_cr("(ObjectMonitor*) " INTPTR_FORMAT " = {", p2i(this));
|
||||||
st->print_cr(" _header = " INTPTR_FORMAT, header().value());
|
st->print_cr(" _header = " INTPTR_FORMAT, header().value());
|
||||||
st->print_cr(" _object = " INTPTR_FORMAT, p2i(_object));
|
st->print_cr(" _object = " INTPTR_FORMAT, p2i(object()));
|
||||||
st->print(" _allocation_state = ");
|
st->print(" _allocation_state = ");
|
||||||
if (is_free()) {
|
if (is_free()) {
|
||||||
st->print("Free");
|
st->print("Free");
|
||||||
|
@ -328,9 +328,9 @@ class ObjectMonitor {
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
void* object() const;
|
oop object() const;
|
||||||
void* object_addr();
|
oop* object_addr();
|
||||||
void set_object(void* obj);
|
void set_object(oop obj);
|
||||||
void release_set_allocation_state(AllocationState s);
|
void release_set_allocation_state(AllocationState s);
|
||||||
void set_allocation_state(AllocationState s);
|
void set_allocation_state(AllocationState s);
|
||||||
AllocationState allocation_state() const;
|
AllocationState allocation_state() const;
|
||||||
|
@ -92,22 +92,22 @@ inline void ObjectMonitor::clear_common() {
|
|||||||
assert(contentions() <= 0, "must not be positive: contentions=%d", contentions());
|
assert(contentions() <= 0, "must not be positive: contentions=%d", contentions());
|
||||||
assert(_waiters == 0, "must be 0: waiters=%d", _waiters);
|
assert(_waiters == 0, "must be 0: waiters=%d", _waiters);
|
||||||
assert(_recursions == 0, "must be 0: recursions=" INTX_FORMAT, _recursions);
|
assert(_recursions == 0, "must be 0: recursions=" INTX_FORMAT, _recursions);
|
||||||
assert(_object != NULL, "must be non-NULL");
|
assert(object() != NULL, "must be non-NULL");
|
||||||
|
|
||||||
set_allocation_state(Free);
|
set_allocation_state(Free);
|
||||||
_object = NULL;
|
set_object(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void* ObjectMonitor::object() const {
|
inline oop ObjectMonitor::object() const {
|
||||||
return _object;
|
return (oop)_object;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void* ObjectMonitor::object_addr() {
|
inline oop* ObjectMonitor::object_addr() {
|
||||||
return (void *)(&_object);
|
return (oop*)&_object;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void ObjectMonitor::set_object(void* obj) {
|
inline void ObjectMonitor::set_object(oop obj) {
|
||||||
_object = obj;
|
_object = (void*)obj;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return number of threads contending for this monitor.
|
// Return number of threads contending for this monitor.
|
||||||
|
@ -462,7 +462,7 @@ bool ObjectSynchronizer::quick_notify(oopDesc* obj, Thread* self, bool all) {
|
|||||||
|
|
||||||
if (mark.has_monitor()) {
|
if (mark.has_monitor()) {
|
||||||
ObjectMonitor* const mon = mark.monitor();
|
ObjectMonitor* const mon = mark.monitor();
|
||||||
assert(mon->object() == obj, "invariant");
|
assert(mon->object() == oop(obj), "invariant");
|
||||||
if (mon->owner() != self) return false; // slow-path for IMS exception
|
if (mon->owner() != self) return false; // slow-path for IMS exception
|
||||||
|
|
||||||
if (mon->first_waiter() != NULL) {
|
if (mon->first_waiter() != NULL) {
|
||||||
@ -683,7 +683,7 @@ void ObjectSynchronizer::exit(oop object, BasicLock* lock, TRAPS) {
|
|||||||
// Java Monitor can be asynchronously inflated by a thread that
|
// Java Monitor can be asynchronously inflated by a thread that
|
||||||
// does not own the Java Monitor.
|
// does not own the Java Monitor.
|
||||||
ObjectMonitor* m = mark.monitor();
|
ObjectMonitor* m = mark.monitor();
|
||||||
assert(((oop)(m->object()))->mark() == mark, "invariant");
|
assert(m->object()->mark() == mark, "invariant");
|
||||||
assert(m->is_entered(THREAD), "invariant");
|
assert(m->is_entered(THREAD), "invariant");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1425,7 +1425,7 @@ void ObjectSynchronizer::list_oops_do(ObjectMonitor* list, OopClosure* f) {
|
|||||||
// so no need to lock ObjectMonitors for the list traversal.
|
// so no need to lock ObjectMonitors for the list traversal.
|
||||||
for (ObjectMonitor* mid = list; mid != NULL; mid = unmarked_next(mid)) {
|
for (ObjectMonitor* mid = list; mid != NULL; mid = unmarked_next(mid)) {
|
||||||
if (mid->object() != NULL) {
|
if (mid->object() != NULL) {
|
||||||
f->do_oop((oop*)mid->object_addr());
|
f->do_oop(mid->object_addr());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2146,7 +2146,7 @@ bool ObjectSynchronizer::deflate_monitor_using_JT(ObjectMonitor* mid,
|
|||||||
"must be no entering threads: EntryList=" INTPTR_FORMAT,
|
"must be no entering threads: EntryList=" INTPTR_FORMAT,
|
||||||
p2i(mid->_EntryList));
|
p2i(mid->_EntryList));
|
||||||
|
|
||||||
const oop obj = (oop) mid->object();
|
const oop obj = mid->object();
|
||||||
if (log_is_enabled(Trace, monitorinflation)) {
|
if (log_is_enabled(Trace, monitorinflation)) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
log_trace(monitorinflation)("deflate_monitor_using_JT: "
|
log_trace(monitorinflation)("deflate_monitor_using_JT: "
|
||||||
@ -2867,7 +2867,7 @@ void ObjectSynchronizer::chk_in_use_entry(JavaThread* jt, ObjectMonitor* n,
|
|||||||
}
|
}
|
||||||
*error_cnt_p = *error_cnt_p + 1;
|
*error_cnt_p = *error_cnt_p + 1;
|
||||||
}
|
}
|
||||||
const oop obj = (oop)n->object();
|
const oop obj = n->object();
|
||||||
const markWord mark = obj->mark();
|
const markWord mark = obj->mark();
|
||||||
if (!mark.has_monitor()) {
|
if (!mark.has_monitor()) {
|
||||||
if (jt != NULL) {
|
if (jt != NULL) {
|
||||||
@ -2977,7 +2977,7 @@ void ObjectSynchronizer::log_in_use_monitor_details(outputStream * out) {
|
|||||||
if ((cur = get_list_head_locked(&om_list_globals._in_use_list)) != NULL) {
|
if ((cur = get_list_head_locked(&om_list_globals._in_use_list)) != NULL) {
|
||||||
// Marked the global in-use list head so process the list.
|
// Marked the global in-use list head so process the list.
|
||||||
while (true) {
|
while (true) {
|
||||||
const oop obj = (oop) cur->object();
|
const oop obj = cur->object();
|
||||||
const markWord mark = cur->header();
|
const markWord mark = cur->header();
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
out->print(INTPTR_FORMAT " %d%d%d " INTPTR_FORMAT " %s", p2i(cur),
|
out->print(INTPTR_FORMAT " %d%d%d " INTPTR_FORMAT " %s", p2i(cur),
|
||||||
@ -3007,7 +3007,7 @@ void ObjectSynchronizer::log_in_use_monitor_details(outputStream * out) {
|
|||||||
if ((cur = get_list_head_locked(&jt->om_in_use_list)) != NULL) {
|
if ((cur = get_list_head_locked(&jt->om_in_use_list)) != NULL) {
|
||||||
// Marked the global in-use list head so process the list.
|
// Marked the global in-use list head so process the list.
|
||||||
while (true) {
|
while (true) {
|
||||||
const oop obj = (oop) cur->object();
|
const oop obj = cur->object();
|
||||||
const markWord mark = cur->header();
|
const markWord mark = cur->header();
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
out->print(INTPTR_FORMAT " " INTPTR_FORMAT " %d%d%d " INTPTR_FORMAT
|
out->print(INTPTR_FORMAT " " INTPTR_FORMAT " %d%d%d " INTPTR_FORMAT
|
||||||
|
@ -229,12 +229,12 @@ Handle ThreadService::get_current_contended_monitor(JavaThread* thread) {
|
|||||||
oop obj = NULL;
|
oop obj = NULL;
|
||||||
if (wait_obj != NULL) {
|
if (wait_obj != NULL) {
|
||||||
// thread is doing an Object.wait() call
|
// thread is doing an Object.wait() call
|
||||||
obj = (oop) wait_obj->object();
|
obj = wait_obj->object();
|
||||||
} else {
|
} else {
|
||||||
ObjectMonitor *enter_obj = thread->current_pending_monitor();
|
ObjectMonitor *enter_obj = thread->current_pending_monitor();
|
||||||
if (enter_obj != NULL) {
|
if (enter_obj != NULL) {
|
||||||
// thread is trying to enter() an ObjectMonitor.
|
// thread is trying to enter() an ObjectMonitor.
|
||||||
obj = (oop) enter_obj->object();
|
obj = enter_obj->object();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -625,7 +625,7 @@ public:
|
|||||||
}
|
}
|
||||||
void do_monitor(ObjectMonitor* mid) {
|
void do_monitor(ObjectMonitor* mid) {
|
||||||
if (mid->owner() == _thread) {
|
if (mid->owner() == _thread) {
|
||||||
oop object = (oop) mid->object();
|
oop object = mid->object();
|
||||||
if (!_stack_trace->is_owned_monitor_on_stack(object)) {
|
if (!_stack_trace->is_owned_monitor_on_stack(object)) {
|
||||||
_stack_trace->add_jni_locked_monitor(object);
|
_stack_trace->add_jni_locked_monitor(object);
|
||||||
}
|
}
|
||||||
@ -997,7 +997,7 @@ void DeadlockCycle::print_on_with(ThreadsList * t_list, outputStream* st) const
|
|||||||
|
|
||||||
if (waitingToLockMonitor != NULL) {
|
if (waitingToLockMonitor != NULL) {
|
||||||
st->print(" waiting to lock monitor " INTPTR_FORMAT, p2i(waitingToLockMonitor));
|
st->print(" waiting to lock monitor " INTPTR_FORMAT, p2i(waitingToLockMonitor));
|
||||||
oop obj = (oop)waitingToLockMonitor->object();
|
oop obj = waitingToLockMonitor->object();
|
||||||
st->print(" (object " INTPTR_FORMAT ", a %s)", p2i(obj),
|
st->print(" (object " INTPTR_FORMAT ", a %s)", p2i(obj),
|
||||||
obj->klass()->external_name());
|
obj->klass()->external_name());
|
||||||
|
|
||||||
|
@ -100,8 +100,8 @@ public class ObjectMonitor extends VMObject {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// FIXME
|
// FIXME
|
||||||
// void* object_addr();
|
// oop* object_addr();
|
||||||
// void set_object(void* obj);
|
// void set_object(oop obj);
|
||||||
|
|
||||||
// The following four either aren't expressed as typed fields in
|
// The following four either aren't expressed as typed fields in
|
||||||
// vmStructs.cpp because they aren't strongly typed in the VM, or
|
// vmStructs.cpp because they aren't strongly typed in the VM, or
|
||||||
|
Loading…
Reference in New Issue
Block a user