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();
|
||||
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();
|
||||
}
|
||||
|
||||
|
@ -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<int (*)(Thread*, oopDesc*)>(SharedRuntime::dtrace_object_alloc)),
|
||||
static_cast<int (*)(JavaThread*, oopDesc*)>(SharedRuntime::dtrace_object_alloc)),
|
||||
"dtrace_object_alloc",
|
||||
TypeRawPtr::BOTTOM);
|
||||
|
||||
|
@ -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;
|
||||
}
|
||||
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();
|
||||
|
@ -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
|
||||
|
@ -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;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user