8311981: Test gc/stringdedup/TestStringDeduplicationAgeThreshold.java#ZGenerational timed out
Reviewed-by: stefank, pchilanomate, dcubed, rehn
This commit is contained in:
parent
595fdd36c5
commit
f142470dea
@ -497,8 +497,17 @@ HandshakeOperation* HandshakeState::get_op_for_self(bool allow_suspend, bool che
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool HandshakeState::has_operation(bool allow_suspend, bool check_async_exception) {
|
bool HandshakeState::has_operation(bool allow_suspend, bool check_async_exception) {
|
||||||
MutexLocker ml(&_lock, Mutex::_no_safepoint_check_flag);
|
// We must not block here as that could lead to deadlocks if we already hold an
|
||||||
return get_op_for_self(allow_suspend, check_async_exception) != nullptr;
|
// "external" mutex. If the try_lock fails then we assume that there is an operation
|
||||||
|
// and force the caller to check more carefully in a safer context. If we can't get
|
||||||
|
// the lock it means another thread is trying to handshake with us, so it can't
|
||||||
|
// happen during thread termination and destruction.
|
||||||
|
bool ret = true;
|
||||||
|
if (_lock.try_lock()) {
|
||||||
|
ret = get_op_for_self(allow_suspend, check_async_exception) != nullptr;
|
||||||
|
_lock.unlock();
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool HandshakeState::has_async_exception_operation() {
|
bool HandshakeState::has_async_exception_operation() {
|
||||||
|
Loading…
Reference in New Issue
Block a user