< prev index next >


Print this page
@@ -69,11 +69,11 @@
  #include "runtime/jfieldIDWorkaround.hpp"
  #include "runtime/osThread.hpp"
  #include "runtime/sharedRuntime.hpp"
  #include "runtime/stackWatermarkSet.hpp"
  #include "runtime/stubRoutines.hpp"
- #include "runtime/synchronizer.hpp"
+ #include "runtime/synchronizer.inline.hpp"
  #include "runtime/threadCritical.hpp"
  #include "utilities/align.hpp"
  #include "utilities/checkedCast.hpp"
  #include "utilities/copy.hpp"
  #include "utilities/events.hpp"

@@ -723,11 +723,10 @@
  // be shared by method invocation and synchronized blocks.
  //%note synchronization_3
  //%note monitor_1
  JRT_ENTRY_NO_ASYNC(void, InterpreterRuntime::monitorenter(JavaThread* current, BasicObjectLock* elem))
-   assert(LockingMode != LM_LIGHTWEIGHT, "Should call monitorenter_obj() when using the new lightweight locking");
  #ifdef ASSERT
    Handle h_obj(current, elem->obj());

@@ -738,27 +737,10 @@
  #ifdef ASSERT
- // NOTE: We provide a separate implementation for the new lightweight locking to workaround a limitation
- // of registers in x86_32. This entry point accepts an oop instead of a BasicObjectLock*.
- // The problem is that we would need to preserve the register that holds the BasicObjectLock,
- // but we are using that register to hold the thread. We don't have enough registers to
- // also keep the BasicObjectLock, but we don't really need it anyway, we only need
- // the object. See also InterpreterMacroAssembler::lock_object().
- // As soon as legacy stack-locking goes away we could remove the other monitorenter() entry
- // point, and only use oop-accepting entries (same for monitorexit() below).
- JRT_ENTRY_NO_ASYNC(void, InterpreterRuntime::monitorenter_obj(JavaThread* current, oopDesc* obj))
-   assert(LockingMode == LM_LIGHTWEIGHT, "Should call monitorenter() when not using the new lightweight locking");
-   Handle h_obj(current, cast_to_oop(obj));
-   assert(Universe::heap()->is_in_or_null(h_obj()),
-          "must be null or an object");
-   ObjectSynchronizer::enter(h_obj, nullptr, current);
-   return;
  JRT_LEAF(void, InterpreterRuntime::monitorexit(BasicObjectLock* elem))
    oop obj = elem->obj();
    assert(Universe::heap()->is_in(obj), "must be an object");
    // The object could become unlocked through a JNI call, which we have no other checks for.
    // Give a fatal message if CheckJNICalls. Otherwise we ignore it.
< prev index next >