8222518: Remove unnecessary caching of Parker object in java.lang.Thread
Reviewed-by: dcubed, rehn
This commit is contained in:
parent
f50047aa8e
commit
ded4f6b5cf
@ -1613,7 +1613,6 @@ int java_lang_Thread::_stackSize_offset = 0;
|
|||||||
int java_lang_Thread::_tid_offset = 0;
|
int java_lang_Thread::_tid_offset = 0;
|
||||||
int java_lang_Thread::_thread_status_offset = 0;
|
int java_lang_Thread::_thread_status_offset = 0;
|
||||||
int java_lang_Thread::_park_blocker_offset = 0;
|
int java_lang_Thread::_park_blocker_offset = 0;
|
||||||
int java_lang_Thread::_park_event_offset = 0 ;
|
|
||||||
|
|
||||||
#define THREAD_FIELDS_DO(macro) \
|
#define THREAD_FIELDS_DO(macro) \
|
||||||
macro(_name_offset, k, vmSymbols::name_name(), string_signature, false); \
|
macro(_name_offset, k, vmSymbols::name_name(), string_signature, false); \
|
||||||
@ -1627,8 +1626,7 @@ int java_lang_Thread::_park_event_offset = 0 ;
|
|||||||
macro(_stackSize_offset, k, "stackSize", long_signature, false); \
|
macro(_stackSize_offset, k, "stackSize", long_signature, false); \
|
||||||
macro(_tid_offset, k, "tid", long_signature, false); \
|
macro(_tid_offset, k, "tid", long_signature, false); \
|
||||||
macro(_thread_status_offset, k, "threadStatus", int_signature, false); \
|
macro(_thread_status_offset, k, "threadStatus", int_signature, false); \
|
||||||
macro(_park_blocker_offset, k, "parkBlocker", object_signature, false); \
|
macro(_park_blocker_offset, k, "parkBlocker", object_signature, false)
|
||||||
macro(_park_event_offset, k, "nativeParkEventPointer", long_signature, false)
|
|
||||||
|
|
||||||
void java_lang_Thread::compute_offsets() {
|
void java_lang_Thread::compute_offsets() {
|
||||||
assert(_group_offset == 0, "offsets should be initialized only once");
|
assert(_group_offset == 0, "offsets should be initialized only once");
|
||||||
@ -1745,15 +1743,6 @@ oop java_lang_Thread::park_blocker(oop java_thread) {
|
|||||||
return java_thread->obj_field(_park_blocker_offset);
|
return java_thread->obj_field(_park_blocker_offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
jlong java_lang_Thread::park_event(oop java_thread) {
|
|
||||||
return java_thread->long_field(_park_event_offset);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool java_lang_Thread::set_park_event(oop java_thread, jlong ptr) {
|
|
||||||
java_thread->long_field_put(_park_event_offset, ptr);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* java_lang_Thread::thread_status_name(oop java_thread) {
|
const char* java_lang_Thread::thread_status_name(oop java_thread) {
|
||||||
ThreadStatus status = (java_lang_Thread::ThreadStatus)java_thread->int_field(_thread_status_offset);
|
ThreadStatus status = (java_lang_Thread::ThreadStatus)java_thread->int_field(_thread_status_offset);
|
||||||
switch (status) {
|
switch (status) {
|
||||||
|
@ -371,7 +371,6 @@ class java_lang_Thread : AllStatic {
|
|||||||
static int _tid_offset;
|
static int _tid_offset;
|
||||||
static int _thread_status_offset;
|
static int _thread_status_offset;
|
||||||
static int _park_blocker_offset;
|
static int _park_blocker_offset;
|
||||||
static int _park_event_offset ;
|
|
||||||
|
|
||||||
static void compute_offsets();
|
static void compute_offsets();
|
||||||
|
|
||||||
@ -413,12 +412,6 @@ class java_lang_Thread : AllStatic {
|
|||||||
// Blocker object responsible for thread parking
|
// Blocker object responsible for thread parking
|
||||||
static oop park_blocker(oop java_thread);
|
static oop park_blocker(oop java_thread);
|
||||||
|
|
||||||
// Pointer to type-stable park handler, encoded as jlong.
|
|
||||||
// Should be set when apparently null
|
|
||||||
// For details, see unsafe.cpp Unsafe_Unpark
|
|
||||||
static jlong park_event(oop java_thread);
|
|
||||||
static bool set_park_event(oop java_thread, jlong ptr);
|
|
||||||
|
|
||||||
// Java Thread Status for JVMTI and M&M use.
|
// Java Thread Status for JVMTI and M&M use.
|
||||||
// This thread status info is saved in threadStatus field of
|
// This thread status info is saved in threadStatus field of
|
||||||
// java.lang.Thread java class.
|
// java.lang.Thread java class.
|
||||||
|
@ -949,27 +949,16 @@ UNSAFE_ENTRY(void, Unsafe_Unpark(JNIEnv *env, jobject unsafe, jobject jthread))
|
|||||||
(void) tlh.cv_internal_thread_to_JavaThread(jthread, &thr, &java_thread);
|
(void) tlh.cv_internal_thread_to_JavaThread(jthread, &thr, &java_thread);
|
||||||
if (java_thread != NULL) {
|
if (java_thread != NULL) {
|
||||||
// This is a valid oop.
|
// This is a valid oop.
|
||||||
jlong lp = java_lang_Thread::park_event(java_thread);
|
if (thr != NULL) {
|
||||||
if (lp != 0) {
|
// The JavaThread is alive.
|
||||||
// This cast is OK even though the jlong might have been read
|
p = thr->parker();
|
||||||
// non-atomically on 32bit systems, since there, one word will
|
|
||||||
// always be zero anyway and the value set is always the same
|
|
||||||
p = (Parker*)addr_from_java(lp);
|
|
||||||
} else {
|
|
||||||
// Not cached in the java.lang.Thread oop yet (could be an
|
|
||||||
// older version of library).
|
|
||||||
if (thr != NULL) {
|
|
||||||
// The JavaThread is alive.
|
|
||||||
p = thr->parker();
|
|
||||||
if (p != NULL) {
|
|
||||||
// Cache the Parker in the java.lang.Thread oop for next time.
|
|
||||||
java_lang_Thread::set_park_event(java_thread, addr_to_java(p));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} // ThreadsListHandle is destroyed here.
|
} // ThreadsListHandle is destroyed here.
|
||||||
|
|
||||||
|
// 'p' points to type-stable-memory if non-NULL. If the target
|
||||||
|
// thread terminates before we get here the new user of this
|
||||||
|
// Parker will get a 'spurious' unpark - which is perfectly valid.
|
||||||
if (p != NULL) {
|
if (p != NULL) {
|
||||||
HOTSPOT_THREAD_UNPARK((uintptr_t) p);
|
HOTSPOT_THREAD_UNPARK((uintptr_t) p);
|
||||||
p->unpark();
|
p->unpark();
|
||||||
|
@ -193,11 +193,6 @@ class Thread implements Runnable {
|
|||||||
*/
|
*/
|
||||||
private final long stackSize;
|
private final long stackSize;
|
||||||
|
|
||||||
/*
|
|
||||||
* JVM-private state that persists after native thread termination.
|
|
||||||
*/
|
|
||||||
private long nativeParkEventPointer;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Thread ID
|
* Thread ID
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user