8241403: JavaThread::get_thread_name() should be ThreadSMR-aware
Reviewed-by: rehn, coleenp, dholmes
This commit is contained in:
parent
3088e1e62e
commit
47a0842646
@ -1006,7 +1006,8 @@ void CompileBroker::init_compiler_sweeper_threads() {
|
|||||||
_compilers[1]->set_num_compiler_threads(i + 1);
|
_compilers[1]->set_num_compiler_threads(i + 1);
|
||||||
if (TraceCompilerThreads) {
|
if (TraceCompilerThreads) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
MutexLocker mu(Threads_lock);
|
ThreadsListHandle tlh; // get_thread_name() depends on the TLH.
|
||||||
|
assert(tlh.includes(ct), "ct=" INTPTR_FORMAT " exited unexpectedly.", p2i(ct));
|
||||||
tty->print_cr("Added initial compiler thread %s", ct->get_thread_name());
|
tty->print_cr("Added initial compiler thread %s", ct->get_thread_name());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1026,7 +1027,8 @@ void CompileBroker::init_compiler_sweeper_threads() {
|
|||||||
_compilers[0]->set_num_compiler_threads(i + 1);
|
_compilers[0]->set_num_compiler_threads(i + 1);
|
||||||
if (TraceCompilerThreads) {
|
if (TraceCompilerThreads) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
MutexLocker mu(Threads_lock);
|
ThreadsListHandle tlh; // get_thread_name() depends on the TLH.
|
||||||
|
assert(tlh.includes(ct), "ct=" INTPTR_FORMAT " exited unexpectedly.", p2i(ct));
|
||||||
tty->print_cr("Added initial compiler thread %s", ct->get_thread_name());
|
tty->print_cr("Added initial compiler thread %s", ct->get_thread_name());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1112,7 +1114,8 @@ void CompileBroker::possibly_add_compiler_threads(Thread* THREAD) {
|
|||||||
_compilers[1]->set_num_compiler_threads(i + 1);
|
_compilers[1]->set_num_compiler_threads(i + 1);
|
||||||
if (TraceCompilerThreads) {
|
if (TraceCompilerThreads) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
MutexLocker mu(Threads_lock);
|
ThreadsListHandle tlh; // get_thread_name() depends on the TLH.
|
||||||
|
assert(tlh.includes(ct), "ct=" INTPTR_FORMAT " exited unexpectedly.", p2i(ct));
|
||||||
tty->print_cr("Added compiler thread %s (available memory: %dMB, available non-profiled code cache: %dMB)",
|
tty->print_cr("Added compiler thread %s (available memory: %dMB, available non-profiled code cache: %dMB)",
|
||||||
ct->get_thread_name(), (int)(available_memory/M), (int)(available_cc_np/M));
|
ct->get_thread_name(), (int)(available_memory/M), (int)(available_cc_np/M));
|
||||||
}
|
}
|
||||||
@ -1132,7 +1135,8 @@ void CompileBroker::possibly_add_compiler_threads(Thread* THREAD) {
|
|||||||
_compilers[0]->set_num_compiler_threads(i + 1);
|
_compilers[0]->set_num_compiler_threads(i + 1);
|
||||||
if (TraceCompilerThreads) {
|
if (TraceCompilerThreads) {
|
||||||
ResourceMark rm;
|
ResourceMark rm;
|
||||||
MutexLocker mu(Threads_lock);
|
ThreadsListHandle tlh; // get_thread_name() depends on the TLH.
|
||||||
|
assert(tlh.includes(ct), "ct=" INTPTR_FORMAT " exited unexpectedly.", p2i(ct));
|
||||||
tty->print_cr("Added compiler thread %s (available memory: %dMB, available profiled code cache: %dMB)",
|
tty->print_cr("Added compiler thread %s (available memory: %dMB, available profiled code cache: %dMB)",
|
||||||
ct->get_thread_name(), (int)(available_memory/M), (int)(available_cc_p/M));
|
ct->get_thread_name(), (int)(available_memory/M), (int)(available_cc_p/M));
|
||||||
}
|
}
|
||||||
|
@ -2933,8 +2933,6 @@ JVM_END
|
|||||||
// but is thought to be reliable and simple. In the case, where the receiver is the
|
// but is thought to be reliable and simple. In the case, where the receiver is the
|
||||||
// same thread as the sender, no VM_Operation is needed.
|
// same thread as the sender, no VM_Operation is needed.
|
||||||
JVM_ENTRY(void, JVM_StopThread(JNIEnv* env, jobject jthread, jobject throwable))
|
JVM_ENTRY(void, JVM_StopThread(JNIEnv* env, jobject jthread, jobject throwable))
|
||||||
// A nested ThreadsListHandle will grab the Threads_lock so create
|
|
||||||
// tlh before we resolve throwable.
|
|
||||||
ThreadsListHandle tlh(thread);
|
ThreadsListHandle tlh(thread);
|
||||||
oop java_throwable = JNIHandles::resolve(throwable);
|
oop java_throwable = JNIHandles::resolve(throwable);
|
||||||
if (java_throwable == NULL) {
|
if (java_throwable == NULL) {
|
||||||
|
@ -482,6 +482,50 @@ void Thread::check_for_dangling_thread_pointer(Thread *thread) {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Is the target JavaThread protected by the calling Thread
|
||||||
|
// or by some other mechanism:
|
||||||
|
bool Thread::is_JavaThread_protected(const JavaThread* p) {
|
||||||
|
// Do the simplest check first:
|
||||||
|
if (SafepointSynchronize::is_at_safepoint()) {
|
||||||
|
// The target is protected since JavaThreads cannot exit
|
||||||
|
// while we're at a safepoint.
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Now make the simple checks based on who the caller is:
|
||||||
|
Thread* current_thread = Thread::current();
|
||||||
|
if (current_thread == p || Threads_lock->owner() == current_thread) {
|
||||||
|
// Target JavaThread is self or calling thread owns the Threads_lock.
|
||||||
|
// Second check is the same as Threads_lock->owner_is_self(),
|
||||||
|
// but we already have the current thread so check directly.
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check the ThreadsLists associated with the calling thread (if any)
|
||||||
|
// to see if one of them protects the target JavaThread:
|
||||||
|
for (SafeThreadsListPtr* stlp = current_thread->_threads_list_ptr;
|
||||||
|
stlp != NULL; stlp = stlp->previous()) {
|
||||||
|
if (stlp->list()->includes(p)) {
|
||||||
|
// The target JavaThread is protected by this ThreadsList:
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Use this debug code with -XX:+UseNewCode to diagnose locations that
|
||||||
|
// are missing a ThreadsListHandle or other protection mechanism:
|
||||||
|
// guarantee(!UseNewCode, "current_thread=" INTPTR_FORMAT " is not protecting p="
|
||||||
|
// INTPTR_FORMAT, p2i(current_thread), p2i(p));
|
||||||
|
|
||||||
|
// Note: Since 'p' isn't protected by a TLH, the call to
|
||||||
|
// p->is_handshake_safe_for() may crash, but we have debug bits so
|
||||||
|
// we'll be able to figure out what protection mechanism is missing.
|
||||||
|
assert(p->is_handshake_safe_for(current_thread), "JavaThread=" INTPTR_FORMAT
|
||||||
|
" is not protected and not handshake safe.", p2i(p));
|
||||||
|
|
||||||
|
// The target JavaThread is not protected so it is not safe to query:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
ThreadPriority Thread::get_priority(const Thread* const thread) {
|
ThreadPriority Thread::get_priority(const Thread* const thread) {
|
||||||
ThreadPriority priority;
|
ThreadPriority priority;
|
||||||
// Can return an error!
|
// Can return an error!
|
||||||
@ -2509,23 +2553,19 @@ void JavaThread::verify() {
|
|||||||
// Most callers of this method assume that it can't return NULL but a
|
// Most callers of this method assume that it can't return NULL but a
|
||||||
// thread may not have a name whilst it is in the process of attaching to
|
// thread may not have a name whilst it is in the process of attaching to
|
||||||
// the VM - see CR 6412693, and there are places where a JavaThread can be
|
// the VM - see CR 6412693, and there are places where a JavaThread can be
|
||||||
// seen prior to having it's threadObj set (eg JNI attaching threads and
|
// seen prior to having its threadObj set (e.g., JNI attaching threads and
|
||||||
// if vm exit occurs during initialization). These cases can all be accounted
|
// if vm exit occurs during initialization). These cases can all be accounted
|
||||||
// for such that this method never returns NULL.
|
// for such that this method never returns NULL.
|
||||||
const char* JavaThread::get_thread_name() const {
|
const char* JavaThread::get_thread_name() const {
|
||||||
#ifdef ASSERT
|
if (Thread::is_JavaThread_protected(this)) {
|
||||||
// early safepoints can hit while current thread does not yet have TLS
|
// The target JavaThread is protected so get_thread_name_string() is safe:
|
||||||
if (!SafepointSynchronize::is_at_safepoint()) {
|
|
||||||
// Current JavaThreads are allowed to get their own name without
|
|
||||||
// the Threads_lock.
|
|
||||||
if (Thread::current() != this) {
|
|
||||||
assert_locked_or_safepoint_or_handshake(Threads_lock, this);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif // ASSERT
|
|
||||||
return get_thread_name_string();
|
return get_thread_name_string();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// The target JavaThread is not protected so we return the default:
|
||||||
|
return Thread::name();
|
||||||
|
}
|
||||||
|
|
||||||
// Returns a non-NULL representation of this thread's name, or a suitable
|
// Returns a non-NULL representation of this thread's name, or a suitable
|
||||||
// descriptive string if there is no set name
|
// descriptive string if there is no set name
|
||||||
const char* JavaThread::get_thread_name_string(char* buf, int buflen) const {
|
const char* JavaThread::get_thread_name_string(char* buf, int buflen) const {
|
||||||
|
@ -201,6 +201,10 @@ class Thread: public ThreadShadow {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
// Is the target JavaThread protected by the calling Thread
|
||||||
|
// or by some other mechanism:
|
||||||
|
static bool is_JavaThread_protected(const JavaThread* p);
|
||||||
|
|
||||||
void* operator new(size_t size) throw() { return allocate(size, true); }
|
void* operator new(size_t size) throw() { return allocate(size, true); }
|
||||||
void* operator new(size_t size, const std::nothrow_t& nothrow_constant) throw() {
|
void* operator new(size_t size, const std::nothrow_t& nothrow_constant) throw() {
|
||||||
return allocate(size, false); }
|
return allocate(size, false); }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user