提交 5421a803 编写于 作者: N never

7144318: GCLocker assert failure: assert(_needs_gc || SafepointSynchronize::is_at_safepoint(

Reviewed-by: kvn, twisti
上级 b62c22d3
...@@ -83,13 +83,26 @@ class GC_locker: public AllStatic { ...@@ -83,13 +83,26 @@ class GC_locker: public AllStatic {
static void jni_lock(JavaThread* thread); static void jni_lock(JavaThread* thread);
static void jni_unlock(JavaThread* thread); static void jni_unlock(JavaThread* thread);
static bool is_active_internal() {
verify_critical_count();
return _lock_count > 0 || _jni_lock_count > 0;
}
public: public:
// Accessors // Accessors
static bool is_active(); static bool is_active() {
assert(_needs_gc || SafepointSynchronize::is_at_safepoint(), "only read at safepoint");
return is_active_internal();
}
static bool needs_gc() { return _needs_gc; } static bool needs_gc() { return _needs_gc; }
// Shorthand // Shorthand
static bool is_active_and_needs_gc() { return needs_gc() && is_active(); } static bool is_active_and_needs_gc() {
// Use is_active_internal since _needs_gc can change from true to
// false outside of a safepoint, triggering the assert in
// is_active.
return needs_gc() && is_active_internal();
}
// In debug mode track the locking state at all times // In debug mode track the locking state at all times
static void increment_debug_jni_lock_count() { static void increment_debug_jni_lock_count() {
......
...@@ -27,12 +27,6 @@ ...@@ -27,12 +27,6 @@
#include "memory/gcLocker.hpp" #include "memory/gcLocker.hpp"
inline bool GC_locker::is_active() {
assert(_needs_gc || SafepointSynchronize::is_at_safepoint(), "only read at safepoint");
verify_critical_count();
return _lock_count > 0 || _jni_lock_count > 0;
}
inline void GC_locker::lock() { inline void GC_locker::lock() {
// cast away volatile // cast away volatile
Atomic::inc(&_lock_count); Atomic::inc(&_lock_count);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册