From 13918a4519d3366d85d8712a8156007154747e22 Mon Sep 17 00:00:00 2001 From: Robbin Ehn Date: Fri, 28 Aug 2020 10:30:02 +0200 Subject: [PATCH] 8252414: Redundant suspend check when determining if a java thread is safe Reviewed-by: dholmes, dcubed, coleenp --- src/hotspot/share/runtime/handshake.cpp | 3 --- src/hotspot/share/runtime/safepoint.cpp | 28 +------------------------ 2 files changed, 1 insertion(+), 30 deletions(-) diff --git a/src/hotspot/share/runtime/handshake.cpp b/src/hotspot/share/runtime/handshake.cpp index 1b02d3671f1..38a74e40344 100644 --- a/src/hotspot/share/runtime/handshake.cpp +++ b/src/hotspot/share/runtime/handshake.cpp @@ -450,9 +450,6 @@ bool HandshakeState::can_process_handshake() { bool HandshakeState::possibly_can_process_handshake() { // Note that this method is allowed to produce false positives. - if (_handshakee->is_ext_suspended()) { - return true; - } if (_handshakee->is_terminated()) { return true; } diff --git a/src/hotspot/share/runtime/safepoint.cpp b/src/hotspot/share/runtime/safepoint.cpp index 1c4cbce3296..d1a00e93552 100644 --- a/src/hotspot/share/runtime/safepoint.cpp +++ b/src/hotspot/share/runtime/safepoint.cpp @@ -653,7 +653,7 @@ static bool safepoint_safe_with(JavaThread *thread, JavaThreadState state) { } bool SafepointSynchronize::handshake_safe(JavaThread *thread) { - if (thread->is_ext_suspended() || thread->is_terminated()) { + if (thread->is_terminated()) { return true; } JavaThreadState stable_state; @@ -890,32 +890,6 @@ void ThreadSafepointState::examine_state_of_thread(uint64_t safepoint_count) { return; } - // Check for a thread that is suspended. Note that thread resume tries - // to grab the Threads_lock which we own here, so a thread cannot be - // resumed during safepoint synchronization. - - // We check to see if this thread is suspended without locking to - // avoid deadlocking with a third thread that is waiting for this - // thread to be suspended. The third thread can notice the safepoint - // that we're trying to start at the beginning of its SR_lock->wait() - // call. If that happens, then the third thread will block on the - // safepoint while still holding the underlying SR_lock. We won't be - // able to get the SR_lock and we'll deadlock. - // - // We don't need to grab the SR_lock here for two reasons: - // 1) The suspend flags are both volatile and are set with an - // Atomic::cmpxchg() call so we should see the suspended - // state right away. - // 2) We're being called from the safepoint polling loop; if - // we don't see the suspended state on this iteration, then - // we'll come around again. - // - bool is_suspended = _thread->is_ext_suspended(); - if (is_suspended) { - account_safe_thread(); - return; - } - if (safepoint_safe_with(_thread, stable_state)) { check_for_lazy_critical_native(_thread, stable_state); account_safe_thread();