diff --git a/src/hotspot/share/gc/shared/memAllocator.cpp b/src/hotspot/share/gc/shared/memAllocator.cpp index ca842f73f7f..650a785a681 100644 --- a/src/hotspot/share/gc/shared/memAllocator.cpp +++ b/src/hotspot/share/gc/shared/memAllocator.cpp @@ -56,11 +56,11 @@ class MemAllocator::Allocation: StackObj { bool check_out_of_memory(); void verify_before(); void verify_after(); - void notify_allocation(); + void notify_allocation(JavaThread* thread); void notify_allocation_jvmti_sampler(); void notify_allocation_low_memory_detector(); 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; #ifdef ASSERT void check_for_valid_allocation_state() const; @@ -84,7 +84,7 @@ public: ~Allocation() { if (!check_out_of_memory()) { 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) { // support for Dtrace object alloc event (no-op most of the time) Klass* klass = obj()->klass(); size_t word_size = _allocator._word_size; 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_jfr_sampler(); - notify_allocation_dtrace_sampler(); + notify_allocation_dtrace_sampler(thread); notify_allocation_jvmti_sampler(); } diff --git a/src/hotspot/share/opto/macro.cpp b/src/hotspot/share/opto/macro.cpp index 6cead533cc5..c5a53acf555 100644 --- a/src/hotspot/share/opto/macro.cpp +++ b/src/hotspot/share/opto/macro.cpp @@ -1626,7 +1626,7 @@ void PhaseMacroExpand::expand_dtrace_alloc_probe(AllocateNode* alloc, Node* oop, int size = TypeFunc::Parms + 2; CallLeafNode *call = new CallLeafNode(OptoRuntime::dtrace_object_alloc_Type(), CAST_FROM_FN_PTR(address, - static_cast(SharedRuntime::dtrace_object_alloc)), + static_cast(SharedRuntime::dtrace_object_alloc)), "dtrace_object_alloc", TypeRawPtr::BOTTOM); diff --git a/src/hotspot/share/runtime/sharedRuntime.cpp b/src/hotspot/share/runtime/sharedRuntime.cpp index 0fcd3c952c0..eb69f130e0b 100644 --- a/src/hotspot/share/runtime/sharedRuntime.cpp +++ b/src/hotspot/share/runtime/sharedRuntime.cpp @@ -996,15 +996,15 @@ JRT_ENTRY_NO_ASYNC(void, SharedRuntime::register_finalizer(JavaThread* current, InstanceKlass::register_finalizer(instanceOop(obj), CHECK); JRT_END -jlong SharedRuntime::get_java_tid(Thread* thread) { - if (thread != NULL && thread->is_Java_thread()) { - Thread* current = Thread::current(); - guarantee(current != thread || JavaThread::cast(thread)->is_oop_safe(), - "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); +jlong SharedRuntime::get_java_tid(JavaThread* thread) { + assert(thread != NULL, "No thread"); + if (thread == NULL) { + return 0; } - 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. */ 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()); } -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"); Klass* klass = o->klass(); Symbol* name = klass->name(); diff --git a/src/hotspot/share/runtime/sharedRuntime.hpp b/src/hotspot/share/runtime/sharedRuntime.hpp index 26f0d4c2db7..6ba3d6830ea 100644 --- a/src/hotspot/share/runtime/sharedRuntime.hpp +++ b/src/hotspot/share/runtime/sharedRuntime.hpp @@ -277,14 +277,14 @@ class SharedRuntime: AllStatic { // dtrace notifications static int dtrace_object_alloc(oopDesc* o); - static int dtrace_object_alloc(Thread* thread, oopDesc* o); - static int dtrace_object_alloc(Thread* thread, oopDesc* o, size_t size); + static int dtrace_object_alloc(JavaThread* thread, oopDesc* o); + 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_exit(JavaThread* thread, Method* m); // Utility method for retrieving the Java thread id, returns 0 if the // 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 diff --git a/src/hotspot/share/runtime/synchronizer.cpp b/src/hotspot/share/runtime/synchronizer.cpp index f2cc1dc4927..4e703ff44aa 100644 --- a/src/hotspot/share/runtime/synchronizer.cpp +++ b/src/hotspot/share/runtime/synchronizer.cpp @@ -240,7 +240,7 @@ ObjectMonitor* MonitorList::Iterator::next() { #endif // ndef DTRACE_ENABLED // 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); return 0; }