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:
Daniel D. Daugherty 2020-09-11 13:35:34 +00:00
parent 040c8f58e5
commit e7a1b9bf81
8 changed files with 44 additions and 44 deletions

View File

@ -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;

View File

@ -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;

View File

@ -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");

View File

@ -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;

View File

@ -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.

View File

@ -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

View File

@ -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());

View File

@ -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