8289004: investigate if SharedRuntime::get_java_tid parameter should be a JavaThread*
Reviewed-by: dholmes, jsjolen
This commit is contained in:
parent
b9eeec2b6b
commit
979efd4174
@ -56,11 +56,11 @@ class MemAllocator::Allocation: StackObj {
|
|||||||
bool check_out_of_memory();
|
bool check_out_of_memory();
|
||||||
void verify_before();
|
void verify_before();
|
||||||
void verify_after();
|
void verify_after();
|
||||||
void notify_allocation();
|
void notify_allocation(JavaThread* thread);
|
||||||
void notify_allocation_jvmti_sampler();
|
void notify_allocation_jvmti_sampler();
|
||||||
void notify_allocation_low_memory_detector();
|
void notify_allocation_low_memory_detector();
|
||||||
void notify_allocation_jfr_sampler();
|
void notify_allocation_jfr_sampler();
|
||||||
void notify_allocation_dtrace_sampler();
|
void notify_allocation_dtrace_sampler(JavaThread* thread);
|
||||||
void check_for_bad_heap_word_value() const;
|
void check_for_bad_heap_word_value() const;
|
||||||
#ifdef ASSERT
|
#ifdef ASSERT
|
||||||
void check_for_valid_allocation_state() const;
|
void check_for_valid_allocation_state() const;
|
||||||
@ -84,7 +84,7 @@ public:
|
|||||||
~Allocation() {
|
~Allocation() {
|
||||||
if (!check_out_of_memory()) {
|
if (!check_out_of_memory()) {
|
||||||
verify_after();
|
verify_after();
|
||||||
notify_allocation();
|
notify_allocation(_thread);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -235,21 +235,21 @@ void MemAllocator::Allocation::notify_allocation_jfr_sampler() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MemAllocator::Allocation::notify_allocation_dtrace_sampler() {
|
void MemAllocator::Allocation::notify_allocation_dtrace_sampler(JavaThread* thread) {
|
||||||
if (DTraceAllocProbes) {
|
if (DTraceAllocProbes) {
|
||||||
// support for Dtrace object alloc event (no-op most of the time)
|
// support for Dtrace object alloc event (no-op most of the time)
|
||||||
Klass* klass = obj()->klass();
|
Klass* klass = obj()->klass();
|
||||||
size_t word_size = _allocator._word_size;
|
size_t word_size = _allocator._word_size;
|
||||||
if (klass != NULL && klass->name() != NULL) {
|
if (klass != NULL && klass->name() != NULL) {
|
||||||
SharedRuntime::dtrace_object_alloc(Thread::current(), obj(), word_size);
|
SharedRuntime::dtrace_object_alloc(thread, obj(), word_size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void MemAllocator::Allocation::notify_allocation() {
|
void MemAllocator::Allocation::notify_allocation(JavaThread* thread) {
|
||||||
notify_allocation_low_memory_detector();
|
notify_allocation_low_memory_detector();
|
||||||
notify_allocation_jfr_sampler();
|
notify_allocation_jfr_sampler();
|
||||||
notify_allocation_dtrace_sampler();
|
notify_allocation_dtrace_sampler(thread);
|
||||||
notify_allocation_jvmti_sampler();
|
notify_allocation_jvmti_sampler();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1626,7 +1626,7 @@ void PhaseMacroExpand::expand_dtrace_alloc_probe(AllocateNode* alloc, Node* oop,
|
|||||||
int size = TypeFunc::Parms + 2;
|
int size = TypeFunc::Parms + 2;
|
||||||
CallLeafNode *call = new CallLeafNode(OptoRuntime::dtrace_object_alloc_Type(),
|
CallLeafNode *call = new CallLeafNode(OptoRuntime::dtrace_object_alloc_Type(),
|
||||||
CAST_FROM_FN_PTR(address,
|
CAST_FROM_FN_PTR(address,
|
||||||
static_cast<int (*)(Thread*, oopDesc*)>(SharedRuntime::dtrace_object_alloc)),
|
static_cast<int (*)(JavaThread*, oopDesc*)>(SharedRuntime::dtrace_object_alloc)),
|
||||||
"dtrace_object_alloc",
|
"dtrace_object_alloc",
|
||||||
TypeRawPtr::BOTTOM);
|
TypeRawPtr::BOTTOM);
|
||||||
|
|
||||||
|
@ -996,15 +996,15 @@ JRT_ENTRY_NO_ASYNC(void, SharedRuntime::register_finalizer(JavaThread* current,
|
|||||||
InstanceKlass::register_finalizer(instanceOop(obj), CHECK);
|
InstanceKlass::register_finalizer(instanceOop(obj), CHECK);
|
||||||
JRT_END
|
JRT_END
|
||||||
|
|
||||||
jlong SharedRuntime::get_java_tid(Thread* thread) {
|
jlong SharedRuntime::get_java_tid(JavaThread* thread) {
|
||||||
if (thread != NULL && thread->is_Java_thread()) {
|
assert(thread != NULL, "No thread");
|
||||||
Thread* current = Thread::current();
|
if (thread == NULL) {
|
||||||
guarantee(current != thread || JavaThread::cast(thread)->is_oop_safe(),
|
return 0;
|
||||||
"current cannot touch oops after its GC barrier is detached.");
|
|
||||||
oop obj = JavaThread::cast(thread)->threadObj();
|
|
||||||
return (obj == NULL) ? 0 : java_lang_Thread::thread_id(obj);
|
|
||||||
}
|
}
|
||||||
return 0;
|
guarantee(Thread::current() != thread || thread->is_oop_safe(),
|
||||||
|
"current cannot touch oops after its GC barrier is detached.");
|
||||||
|
oop obj = thread->threadObj();
|
||||||
|
return (obj == NULL) ? 0 : java_lang_Thread::thread_id(obj);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1013,14 +1013,14 @@ jlong SharedRuntime::get_java_tid(Thread* thread) {
|
|||||||
* 6254741. Once that is fixed we can remove the dummy return value.
|
* 6254741. Once that is fixed we can remove the dummy return value.
|
||||||
*/
|
*/
|
||||||
int SharedRuntime::dtrace_object_alloc(oopDesc* o) {
|
int SharedRuntime::dtrace_object_alloc(oopDesc* o) {
|
||||||
return dtrace_object_alloc(Thread::current(), o, o->size());
|
return dtrace_object_alloc(JavaThread::current(), o, o->size());
|
||||||
}
|
}
|
||||||
|
|
||||||
int SharedRuntime::dtrace_object_alloc(Thread* thread, oopDesc* o) {
|
int SharedRuntime::dtrace_object_alloc(JavaThread* thread, oopDesc* o) {
|
||||||
return dtrace_object_alloc(thread, o, o->size());
|
return dtrace_object_alloc(thread, o, o->size());
|
||||||
}
|
}
|
||||||
|
|
||||||
int SharedRuntime::dtrace_object_alloc(Thread* thread, oopDesc* o, size_t size) {
|
int SharedRuntime::dtrace_object_alloc(JavaThread* thread, oopDesc* o, size_t size) {
|
||||||
assert(DTraceAllocProbes, "wrong call");
|
assert(DTraceAllocProbes, "wrong call");
|
||||||
Klass* klass = o->klass();
|
Klass* klass = o->klass();
|
||||||
Symbol* name = klass->name();
|
Symbol* name = klass->name();
|
||||||
|
@ -277,14 +277,14 @@ class SharedRuntime: AllStatic {
|
|||||||
|
|
||||||
// dtrace notifications
|
// dtrace notifications
|
||||||
static int dtrace_object_alloc(oopDesc* o);
|
static int dtrace_object_alloc(oopDesc* o);
|
||||||
static int dtrace_object_alloc(Thread* thread, oopDesc* o);
|
static int dtrace_object_alloc(JavaThread* thread, oopDesc* o);
|
||||||
static int dtrace_object_alloc(Thread* thread, oopDesc* o, size_t size);
|
static int dtrace_object_alloc(JavaThread* thread, oopDesc* o, size_t size);
|
||||||
static int dtrace_method_entry(JavaThread* thread, Method* m);
|
static int dtrace_method_entry(JavaThread* thread, Method* m);
|
||||||
static int dtrace_method_exit(JavaThread* thread, Method* m);
|
static int dtrace_method_exit(JavaThread* thread, Method* m);
|
||||||
|
|
||||||
// Utility method for retrieving the Java thread id, returns 0 if the
|
// Utility method for retrieving the Java thread id, returns 0 if the
|
||||||
// thread is not a well formed Java thread.
|
// thread is not a well formed Java thread.
|
||||||
static jlong get_java_tid(Thread* thread);
|
static jlong get_java_tid(JavaThread* thread);
|
||||||
|
|
||||||
|
|
||||||
// used by native wrappers to re-enable yellow if overflow happened in native code
|
// used by native wrappers to re-enable yellow if overflow happened in native code
|
||||||
|
@ -240,7 +240,7 @@ ObjectMonitor* MonitorList::Iterator::next() {
|
|||||||
#endif // ndef DTRACE_ENABLED
|
#endif // ndef DTRACE_ENABLED
|
||||||
|
|
||||||
// This exists only as a workaround of dtrace bug 6254741
|
// This exists only as a workaround of dtrace bug 6254741
|
||||||
int dtrace_waited_probe(ObjectMonitor* monitor, Handle obj, Thread* thr) {
|
int dtrace_waited_probe(ObjectMonitor* monitor, Handle obj, JavaThread* thr) {
|
||||||
DTRACE_MONITOR_PROBE(waited, monitor, obj(), thr);
|
DTRACE_MONITOR_PROBE(waited, monitor, obj(), thr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user