# include "precompiled.hpp" # include "prims/jvmtiEnter.hpp" # include "prims/jvmtiRawMonitor.hpp" # include "prims/jvmtiUtil.hpp" #ifdef JVMTI_TRACE // Error names const char* JvmtiUtil::_error_names[] = { }; // Event threaded const bool JvmtiUtil::_event_threaded[] = { }; jbyte JvmtiTrace::_event_trace_flags[ ]; jint JvmtiTrace::_max_event_index = ; // Event names const char* JvmtiTrace::_event_names[] = { }; #endif /*JVMTI_TRACE */ // names const char* ConstantNames[] = { NULL }; // value jint ConstantValues[] = { 0 }; " ", , // Check Event Capabilities const bool JvmtiUtil::has_event_capability(jvmtiEvent event_type, const jvmtiCapabilities* capabilities_ptr) { switch (event_type) { case : return capabilities_ptr-> != 0; } // if it does not have a capability it is required return JNI_TRUE; } jbyte JvmtiTrace::_trace_flags[ ]; jint JvmtiTrace::_max_function_index = ; // Function names const char* JvmtiTrace::_function_names[] = { }; // Exclude list short JvmtiTrace::_exclude_functions[] = { 0 }; extern "C" { } /* end extern "C" */ // JVMTI API functions struct jvmtiInterface_1_ jvmti _Interface = { }; jvmti _ /* : */ RESERVED */ NULL , " " NULL , false true false , , // // functions // if (this_thread == NULL || !this_thread->is_Java_thread()) { if (this_thread == NULL || (!this_thread->is_Java_thread() && !this_thread->is_VM_thread())) { if (!this_thread->is_Java_thread()) { if (trace_flags) { tty->print_cr("JVMTI [non-attached thread] %s %s", func_name, JvmtiUtil::error_name(JVMTI_ERROR_UNATTACHED_THREAD)); } return JVMTI_ERROR_UNATTACHED_THREAD; } JavaThread* current_thread = (JavaThread*)this_thread; ThreadInVMfromNative __tiv(current_thread); VM_ENTRY_BASE(jvmtiError, , current_thread) debug_only(VMNativeEntryWrapper __vew;) CautiouslyPreserveExceptionMark __em(this_thread); if (jvmti_env->get_capabilities()-> == 0) { if (trace_flags) { tty->print_cr("JVMTI [%s] %s %s", curr_thread_name, func_name, JvmtiUtil::error_name(JVMTI_ERROR_MUST_POSSESS_CAPABILITY)); } return JVMTI_ERROR_MUST_POSSESS_CAPABILITY; } static jvmtiError JNICALL (jvmtiEnv* env ) { #ifdef JVMTI_KERNEL return JVMTI_ERROR_NOT_AVAILABLE; #else if(!JvmtiEnv::is_vm_live()) { if (trace_flags) { tty->print_cr("JVMTI [-] %s %s", func_name, JvmtiUtil::error_name(JVMTI_ERROR_WRONG_PHASE)); } return JVMTI_ERROR_WRONG_PHASE; } Thread* this_thread = (Thread*)ThreadLocalStorage::thread(); if(JvmtiEnv::get_phase()!=JVMTI_PHASE_ONLOAD && JvmtiEnv::get_phase()!=JVMTI_PHASE_LIVE ) { if (trace_flags) { tty->print_cr("JVMTI [-] %s %s", func_name, JvmtiUtil::error_name(JVMTI_ERROR_WRONG_PHASE)); } return JVMTI_ERROR_WRONG_PHASE; } if(JvmtiEnv::get_phase()!=JVMTI_PHASE_START && JvmtiEnv::get_phase()!=JVMTI_PHASE_LIVE) { if (trace_flags) { tty->print_cr("JVMTI [-] %s %s", func_name, JvmtiUtil::error_name(JVMTI_ERROR_WRONG_PHASE)); } return JVMTI_ERROR_WRONG_PHASE; } Thread* this_thread = (Thread*)ThreadLocalStorage::thread(); JvmtiEnv* jvmti_env = JvmtiEnv::JvmtiEnv_from_jvmti_env(env); if (!jvmti_env->is_valid()) { if (trace_flags) { tty->print_cr("JVMTI [%s] %s %s env=%d", curr_thread_name, func_name, JvmtiUtil::error_name(JVMTI_ERROR_INVALID_ENVIRONMENT), env); } return JVMTI_ERROR_INVALID_ENVIRONMENT; } jvmtiError err; if (Threads::number_of_threads() != 0) { Thread* this_thread = (Thread*)ThreadLocalStorage::thread(); Thread* this_thread = NULL; bool transition; if (Threads::number_of_threads() == 0) { transition = false; } else { this_thread = (Thread*)ThreadLocalStorage::thread(); transition = ((this_thread != NULL) && !this_thread->is_VM_thread() && !this_thread->is_ConcurrentGC_thread()); } if (transition) { } else { } return err; #endif // JVMTI_KERNEL } err = jvmti_env-> ( ); SafeResourceMark rm; jint trace_flags = JvmtiTrace::trace_flags( ); const char *func_name; const char *curr_thread_name; if (trace_flags) { func_name = JvmtiTrace::function_name( ); curr_thread_name = JvmtiTrace::safe_get_current_thread_name(); } if ((trace_flags & JvmtiTrace::SHOW_IN) != 0) { } if ((trace_flags & JvmtiTrace::SHOW_ERROR) != 0) { if ((trace_flags & JvmtiTrace::SHOW_IN) == 0) { } tty->print_cr("JVMTI [%s] %s } %s - erroneous arg is ", curr_thread_name, func_name, JvmtiUtil::error_name( ) ); } return ; if ( err != JVMTI_ERROR_NONE && (trace_flags & JvmtiTrace::SHOW_ERROR) != 0) { if ((trace_flags & JvmtiTrace::SHOW_IN) == 0) { } tty->print_cr("JVMTI [%s] %s } %s", curr_thread_name, func_name, JvmtiUtil::error_name(err)); } else if ((trace_flags & JvmtiTrace::SHOW_OUT) != 0) { tty->print_cr("JVMTI [%s] %s }", curr_thread_name, func_name); } tty->print_cr("JVMTI [%s] %s { ", curr_thread_name, func_name ); if ( == NULL) { JVMTI_ERROR_NULL_POINTER } JvmtiRawMonitor *rmonitor = (JvmtiRawMonitor *) ; if (rmonitor == NULL) { JVMTI_ERROR_INVALID_MONITOR - raw monitor is NULL } if (!rmonitor->is_valid()) { JVMTI_ERROR_INVALID_MONITOR - not a raw monitor 0x%x , rmonitor } oop thread_oop = JNIHandles::resolve_external_guard( ); if (thread_oop == NULL) { JVMTI_ERROR_INVALID_THREAD - jthread resolved to NULL - jthread = %0x%x , } if (!thread_oop->is_a(SystemDictionary::Thread_klass())) { JVMTI_ERROR_INVALID_THREAD - oop is not a thread - jthread = %0x%x , } java_thread = java_lang_Thread::thread(thread_oop); if (java_thread == NULL) { JVMTI_ERROR_THREAD_NOT_ALIVE - not a Java thread - jthread = %0x%x , } JavaThread* java_thread; if ( == NULL) { java_thread = current_thread; } else { } if (depth < 0) { JVMTI_ERROR_ILLEGAL_ARGUMENT - negative depth - jthread = %0x%x , } oop k_mirror = JNIHandles::resolve_external_guard( ); if (k_mirror == NULL) { JVMTI_ERROR_INVALID_CLASS - resolved to NULL - jclass = 0x%x , } if (!k_mirror->is_a(SystemDictionary::Class_klass())) { JVMTI_ERROR_INVALID_CLASS - not a class - jclass = 0x%x , } if (java_lang_Class::is_primitive(k_mirror)) { JVMTI_ERROR_INVALID_CLASS - is a primitive class - jclass = 0x%x , } klassOop k_oop = java_lang_Class::as_klassOop(k_mirror); if (k_oop == NULL) { JVMTI_ERROR_INVALID_CLASS - no klassOop - jclass = 0x%x , } methodOop method_oop = JNIHandles::checked_resolve_jmethod_id( ); if (method_oop == NULL) { JVMTI_ERROR_INVALID_METHODID } if (method_oop->is_native()) { return JVMTI_ERROR_NATIVE_METHOD; } ResourceMark rm_fdesc(current_thread); fieldDescriptor fdesc; if (!JvmtiEnv::get_field_descriptor(k_oop, , &fdesc)) { JVMTI_ERROR_INVALID_FIELDID } if ( < ) { JVMTI_ERROR_ILLEGAL_ARGUMENT } ='%s' =0x%x , =0x%x , =0x%x , =%s =%s , rmonitor->get_name() =%s , JvmtiTrace::safe_get_thread_name(java_thread) depth=%d , , JvmtiTrace::get_class_name(k_mirror) =%s.%s , method_oop == NULL? "NULL" : method_oop->klass_name()->as_C_string(), method_oop == NULL? "NULL" : method_oop->name()->as_C_string() , fdesc.name()->as_C_string() =%d:%s , , JvmtiUtil::error_name( ) JvmtiTrace::event_name( ) JvmtiTrace::enum_name( ConstantNames, ConstantValues, ) =%d =%ld =0x%zx =%f =%c =0x%x , =%s , ? "true" : "false"