2007-12-01 00:00:00 +00:00
|
|
|
/*
|
2018-03-01 16:51:22 -05:00
|
|
|
* Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved.
|
2007-12-01 00:00:00 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
2010-05-27 19:08:38 -07:00
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
2007-12-01 00:00:00 +00:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2010-11-23 13:22:55 -08:00
|
|
|
#include "precompiled.hpp"
|
|
|
|
#include "classfile/systemDictionary.hpp"
|
|
|
|
#include "code/nmethod.hpp"
|
|
|
|
#include "code/pcDesc.hpp"
|
|
|
|
#include "code/scopeDesc.hpp"
|
|
|
|
#include "interpreter/interpreter.hpp"
|
|
|
|
#include "jvmtifiles/jvmtiEnv.hpp"
|
2016-04-19 14:14:04 +02:00
|
|
|
#include "logging/log.hpp"
|
|
|
|
#include "logging/logStream.hpp"
|
2018-03-08 09:56:29 +01:00
|
|
|
#include "memory/allocation.inline.hpp"
|
2010-11-23 13:22:55 -08:00
|
|
|
#include "memory/resourceArea.hpp"
|
|
|
|
#include "oops/objArrayKlass.hpp"
|
|
|
|
#include "oops/objArrayOop.hpp"
|
2015-02-13 14:37:35 +01:00
|
|
|
#include "oops/oop.inline.hpp"
|
2010-11-23 13:22:55 -08:00
|
|
|
#include "prims/jvmtiCodeBlobEvents.hpp"
|
|
|
|
#include "prims/jvmtiEventController.hpp"
|
|
|
|
#include "prims/jvmtiEventController.inline.hpp"
|
|
|
|
#include "prims/jvmtiExport.hpp"
|
|
|
|
#include "prims/jvmtiImpl.hpp"
|
|
|
|
#include "prims/jvmtiManageCapabilities.hpp"
|
|
|
|
#include "prims/jvmtiRawMonitor.hpp"
|
2015-05-13 15:16:06 +02:00
|
|
|
#include "prims/jvmtiRedefineClasses.hpp"
|
2010-11-23 13:22:55 -08:00
|
|
|
#include "prims/jvmtiTagMap.hpp"
|
|
|
|
#include "prims/jvmtiThreadState.inline.hpp"
|
|
|
|
#include "runtime/arguments.hpp"
|
|
|
|
#include "runtime/handles.hpp"
|
2018-03-16 09:12:13 -04:00
|
|
|
#include "runtime/interfaceSupport.inline.hpp"
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
#include "runtime/javaCalls.hpp"
|
2018-03-01 16:51:22 -05:00
|
|
|
#include "runtime/jniHandles.inline.hpp"
|
2010-11-23 13:22:55 -08:00
|
|
|
#include "runtime/objectMonitor.hpp"
|
|
|
|
#include "runtime/objectMonitor.inline.hpp"
|
2014-06-26 16:05:15 +02:00
|
|
|
#include "runtime/os.inline.hpp"
|
2018-03-23 18:54:12 +01:00
|
|
|
#include "runtime/safepointVerifiers.hpp"
|
2014-04-29 15:17:27 +02:00
|
|
|
#include "runtime/thread.inline.hpp"
|
2017-11-22 17:54:50 -08:00
|
|
|
#include "runtime/threadSMR.hpp"
|
2018-03-21 19:45:24 -04:00
|
|
|
#include "runtime/vframe.inline.hpp"
|
2013-01-23 13:02:39 -05:00
|
|
|
#include "utilities/macros.hpp"
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
#ifdef JVMTI_TRACE
|
2016-04-19 14:14:04 +02:00
|
|
|
#define EVT_TRACE(evt,out) if ((JvmtiTrace::event_trace_flags(evt) & JvmtiTrace::SHOW_EVENT_SENT) != 0) { SafeResourceMark rm; log_trace(jvmti) out; }
|
|
|
|
#define EVT_TRIG_TRACE(evt,out) if ((JvmtiTrace::event_trace_flags(evt) & JvmtiTrace::SHOW_EVENT_TRIGGER) != 0) { SafeResourceMark rm; log_trace(jvmti) out; }
|
2007-12-01 00:00:00 +00:00
|
|
|
#else
|
|
|
|
#define EVT_TRIG_TRACE(evt,out)
|
|
|
|
#define EVT_TRACE(evt,out)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// JvmtiEventTransition
|
|
|
|
//
|
|
|
|
// TO DO --
|
|
|
|
// more handle purging
|
|
|
|
|
|
|
|
// Use this for JavaThreads and state is _thread_in_vm.
|
|
|
|
class JvmtiJavaThreadEventTransition : StackObj {
|
|
|
|
private:
|
|
|
|
ResourceMark _rm;
|
|
|
|
ThreadToNativeFromVM _transition;
|
|
|
|
HandleMark _hm;
|
|
|
|
|
|
|
|
public:
|
|
|
|
JvmtiJavaThreadEventTransition(JavaThread *thread) :
|
|
|
|
_rm(),
|
|
|
|
_transition(thread),
|
|
|
|
_hm(thread) {};
|
|
|
|
};
|
|
|
|
|
|
|
|
// For JavaThreads which are not in _thread_in_vm state
|
|
|
|
// and other system threads use this.
|
|
|
|
class JvmtiThreadEventTransition : StackObj {
|
|
|
|
private:
|
|
|
|
ResourceMark _rm;
|
|
|
|
HandleMark _hm;
|
|
|
|
JavaThreadState _saved_state;
|
|
|
|
JavaThread *_jthread;
|
|
|
|
|
|
|
|
public:
|
|
|
|
JvmtiThreadEventTransition(Thread *thread) : _rm(), _hm() {
|
|
|
|
if (thread->is_Java_thread()) {
|
|
|
|
_jthread = (JavaThread *)thread;
|
|
|
|
_saved_state = _jthread->thread_state();
|
|
|
|
if (_saved_state == _thread_in_Java) {
|
|
|
|
ThreadStateTransition::transition_from_java(_jthread, _thread_in_native);
|
|
|
|
} else {
|
|
|
|
ThreadStateTransition::transition(_jthread, _saved_state, _thread_in_native);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
_jthread = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
~JvmtiThreadEventTransition() {
|
|
|
|
if (_jthread != NULL)
|
|
|
|
ThreadStateTransition::transition_from_native(_jthread, _saved_state);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// JvmtiEventMark
|
|
|
|
//
|
|
|
|
|
|
|
|
class JvmtiEventMark : public StackObj {
|
|
|
|
private:
|
|
|
|
JavaThread *_thread;
|
|
|
|
JNIEnv* _jni_env;
|
2016-12-20 15:40:01 +03:00
|
|
|
JvmtiThreadState::ExceptionState _saved_exception_state;
|
2007-12-01 00:00:00 +00:00
|
|
|
#if 0
|
|
|
|
JNIHandleBlock* _hblock;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
public:
|
|
|
|
JvmtiEventMark(JavaThread *thread) : _thread(thread),
|
2016-12-20 15:40:01 +03:00
|
|
|
_jni_env(thread->jni_environment()),
|
|
|
|
_saved_exception_state(JvmtiThreadState::ES_CLEARED) {
|
2007-12-01 00:00:00 +00:00
|
|
|
#if 0
|
|
|
|
_hblock = thread->active_handles();
|
|
|
|
_hblock->clear_thoroughly(); // so we can be safe
|
|
|
|
#else
|
|
|
|
// we want to use the code above - but that needs the JNIHandle changes - later...
|
|
|
|
// for now, steal JNI push local frame code
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
// we are before an event.
|
|
|
|
// Save current jvmti thread exception state.
|
|
|
|
if (state != NULL) {
|
2016-12-20 15:40:01 +03:00
|
|
|
_saved_exception_state = state->get_exception_state();
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
JNIHandleBlock* old_handles = thread->active_handles();
|
|
|
|
JNIHandleBlock* new_handles = JNIHandleBlock::allocate_block(thread);
|
|
|
|
assert(new_handles != NULL, "should not be NULL");
|
|
|
|
new_handles->set_pop_frame_link(old_handles);
|
|
|
|
thread->set_active_handles(new_handles);
|
|
|
|
#endif
|
|
|
|
assert(thread == JavaThread::current(), "thread must be current!");
|
|
|
|
thread->frame_anchor()->make_walkable(thread);
|
|
|
|
};
|
|
|
|
|
|
|
|
~JvmtiEventMark() {
|
|
|
|
#if 0
|
|
|
|
_hblock->clear(); // for consistency with future correct behavior
|
|
|
|
#else
|
|
|
|
// we want to use the code above - but that needs the JNIHandle changes - later...
|
|
|
|
// for now, steal JNI pop local frame code
|
|
|
|
JNIHandleBlock* old_handles = _thread->active_handles();
|
|
|
|
JNIHandleBlock* new_handles = old_handles->pop_frame_link();
|
|
|
|
assert(new_handles != NULL, "should not be NULL");
|
|
|
|
_thread->set_active_handles(new_handles);
|
|
|
|
// Note that we set the pop_frame_link to NULL explicitly, otherwise
|
|
|
|
// the release_block call will release the blocks.
|
|
|
|
old_handles->set_pop_frame_link(NULL);
|
|
|
|
JNIHandleBlock::release_block(old_handles, _thread); // may block
|
|
|
|
#endif
|
|
|
|
|
|
|
|
JvmtiThreadState* state = _thread->jvmti_thread_state();
|
|
|
|
// we are continuing after an event.
|
|
|
|
if (state != NULL) {
|
|
|
|
// Restore the jvmti thread exception state.
|
2016-12-20 15:40:01 +03:00
|
|
|
state->restore_exception_state(_saved_exception_state);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
jobject to_jobject(oop obj) { return obj == NULL? NULL : _hblock->allocate_handle_fast(obj); }
|
|
|
|
#else
|
|
|
|
// we want to use the code above - but that needs the JNIHandle changes - later...
|
|
|
|
// for now, use regular make_local
|
|
|
|
jobject to_jobject(oop obj) { return JNIHandles::make_local(_thread,obj); }
|
|
|
|
#endif
|
|
|
|
|
2012-11-12 16:15:05 -05:00
|
|
|
jclass to_jclass(Klass* klass) { return (klass == NULL ? NULL : (jclass)to_jobject(klass->java_mirror())); }
|
2007-12-01 00:00:00 +00:00
|
|
|
|
2017-07-27 18:06:41 -04:00
|
|
|
jmethodID to_jmethodID(const methodHandle& method) { return method->jmethod_id(); }
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JNIEnv* jni_env() { return _jni_env; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class JvmtiThreadEventMark : public JvmtiEventMark {
|
|
|
|
private:
|
|
|
|
jthread _jt;
|
|
|
|
|
|
|
|
public:
|
|
|
|
JvmtiThreadEventMark(JavaThread *thread) :
|
|
|
|
JvmtiEventMark(thread) {
|
|
|
|
_jt = (jthread)(to_jobject(thread->threadObj()));
|
|
|
|
};
|
|
|
|
jthread jni_thread() { return _jt; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class JvmtiClassEventMark : public JvmtiThreadEventMark {
|
|
|
|
private:
|
|
|
|
jclass _jc;
|
|
|
|
|
|
|
|
public:
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
JvmtiClassEventMark(JavaThread *thread, Klass* klass) :
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiThreadEventMark(thread) {
|
|
|
|
_jc = to_jclass(klass);
|
|
|
|
};
|
|
|
|
jclass jni_class() { return _jc; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class JvmtiMethodEventMark : public JvmtiThreadEventMark {
|
|
|
|
private:
|
|
|
|
jmethodID _mid;
|
|
|
|
|
|
|
|
public:
|
2017-07-27 18:06:41 -04:00
|
|
|
JvmtiMethodEventMark(JavaThread *thread, const methodHandle& method) :
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiThreadEventMark(thread),
|
|
|
|
_mid(to_jmethodID(method)) {};
|
|
|
|
jmethodID jni_methodID() { return _mid; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class JvmtiLocationEventMark : public JvmtiMethodEventMark {
|
|
|
|
private:
|
|
|
|
jlocation _loc;
|
|
|
|
|
|
|
|
public:
|
2017-07-27 18:06:41 -04:00
|
|
|
JvmtiLocationEventMark(JavaThread *thread, const methodHandle& method, address location) :
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiMethodEventMark(thread, method),
|
|
|
|
_loc(location - method->code_base()) {};
|
|
|
|
jlocation location() { return _loc; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class JvmtiExceptionEventMark : public JvmtiLocationEventMark {
|
|
|
|
private:
|
|
|
|
jobject _exc;
|
|
|
|
|
|
|
|
public:
|
2017-07-27 18:06:41 -04:00
|
|
|
JvmtiExceptionEventMark(JavaThread *thread, const methodHandle& method, address location, Handle exception) :
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiLocationEventMark(thread, method, location),
|
|
|
|
_exc(to_jobject(exception())) {};
|
|
|
|
jobject exception() { return _exc; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class JvmtiClassFileLoadEventMark : public JvmtiThreadEventMark {
|
|
|
|
private:
|
|
|
|
const char *_class_name;
|
|
|
|
jobject _jloader;
|
|
|
|
jobject _protection_domain;
|
|
|
|
jclass _class_being_redefined;
|
|
|
|
|
|
|
|
public:
|
2011-01-27 16:11:27 -08:00
|
|
|
JvmtiClassFileLoadEventMark(JavaThread *thread, Symbol* name,
|
2017-03-15 10:25:37 -04:00
|
|
|
Handle class_loader, Handle prot_domain, Klass* class_being_redefined) : JvmtiThreadEventMark(thread) {
|
2011-01-27 16:11:27 -08:00
|
|
|
_class_name = name != NULL? name->as_utf8() : NULL;
|
2007-12-01 00:00:00 +00:00
|
|
|
_jloader = (jobject)to_jobject(class_loader());
|
|
|
|
_protection_domain = (jobject)to_jobject(prot_domain());
|
|
|
|
if (class_being_redefined == NULL) {
|
|
|
|
_class_being_redefined = NULL;
|
|
|
|
} else {
|
2017-03-15 10:25:37 -04:00
|
|
|
_class_being_redefined = (jclass)to_jclass(class_being_redefined);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
const char *class_name() {
|
|
|
|
return _class_name;
|
|
|
|
}
|
|
|
|
jobject jloader() {
|
|
|
|
return _jloader;
|
|
|
|
}
|
|
|
|
jobject protection_domain() {
|
|
|
|
return _protection_domain;
|
|
|
|
}
|
|
|
|
jclass class_being_redefined() {
|
|
|
|
return _class_being_redefined;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
int JvmtiExport::_field_access_count = 0;
|
|
|
|
int JvmtiExport::_field_modification_count = 0;
|
|
|
|
|
|
|
|
bool JvmtiExport::_can_access_local_variables = false;
|
|
|
|
bool JvmtiExport::_can_hotswap_or_post_breakpoint = false;
|
|
|
|
bool JvmtiExport::_can_modify_any_class = false;
|
|
|
|
bool JvmtiExport::_can_walk_any_space = false;
|
|
|
|
|
|
|
|
bool JvmtiExport::_has_redefined_a_class = false;
|
|
|
|
bool JvmtiExport::_all_dependencies_are_recorded = false;
|
|
|
|
|
|
|
|
//
|
|
|
|
// field access management
|
|
|
|
//
|
|
|
|
|
|
|
|
// interpreter generator needs the address of the counter
|
|
|
|
address JvmtiExport::get_field_access_count_addr() {
|
|
|
|
// We don't grab a lock because we don't want to
|
|
|
|
// serialize field access between all threads. This means that a
|
|
|
|
// thread on another processor can see the wrong count value and
|
|
|
|
// may either miss making a needed call into post_field_access()
|
|
|
|
// or will make an unneeded call into post_field_access(). We pay
|
|
|
|
// this price to avoid slowing down the VM when we aren't watching
|
|
|
|
// field accesses.
|
|
|
|
// Other access/mutation safe by virtue of being in VM state.
|
|
|
|
return (address)(&_field_access_count);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// field modification management
|
|
|
|
//
|
|
|
|
|
|
|
|
// interpreter generator needs the address of the counter
|
|
|
|
address JvmtiExport::get_field_modification_count_addr() {
|
|
|
|
// We don't grab a lock because we don't
|
|
|
|
// want to serialize field modification between all threads. This
|
|
|
|
// means that a thread on another processor can see the wrong
|
|
|
|
// count value and may either miss making a needed call into
|
|
|
|
// post_field_modification() or will make an unneeded call into
|
|
|
|
// post_field_modification(). We pay this price to avoid slowing
|
|
|
|
// down the VM when we aren't watching field modifications.
|
|
|
|
// Other access/mutation safe by virtue of being in VM state.
|
|
|
|
return (address)(&_field_modification_count);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
// Functions needed by java.lang.instrument for starting up javaagent.
|
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
jint
|
|
|
|
JvmtiExport::get_jvmti_interface(JavaVM *jvm, void **penv, jint version) {
|
2009-12-14 10:05:36 -07:00
|
|
|
// The JVMTI_VERSION_INTERFACE_JVMTI part of the version number
|
|
|
|
// has already been validated in JNI GetEnv().
|
|
|
|
int major, minor, micro;
|
|
|
|
|
|
|
|
// micro version doesn't matter here (yet?)
|
|
|
|
decode_version_values(version, &major, &minor, µ);
|
|
|
|
switch (major) {
|
2010-12-06 20:21:15 -05:00
|
|
|
case 1:
|
2009-12-14 10:05:36 -07:00
|
|
|
switch (minor) {
|
2010-12-06 20:21:15 -05:00
|
|
|
case 0: // version 1.0.<micro> is recognized
|
|
|
|
case 1: // version 1.1.<micro> is recognized
|
|
|
|
case 2: // version 1.2.<micro> is recognized
|
2009-12-14 10:05:36 -07:00
|
|
|
break;
|
|
|
|
|
2010-12-06 20:21:15 -05:00
|
|
|
default:
|
2009-12-14 10:05:36 -07:00
|
|
|
return JNI_EVERSION; // unsupported minor version number
|
|
|
|
}
|
|
|
|
break;
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
case 9:
|
|
|
|
switch (minor) {
|
|
|
|
case 0: // version 9.0.<micro> is recognized
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return JNI_EVERSION; // unsupported minor version number
|
|
|
|
}
|
|
|
|
break;
|
2010-12-06 20:21:15 -05:00
|
|
|
default:
|
2009-12-14 10:05:36 -07:00
|
|
|
return JNI_EVERSION; // unsupported major version number
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
if (JvmtiEnv::get_phase() == JVMTI_PHASE_LIVE) {
|
2015-12-04 04:06:37 -05:00
|
|
|
JavaThread* current_thread = JavaThread::current();
|
2007-12-01 00:00:00 +00:00
|
|
|
// transition code: native to VM
|
|
|
|
ThreadInVMfromNative __tiv(current_thread);
|
2011-10-25 08:17:15 -07:00
|
|
|
VM_ENTRY_BASE(jvmtiEnv*, JvmtiExport::get_jvmti_interface, current_thread)
|
2007-12-01 00:00:00 +00:00
|
|
|
debug_only(VMNativeEntryWrapper __vew;)
|
|
|
|
|
2009-12-14 10:05:36 -07:00
|
|
|
JvmtiEnv *jvmti_env = JvmtiEnv::create_a_jvmti(version);
|
2007-12-01 00:00:00 +00:00
|
|
|
*penv = jvmti_env->jvmti_external(); // actual type is jvmtiEnv* -- not to be confused with JvmtiEnv*
|
|
|
|
return JNI_OK;
|
|
|
|
|
|
|
|
} else if (JvmtiEnv::get_phase() == JVMTI_PHASE_ONLOAD) {
|
|
|
|
// not live, no thread to transition
|
2009-12-14 10:05:36 -07:00
|
|
|
JvmtiEnv *jvmti_env = JvmtiEnv::create_a_jvmti(version);
|
2007-12-01 00:00:00 +00:00
|
|
|
*penv = jvmti_env->jvmti_external(); // actual type is jvmtiEnv* -- not to be confused with JvmtiEnv*
|
|
|
|
return JNI_OK;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
// Called at the wrong time
|
|
|
|
*penv = NULL;
|
|
|
|
return JNI_EDETACHED;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
void
|
|
|
|
JvmtiExport::add_default_read_edges(Handle h_module, TRAPS) {
|
|
|
|
if (!Universe::is_module_initialized()) {
|
|
|
|
return; // extra safety
|
|
|
|
}
|
|
|
|
assert(!h_module.is_null(), "module should always be set");
|
|
|
|
|
|
|
|
// Invoke the transformedByAgent method
|
|
|
|
JavaValue result(T_VOID);
|
|
|
|
JavaCalls::call_static(&result,
|
|
|
|
SystemDictionary::module_Modules_klass(),
|
|
|
|
vmSymbols::transformedByAgent_name(),
|
|
|
|
vmSymbols::transformedByAgent_signature(),
|
|
|
|
h_module,
|
|
|
|
THREAD);
|
|
|
|
|
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
2016-04-19 14:14:04 +02:00
|
|
|
LogTarget(Trace, jvmti) log;
|
2017-07-21 09:50:12 +02:00
|
|
|
LogStream log_stream(log);
|
2016-04-19 14:14:04 +02:00
|
|
|
java_lang_Throwable::print(PENDING_EXCEPTION, &log_stream);
|
2016-04-20 10:01:25 +02:00
|
|
|
log_stream.cr();
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2009-12-14 10:05:36 -07:00
|
|
|
|
2016-12-01 08:56:41 +00:00
|
|
|
jvmtiError
|
|
|
|
JvmtiExport::add_module_reads(Handle module, Handle to_module, TRAPS) {
|
|
|
|
if (!Universe::is_module_initialized()) {
|
|
|
|
return JVMTI_ERROR_NONE; // extra safety
|
|
|
|
}
|
|
|
|
assert(!module.is_null(), "module should always be set");
|
|
|
|
assert(!to_module.is_null(), "to_module should always be set");
|
|
|
|
|
|
|
|
// Invoke the addReads method
|
|
|
|
JavaValue result(T_VOID);
|
|
|
|
JavaCalls::call_static(&result,
|
|
|
|
SystemDictionary::module_Modules_klass(),
|
|
|
|
vmSymbols::addReads_name(),
|
|
|
|
vmSymbols::addReads_signature(),
|
|
|
|
module,
|
|
|
|
to_module,
|
|
|
|
THREAD);
|
|
|
|
|
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
|
|
|
LogTarget(Trace, jvmti) log;
|
2017-07-21 09:50:12 +02:00
|
|
|
LogStream log_stream(log);
|
2016-12-01 08:56:41 +00:00
|
|
|
java_lang_Throwable::print(PENDING_EXCEPTION, &log_stream);
|
|
|
|
log_stream.cr();
|
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
return JVMTI_ERROR_INTERNAL;
|
|
|
|
}
|
|
|
|
return JVMTI_ERROR_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
jvmtiError
|
|
|
|
JvmtiExport::add_module_exports(Handle module, Handle pkg_name, Handle to_module, TRAPS) {
|
|
|
|
if (!Universe::is_module_initialized()) {
|
|
|
|
return JVMTI_ERROR_NONE; // extra safety
|
|
|
|
}
|
|
|
|
assert(!module.is_null(), "module should always be set");
|
|
|
|
assert(!to_module.is_null(), "to_module should always be set");
|
|
|
|
assert(!pkg_name.is_null(), "pkg_name should always be set");
|
|
|
|
|
|
|
|
// Invoke the addExports method
|
|
|
|
JavaValue result(T_VOID);
|
|
|
|
JavaCalls::call_static(&result,
|
|
|
|
SystemDictionary::module_Modules_klass(),
|
|
|
|
vmSymbols::addExports_name(),
|
|
|
|
vmSymbols::addExports_signature(),
|
|
|
|
module,
|
|
|
|
pkg_name,
|
|
|
|
to_module,
|
|
|
|
THREAD);
|
|
|
|
|
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
|
|
|
Symbol* ex_name = PENDING_EXCEPTION->klass()->name();
|
|
|
|
LogTarget(Trace, jvmti) log;
|
2017-07-21 09:50:12 +02:00
|
|
|
LogStream log_stream(log);
|
2016-12-01 08:56:41 +00:00
|
|
|
java_lang_Throwable::print(PENDING_EXCEPTION, &log_stream);
|
|
|
|
log_stream.cr();
|
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
if (ex_name == vmSymbols::java_lang_IllegalArgumentException()) {
|
|
|
|
return JVMTI_ERROR_ILLEGAL_ARGUMENT;
|
|
|
|
}
|
|
|
|
return JVMTI_ERROR_INTERNAL;
|
|
|
|
}
|
|
|
|
return JVMTI_ERROR_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
jvmtiError
|
|
|
|
JvmtiExport::add_module_opens(Handle module, Handle pkg_name, Handle to_module, TRAPS) {
|
|
|
|
if (!Universe::is_module_initialized()) {
|
|
|
|
return JVMTI_ERROR_NONE; // extra safety
|
|
|
|
}
|
|
|
|
assert(!module.is_null(), "module should always be set");
|
|
|
|
assert(!to_module.is_null(), "to_module should always be set");
|
|
|
|
assert(!pkg_name.is_null(), "pkg_name should always be set");
|
|
|
|
|
|
|
|
// Invoke the addOpens method
|
|
|
|
JavaValue result(T_VOID);
|
|
|
|
JavaCalls::call_static(&result,
|
|
|
|
SystemDictionary::module_Modules_klass(),
|
|
|
|
vmSymbols::addOpens_name(),
|
|
|
|
vmSymbols::addExports_signature(),
|
|
|
|
module,
|
|
|
|
pkg_name,
|
|
|
|
to_module,
|
|
|
|
THREAD);
|
|
|
|
|
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
|
|
|
Symbol* ex_name = PENDING_EXCEPTION->klass()->name();
|
|
|
|
LogTarget(Trace, jvmti) log;
|
2017-07-21 09:50:12 +02:00
|
|
|
LogStream log_stream(log);
|
2016-12-01 08:56:41 +00:00
|
|
|
java_lang_Throwable::print(PENDING_EXCEPTION, &log_stream);
|
|
|
|
log_stream.cr();
|
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
if (ex_name == vmSymbols::java_lang_IllegalArgumentException()) {
|
|
|
|
return JVMTI_ERROR_ILLEGAL_ARGUMENT;
|
|
|
|
}
|
|
|
|
return JVMTI_ERROR_INTERNAL;
|
|
|
|
}
|
|
|
|
return JVMTI_ERROR_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
jvmtiError
|
|
|
|
JvmtiExport::add_module_uses(Handle module, Handle service, TRAPS) {
|
|
|
|
if (!Universe::is_module_initialized()) {
|
|
|
|
return JVMTI_ERROR_NONE; // extra safety
|
|
|
|
}
|
|
|
|
assert(!module.is_null(), "module should always be set");
|
|
|
|
assert(!service.is_null(), "service should always be set");
|
|
|
|
|
|
|
|
// Invoke the addUses method
|
|
|
|
JavaValue result(T_VOID);
|
|
|
|
JavaCalls::call_static(&result,
|
|
|
|
SystemDictionary::module_Modules_klass(),
|
|
|
|
vmSymbols::addUses_name(),
|
|
|
|
vmSymbols::addUses_signature(),
|
|
|
|
module,
|
|
|
|
service,
|
|
|
|
THREAD);
|
|
|
|
|
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
|
|
|
LogTarget(Trace, jvmti) log;
|
2017-07-21 09:50:12 +02:00
|
|
|
LogStream log_stream(log);
|
2016-12-01 08:56:41 +00:00
|
|
|
java_lang_Throwable::print(PENDING_EXCEPTION, &log_stream);
|
|
|
|
log_stream.cr();
|
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
return JVMTI_ERROR_INTERNAL;
|
|
|
|
}
|
|
|
|
return JVMTI_ERROR_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
jvmtiError
|
|
|
|
JvmtiExport::add_module_provides(Handle module, Handle service, Handle impl_class, TRAPS) {
|
|
|
|
if (!Universe::is_module_initialized()) {
|
|
|
|
return JVMTI_ERROR_NONE; // extra safety
|
|
|
|
}
|
|
|
|
assert(!module.is_null(), "module should always be set");
|
|
|
|
assert(!service.is_null(), "service should always be set");
|
|
|
|
assert(!impl_class.is_null(), "impl_class should always be set");
|
|
|
|
|
|
|
|
// Invoke the addProvides method
|
|
|
|
JavaValue result(T_VOID);
|
|
|
|
JavaCalls::call_static(&result,
|
|
|
|
SystemDictionary::module_Modules_klass(),
|
|
|
|
vmSymbols::addProvides_name(),
|
|
|
|
vmSymbols::addProvides_signature(),
|
|
|
|
module,
|
|
|
|
service,
|
|
|
|
impl_class,
|
|
|
|
THREAD);
|
|
|
|
|
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
|
|
|
LogTarget(Trace, jvmti) log;
|
2017-07-21 09:50:12 +02:00
|
|
|
LogStream log_stream(log);
|
2016-12-01 08:56:41 +00:00
|
|
|
java_lang_Throwable::print(PENDING_EXCEPTION, &log_stream);
|
|
|
|
log_stream.cr();
|
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
return JVMTI_ERROR_INTERNAL;
|
|
|
|
}
|
|
|
|
return JVMTI_ERROR_NONE;
|
|
|
|
}
|
|
|
|
|
2009-12-14 10:05:36 -07:00
|
|
|
void
|
|
|
|
JvmtiExport::decode_version_values(jint version, int * major, int * minor,
|
|
|
|
int * micro) {
|
|
|
|
*major = (version & JVMTI_VERSION_MASK_MAJOR) >> JVMTI_VERSION_SHIFT_MAJOR;
|
|
|
|
*minor = (version & JVMTI_VERSION_MASK_MINOR) >> JVMTI_VERSION_SHIFT_MINOR;
|
|
|
|
*micro = (version & JVMTI_VERSION_MASK_MICRO) >> JVMTI_VERSION_SHIFT_MICRO;
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
void JvmtiExport::enter_primordial_phase() {
|
|
|
|
JvmtiEnvBase::set_phase(JVMTI_PHASE_PRIMORDIAL);
|
|
|
|
}
|
|
|
|
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
void JvmtiExport::enter_early_start_phase() {
|
|
|
|
set_early_vmstart_recorded(true);
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
void JvmtiExport::enter_start_phase() {
|
|
|
|
JvmtiEnvBase::set_phase(JVMTI_PHASE_START);
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::enter_onload_phase() {
|
|
|
|
JvmtiEnvBase::set_phase(JVMTI_PHASE_ONLOAD);
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::enter_live_phase() {
|
|
|
|
JvmtiEnvBase::set_phase(JVMTI_PHASE_LIVE);
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// JVMTI events that the VM posts to the debugger and also startup agent
|
|
|
|
// and call the agent's premain() for java.lang.instrument.
|
|
|
|
//
|
|
|
|
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
void JvmtiExport::post_early_vm_start() {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_VM_START, ("Trg Early VM start event triggered" ));
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
|
|
|
|
// can now enable some events
|
|
|
|
JvmtiEventController::vm_start();
|
|
|
|
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
// Only early vmstart envs post early VMStart event
|
|
|
|
if (env->early_vmstart_env() && env->is_enabled(JVMTI_EVENT_VM_START)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_VM_START, ("Evt Early VM start event sent" ));
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
JavaThread *thread = JavaThread::current();
|
|
|
|
JvmtiThreadEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventVMStart callback = env->callbacks()->VMStart;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
void JvmtiExport::post_vm_start() {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_VM_START, ("Trg VM start event triggered" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// can now enable some events
|
|
|
|
JvmtiEventController::vm_start();
|
|
|
|
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
// Early vmstart envs do not post normal VMStart event
|
|
|
|
if (!env->early_vmstart_env() && env->is_enabled(JVMTI_EVENT_VM_START)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_VM_START, ("Evt VM start event sent" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JavaThread *thread = JavaThread::current();
|
|
|
|
JvmtiThreadEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventVMStart callback = env->callbacks()->VMStart;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void JvmtiExport::post_vm_initialized() {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_VM_INIT, ("Trg VM init event triggered" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// can now enable events
|
|
|
|
JvmtiEventController::vm_init();
|
|
|
|
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_VM_INIT)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_VM_INIT, ("Evt VM init event sent" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JavaThread *thread = JavaThread::current();
|
|
|
|
JvmtiThreadEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventVMInit callback = env->callbacks()->VMInit;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void JvmtiExport::post_vm_death() {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_VM_DEATH, ("Trg VM death event triggered" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_VM_DEATH)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_VM_DEATH, ("Evt VM death event sent" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JavaThread *thread = JavaThread::current();
|
|
|
|
JvmtiEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventVMDeath callback = env->callbacks()->VMDeath;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
JvmtiEnvBase::set_phase(JVMTI_PHASE_DEAD);
|
|
|
|
JvmtiEventController::vm_death();
|
|
|
|
}
|
|
|
|
|
|
|
|
char**
|
|
|
|
JvmtiExport::get_all_native_method_prefixes(int* count_ptr) {
|
|
|
|
// Have to grab JVMTI thread state lock to be sure environment doesn't
|
|
|
|
// go away while we iterate them. No locks during VM bring-up.
|
|
|
|
if (Threads::number_of_threads() == 0 || SafepointSynchronize::is_at_safepoint()) {
|
|
|
|
return JvmtiEnvBase::get_all_native_method_prefixes(count_ptr);
|
|
|
|
} else {
|
|
|
|
MutexLocker mu(JvmtiThreadState_lock);
|
|
|
|
return JvmtiEnvBase::get_all_native_method_prefixes(count_ptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-22 17:54:50 -08:00
|
|
|
// Convert an external thread reference to a JavaThread found on the
|
|
|
|
// specified ThreadsList. The ThreadsListHandle in the caller "protects"
|
|
|
|
// the returned JavaThread *.
|
|
|
|
//
|
|
|
|
// If thread_oop_p is not NULL, then the caller wants to use the oop
|
|
|
|
// after this call so the oop is returned. On success, *jt_pp is set
|
|
|
|
// to the converted JavaThread * and JVMTI_ERROR_NONE is returned.
|
|
|
|
// On error, returns various JVMTI_ERROR_* values.
|
|
|
|
//
|
|
|
|
jvmtiError
|
|
|
|
JvmtiExport::cv_external_thread_to_JavaThread(ThreadsList * t_list,
|
|
|
|
jthread thread,
|
|
|
|
JavaThread ** jt_pp,
|
|
|
|
oop * thread_oop_p) {
|
|
|
|
assert(t_list != NULL, "must have a ThreadsList");
|
|
|
|
assert(jt_pp != NULL, "must have a return JavaThread pointer");
|
|
|
|
// thread_oop_p is optional so no assert()
|
|
|
|
|
|
|
|
oop thread_oop = JNIHandles::resolve_external_guard(thread);
|
|
|
|
if (thread_oop == NULL) {
|
|
|
|
// NULL jthread, GC'ed jthread or a bad JNI handle.
|
|
|
|
return JVMTI_ERROR_INVALID_THREAD;
|
|
|
|
}
|
|
|
|
// Looks like an oop at this point.
|
|
|
|
|
|
|
|
if (!thread_oop->is_a(SystemDictionary::Thread_klass())) {
|
|
|
|
// The oop is not a java.lang.Thread.
|
|
|
|
return JVMTI_ERROR_INVALID_THREAD;
|
|
|
|
}
|
|
|
|
// Looks like a java.lang.Thread oop at this point.
|
|
|
|
|
|
|
|
if (thread_oop_p != NULL) {
|
|
|
|
// Return the oop to the caller; the caller may still want
|
|
|
|
// the oop even if this function returns an error.
|
|
|
|
*thread_oop_p = thread_oop;
|
|
|
|
}
|
|
|
|
|
|
|
|
JavaThread * java_thread = java_lang_Thread::thread(thread_oop);
|
|
|
|
if (java_thread == NULL) {
|
|
|
|
// The java.lang.Thread does not contain a JavaThread * so it has
|
|
|
|
// not yet run or it has died.
|
|
|
|
return JVMTI_ERROR_THREAD_NOT_ALIVE;
|
|
|
|
}
|
|
|
|
// Looks like a live JavaThread at this point.
|
|
|
|
|
|
|
|
// We do not check the EnableThreadSMRExtraValidityChecks option
|
|
|
|
// for this includes() call because JVM/TI's spec is tighter.
|
|
|
|
if (!t_list->includes(java_thread)) {
|
|
|
|
// Not on the JavaThreads list so it is not alive.
|
|
|
|
return JVMTI_ERROR_THREAD_NOT_ALIVE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return a live JavaThread that is "protected" by the
|
|
|
|
// ThreadsListHandle in the caller.
|
|
|
|
*jt_pp = java_thread;
|
|
|
|
|
|
|
|
return JVMTI_ERROR_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Convert an oop to a JavaThread found on the specified ThreadsList.
|
|
|
|
// The ThreadsListHandle in the caller "protects" the returned
|
|
|
|
// JavaThread *.
|
|
|
|
//
|
|
|
|
// On success, *jt_pp is set to the converted JavaThread * and
|
|
|
|
// JVMTI_ERROR_NONE is returned. On error, returns various
|
|
|
|
// JVMTI_ERROR_* values.
|
|
|
|
//
|
|
|
|
jvmtiError
|
|
|
|
JvmtiExport::cv_oop_to_JavaThread(ThreadsList * t_list, oop thread_oop,
|
|
|
|
JavaThread ** jt_pp) {
|
|
|
|
assert(t_list != NULL, "must have a ThreadsList");
|
|
|
|
assert(thread_oop != NULL, "must have an oop");
|
|
|
|
assert(jt_pp != NULL, "must have a return JavaThread pointer");
|
|
|
|
|
|
|
|
if (!thread_oop->is_a(SystemDictionary::Thread_klass())) {
|
|
|
|
// The oop is not a java.lang.Thread.
|
|
|
|
return JVMTI_ERROR_INVALID_THREAD;
|
|
|
|
}
|
|
|
|
// Looks like a java.lang.Thread oop at this point.
|
|
|
|
|
|
|
|
JavaThread * java_thread = java_lang_Thread::thread(thread_oop);
|
|
|
|
if (java_thread == NULL) {
|
|
|
|
// The java.lang.Thread does not contain a JavaThread * so it has
|
|
|
|
// not yet run or it has died.
|
|
|
|
return JVMTI_ERROR_THREAD_NOT_ALIVE;
|
|
|
|
}
|
|
|
|
// Looks like a live JavaThread at this point.
|
|
|
|
|
|
|
|
// We do not check the EnableThreadSMRExtraValidityChecks option
|
|
|
|
// for this includes() call because JVM/TI's spec is tighter.
|
|
|
|
if (!t_list->includes(java_thread)) {
|
|
|
|
// Not on the JavaThreads list so it is not alive.
|
|
|
|
return JVMTI_ERROR_THREAD_NOT_ALIVE;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Return a live JavaThread that is "protected" by the
|
|
|
|
// ThreadsListHandle in the caller.
|
|
|
|
*jt_pp = java_thread;
|
|
|
|
|
|
|
|
return JVMTI_ERROR_NONE;
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
class JvmtiClassFileLoadHookPoster : public StackObj {
|
|
|
|
private:
|
2011-01-27 16:11:27 -08:00
|
|
|
Symbol* _h_name;
|
2007-12-01 00:00:00 +00:00
|
|
|
Handle _class_loader;
|
|
|
|
Handle _h_protection_domain;
|
|
|
|
unsigned char ** _data_ptr;
|
|
|
|
unsigned char ** _end_ptr;
|
|
|
|
JavaThread * _thread;
|
|
|
|
jint _curr_len;
|
|
|
|
unsigned char * _curr_data;
|
|
|
|
JvmtiEnv * _curr_env;
|
2013-07-17 18:06:29 -04:00
|
|
|
JvmtiCachedClassFileData ** _cached_class_file_ptr;
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiThreadState * _state;
|
2017-03-15 10:25:37 -04:00
|
|
|
Klass* _class_being_redefined;
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiClassLoadKind _load_kind;
|
2016-12-11 19:07:04 -08:00
|
|
|
bool _has_been_modified;
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
public:
|
2011-01-27 16:11:27 -08:00
|
|
|
inline JvmtiClassFileLoadHookPoster(Symbol* h_name, Handle class_loader,
|
2007-12-01 00:00:00 +00:00
|
|
|
Handle h_protection_domain,
|
|
|
|
unsigned char **data_ptr, unsigned char **end_ptr,
|
2013-07-17 18:06:29 -04:00
|
|
|
JvmtiCachedClassFileData **cache_ptr) {
|
2007-12-01 00:00:00 +00:00
|
|
|
_h_name = h_name;
|
|
|
|
_class_loader = class_loader;
|
|
|
|
_h_protection_domain = h_protection_domain;
|
|
|
|
_data_ptr = data_ptr;
|
|
|
|
_end_ptr = end_ptr;
|
|
|
|
_thread = JavaThread::current();
|
|
|
|
_curr_len = *end_ptr - *data_ptr;
|
|
|
|
_curr_data = *data_ptr;
|
|
|
|
_curr_env = NULL;
|
2013-07-17 18:06:29 -04:00
|
|
|
_cached_class_file_ptr = cache_ptr;
|
2016-12-11 19:07:04 -08:00
|
|
|
_has_been_modified = false;
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
_state = _thread->jvmti_thread_state();
|
|
|
|
if (_state != NULL) {
|
2017-03-15 10:25:37 -04:00
|
|
|
_class_being_redefined = _state->get_class_being_redefined();
|
2007-12-01 00:00:00 +00:00
|
|
|
_load_kind = _state->get_class_load_kind();
|
2017-03-15 10:25:37 -04:00
|
|
|
Klass* klass = (_class_being_redefined == NULL) ? NULL : _class_being_redefined;
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (_load_kind != jvmti_class_load_kind_load && klass != NULL) {
|
|
|
|
ModuleEntry* module_entry = InstanceKlass::cast(klass)->module();
|
|
|
|
assert(module_entry != NULL, "module_entry should always be set");
|
|
|
|
if (module_entry->is_named() &&
|
2017-08-23 12:00:39 -04:00
|
|
|
module_entry->module() != NULL &&
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
!module_entry->has_default_read_edges()) {
|
|
|
|
if (!module_entry->set_has_default_read_edges()) {
|
|
|
|
// We won a potential race.
|
|
|
|
// Add read edges to the unnamed modules of the bootstrap and app class loaders
|
2017-08-08 09:53:52 -04:00
|
|
|
Handle class_module(_thread, module_entry->module()); // Obtain j.l.r.Module
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
JvmtiExport::add_default_read_edges(class_module, _thread);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
// Clear class_being_redefined flag here. The action
|
|
|
|
// from agent handler could generate a new class file load
|
|
|
|
// hook event and if it is not cleared the new event generated
|
|
|
|
// from regular class file load could have this stale redefined
|
|
|
|
// class handle info.
|
|
|
|
_state->clear_class_being_redefined();
|
|
|
|
} else {
|
|
|
|
// redefine and retransform will always set the thread state
|
2017-03-15 10:25:37 -04:00
|
|
|
_class_being_redefined = NULL;
|
2007-12-01 00:00:00 +00:00
|
|
|
_load_kind = jvmti_class_load_kind_load;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void post() {
|
|
|
|
post_all_envs();
|
|
|
|
copy_modified_data();
|
|
|
|
}
|
|
|
|
|
2016-12-11 19:07:04 -08:00
|
|
|
bool has_been_modified() { return _has_been_modified; }
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
private:
|
|
|
|
void post_all_envs() {
|
|
|
|
if (_load_kind != jvmti_class_load_kind_retransform) {
|
|
|
|
// for class load and redefine,
|
|
|
|
// call the non-retransformable agents
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (!env->is_retransformable() && env->is_enabled(JVMTI_EVENT_CLASS_FILE_LOAD_HOOK)) {
|
|
|
|
// non-retransformable agents cannot retransform back,
|
|
|
|
// so no need to cache the original class file bytes
|
|
|
|
post_to_env(env, false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
// retransformable agents get all events
|
|
|
|
if (env->is_retransformable() && env->is_enabled(JVMTI_EVENT_CLASS_FILE_LOAD_HOOK)) {
|
|
|
|
// retransformable agents need to cache the original class file
|
|
|
|
// bytes if changes are made via the ClassFileLoadHook
|
|
|
|
post_to_env(env, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void post_to_env(JvmtiEnv* env, bool caching_needed) {
|
2016-04-28 00:36:46 -07:00
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL && !env->early_class_hook_env()) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
return;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
unsigned char *new_data = NULL;
|
|
|
|
jint new_len = 0;
|
|
|
|
JvmtiClassFileLoadEventMark jem(_thread, _h_name, _class_loader,
|
|
|
|
_h_protection_domain,
|
2017-03-15 10:25:37 -04:00
|
|
|
_class_being_redefined);
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiJavaThreadEventTransition jet(_thread);
|
|
|
|
jvmtiEventClassFileLoadHook callback = env->callbacks()->ClassFileLoadHook;
|
|
|
|
if (callback != NULL) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(),
|
2007-12-01 00:00:00 +00:00
|
|
|
jem.class_being_redefined(),
|
|
|
|
jem.jloader(), jem.class_name(),
|
|
|
|
jem.protection_domain(),
|
|
|
|
_curr_len, _curr_data,
|
|
|
|
&new_len, &new_data);
|
|
|
|
}
|
|
|
|
if (new_data != NULL) {
|
|
|
|
// this agent has modified class data.
|
2016-12-11 19:07:04 -08:00
|
|
|
_has_been_modified = true;
|
2013-07-17 18:06:29 -04:00
|
|
|
if (caching_needed && *_cached_class_file_ptr == NULL) {
|
2007-12-01 00:00:00 +00:00
|
|
|
// data has been changed by the new retransformable agent
|
|
|
|
// and it hasn't already been cached, cache it
|
2013-07-17 18:06:29 -04:00
|
|
|
JvmtiCachedClassFileData *p;
|
|
|
|
p = (JvmtiCachedClassFileData *)os::malloc(
|
|
|
|
offset_of(JvmtiCachedClassFileData, data) + _curr_len, mtInternal);
|
|
|
|
if (p == NULL) {
|
|
|
|
vm_exit_out_of_memory(offset_of(JvmtiCachedClassFileData, data) + _curr_len,
|
|
|
|
OOM_MALLOC_ERROR,
|
|
|
|
"unable to allocate cached copy of original class bytes");
|
2013-05-08 11:21:56 +02:00
|
|
|
}
|
2013-07-17 18:06:29 -04:00
|
|
|
p->length = _curr_len;
|
|
|
|
memcpy(p->data, _curr_data, _curr_len);
|
|
|
|
*_cached_class_file_ptr = p;
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (_curr_data != *_data_ptr) {
|
|
|
|
// curr_data is previous agent modified class data.
|
|
|
|
// And this has been changed by the new agent so
|
|
|
|
// we can delete it now.
|
|
|
|
_curr_env->Deallocate(_curr_data);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Class file data has changed by the current agent.
|
|
|
|
_curr_data = new_data;
|
|
|
|
_curr_len = new_len;
|
|
|
|
// Save the current agent env we need this to deallocate the
|
|
|
|
// memory allocated by this agent.
|
|
|
|
_curr_env = env;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void copy_modified_data() {
|
|
|
|
// if one of the agent has modified class file data.
|
|
|
|
// Copy modified class data to new resources array.
|
|
|
|
if (_curr_data != *_data_ptr) {
|
|
|
|
*_data_ptr = NEW_RESOURCE_ARRAY(u1, _curr_len);
|
|
|
|
memcpy(*_data_ptr, _curr_data, _curr_len);
|
|
|
|
*_end_ptr = *_data_ptr + _curr_len;
|
|
|
|
_curr_env->Deallocate(_curr_data);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
bool JvmtiExport::_should_post_class_file_load_hook = false;
|
|
|
|
|
|
|
|
// this entry is for class file load hook on class load, redefine and retransform
|
2016-12-11 19:07:04 -08:00
|
|
|
bool JvmtiExport::post_class_file_load_hook(Symbol* h_name,
|
2007-12-01 00:00:00 +00:00
|
|
|
Handle class_loader,
|
|
|
|
Handle h_protection_domain,
|
|
|
|
unsigned char **data_ptr,
|
|
|
|
unsigned char **end_ptr,
|
2013-07-17 18:06:29 -04:00
|
|
|
JvmtiCachedClassFileData **cache_ptr) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
2016-12-11 19:07:04 -08:00
|
|
|
return false;
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiClassFileLoadHookPoster poster(h_name, class_loader,
|
|
|
|
h_protection_domain,
|
|
|
|
data_ptr, end_ptr,
|
2013-07-17 18:06:29 -04:00
|
|
|
cache_ptr);
|
2007-12-01 00:00:00 +00:00
|
|
|
poster.post();
|
2016-12-11 19:07:04 -08:00
|
|
|
return poster.has_been_modified();
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::report_unsupported(bool on) {
|
|
|
|
// If any JVMTI service is turned on, we need to exit before native code
|
|
|
|
// tries to access nonexistant services.
|
|
|
|
if (on) {
|
|
|
|
vm_exit_during_initialization("Java Kernel does not support JVMTI.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
static inline Klass* oop_to_klass(oop obj) {
|
|
|
|
Klass* k = obj->klass();
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// if the object is a java.lang.Class then return the java mirror
|
2010-01-06 14:22:39 -08:00
|
|
|
if (k == SystemDictionary::Class_klass()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
if (!java_lang_Class::is_primitive(obj)) {
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
k = java_lang_Class::as_Klass(obj);
|
2007-12-01 00:00:00 +00:00
|
|
|
assert(k != NULL, "class for non-primitive mirror must exist");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return k;
|
|
|
|
}
|
|
|
|
|
|
|
|
class JvmtiVMObjectAllocEventMark : public JvmtiClassEventMark {
|
|
|
|
private:
|
|
|
|
jobject _jobj;
|
|
|
|
jlong _size;
|
|
|
|
public:
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
JvmtiVMObjectAllocEventMark(JavaThread *thread, oop obj) : JvmtiClassEventMark(thread, oop_to_klass(obj)) {
|
2007-12-01 00:00:00 +00:00
|
|
|
_jobj = (jobject)to_jobject(obj);
|
|
|
|
_size = obj->size() * wordSize;
|
|
|
|
};
|
|
|
|
jobject jni_jobject() { return _jobj; }
|
|
|
|
jlong size() { return _size; }
|
|
|
|
};
|
|
|
|
|
|
|
|
class JvmtiCompiledMethodLoadEventMark : public JvmtiMethodEventMark {
|
|
|
|
private:
|
|
|
|
jint _code_size;
|
|
|
|
const void *_code_data;
|
|
|
|
jint _map_length;
|
|
|
|
jvmtiAddrLocationMap *_map;
|
|
|
|
const void *_compile_info;
|
|
|
|
public:
|
2010-01-13 09:39:46 -07:00
|
|
|
JvmtiCompiledMethodLoadEventMark(JavaThread *thread, nmethod *nm, void* compile_info_ptr = NULL)
|
2007-12-01 00:00:00 +00:00
|
|
|
: JvmtiMethodEventMark(thread,methodHandle(thread, nm->method())) {
|
2010-08-25 05:27:54 -07:00
|
|
|
_code_data = nm->insts_begin();
|
|
|
|
_code_size = nm->insts_size();
|
2010-01-13 09:39:46 -07:00
|
|
|
_compile_info = compile_info_ptr; // Set void pointer of compiledMethodLoad Event. Default value is NULL.
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiCodeBlobEvents::build_jvmti_addr_location_map(nm, &_map, &_map_length);
|
|
|
|
}
|
|
|
|
~JvmtiCompiledMethodLoadEventMark() {
|
2014-12-01 12:16:15 -05:00
|
|
|
FREE_C_HEAP_ARRAY(jvmtiAddrLocationMap, _map);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
jint code_size() { return _code_size; }
|
|
|
|
const void *code_data() { return _code_data; }
|
|
|
|
jint map_length() { return _map_length; }
|
|
|
|
const jvmtiAddrLocationMap* map() { return _map; }
|
|
|
|
const void *compile_info() { return _compile_info; }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class JvmtiMonitorEventMark : public JvmtiThreadEventMark {
|
|
|
|
private:
|
|
|
|
jobject _jobj;
|
|
|
|
public:
|
|
|
|
JvmtiMonitorEventMark(JavaThread *thread, oop object)
|
|
|
|
: JvmtiThreadEventMark(thread){
|
|
|
|
_jobj = to_jobject(object);
|
|
|
|
}
|
|
|
|
jobject jni_object() { return _jobj; }
|
|
|
|
};
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// pending CompiledMethodUnload support
|
|
|
|
//
|
|
|
|
|
2011-02-02 14:38:01 -05:00
|
|
|
void JvmtiExport::post_compiled_method_unload(
|
|
|
|
jmethodID method, const void *code_begin) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2011-02-02 14:38:01 -05:00
|
|
|
JavaThread* thread = JavaThread::current();
|
2010-06-02 14:23:23 -07:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_COMPILED_METHOD_UNLOAD,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] method compile unload event triggered",
|
2011-02-02 14:38:01 -05:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
2010-06-02 14:23:23 -07:00
|
|
|
|
|
|
|
// post the event for each environment that has this event enabled.
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_COMPILED_METHOD_UNLOAD)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
continue;
|
|
|
|
}
|
2010-06-02 14:23:23 -07:00
|
|
|
EVT_TRACE(JVMTI_EVENT_COMPILED_METHOD_UNLOAD,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] class compile method unload event sent jmethodID " PTR_FORMAT,
|
2015-10-09 09:42:33 +02:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread), p2i(method)));
|
2010-06-02 14:23:23 -07:00
|
|
|
|
2011-02-02 14:38:01 -05:00
|
|
|
ResourceMark rm(thread);
|
2010-06-02 14:23:23 -07:00
|
|
|
|
2011-02-02 14:38:01 -05:00
|
|
|
JvmtiEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
2010-06-02 14:23:23 -07:00
|
|
|
jvmtiEventCompiledMethodUnload callback = env->callbacks()->CompiledMethodUnload;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), method, code_begin);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
///////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// JvmtiExport
|
|
|
|
//
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_raw_breakpoint(JavaThread *thread, Method* method, address location) {
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_BREAKPOINT, ("[%s] Trg Breakpoint triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
ets->compare_and_set_current_location(mh(), location, JVMTI_EVENT_BREAKPOINT);
|
|
|
|
if (!ets->breakpoint_posted() && ets->is_enabled(JVMTI_EVENT_BREAKPOINT)) {
|
|
|
|
ThreadState old_os_state = thread->osthread()->get_state();
|
|
|
|
thread->osthread()->set_state(BREAKPOINTED);
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_BREAKPOINT, ("[%s] Evt Breakpoint sent %s.%s @ " INTX_FORMAT,
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string(),
|
|
|
|
location - mh()->code_base() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiLocationEventMark jem(thread, mh, location);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventBreakpoint callback = env->callbacks()->Breakpoint;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), jem.location());
|
|
|
|
}
|
|
|
|
|
|
|
|
ets->set_breakpoint_posted();
|
|
|
|
thread->osthread()->set_state(old_os_state);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
bool JvmtiExport::_can_get_source_debug_extension = false;
|
|
|
|
bool JvmtiExport::_can_maintain_original_method_order = false;
|
|
|
|
bool JvmtiExport::_can_post_interpreter_events = false;
|
2010-02-01 17:35:05 -07:00
|
|
|
bool JvmtiExport::_can_post_on_exceptions = false;
|
2007-12-01 00:00:00 +00:00
|
|
|
bool JvmtiExport::_can_post_breakpoint = false;
|
|
|
|
bool JvmtiExport::_can_post_field_access = false;
|
|
|
|
bool JvmtiExport::_can_post_field_modification = false;
|
|
|
|
bool JvmtiExport::_can_post_method_entry = false;
|
|
|
|
bool JvmtiExport::_can_post_method_exit = false;
|
|
|
|
bool JvmtiExport::_can_pop_frame = false;
|
|
|
|
bool JvmtiExport::_can_force_early_return = false;
|
|
|
|
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
bool JvmtiExport::_early_vmstart_recorded = false;
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
bool JvmtiExport::_should_post_single_step = false;
|
|
|
|
bool JvmtiExport::_should_post_field_access = false;
|
|
|
|
bool JvmtiExport::_should_post_field_modification = false;
|
|
|
|
bool JvmtiExport::_should_post_class_load = false;
|
|
|
|
bool JvmtiExport::_should_post_class_prepare = false;
|
|
|
|
bool JvmtiExport::_should_post_class_unload = false;
|
|
|
|
bool JvmtiExport::_should_post_thread_life = false;
|
|
|
|
bool JvmtiExport::_should_clean_up_heap_objects = false;
|
|
|
|
bool JvmtiExport::_should_post_native_method_bind = false;
|
|
|
|
bool JvmtiExport::_should_post_dynamic_code_generated = false;
|
|
|
|
bool JvmtiExport::_should_post_data_dump = false;
|
|
|
|
bool JvmtiExport::_should_post_compiled_method_load = false;
|
|
|
|
bool JvmtiExport::_should_post_compiled_method_unload = false;
|
|
|
|
bool JvmtiExport::_should_post_monitor_contended_enter = false;
|
|
|
|
bool JvmtiExport::_should_post_monitor_contended_entered = false;
|
|
|
|
bool JvmtiExport::_should_post_monitor_wait = false;
|
|
|
|
bool JvmtiExport::_should_post_monitor_waited = false;
|
|
|
|
bool JvmtiExport::_should_post_garbage_collection_start = false;
|
|
|
|
bool JvmtiExport::_should_post_garbage_collection_finish = false;
|
|
|
|
bool JvmtiExport::_should_post_object_free = false;
|
|
|
|
bool JvmtiExport::_should_post_resource_exhausted = false;
|
|
|
|
bool JvmtiExport::_should_post_vm_object_alloc = false;
|
2010-02-01 17:35:05 -07:00
|
|
|
bool JvmtiExport::_should_post_on_exceptions = false;
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// JVMTI single step management
|
|
|
|
//
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::at_single_stepping_point(JavaThread *thread, Method* method, address location) {
|
2007-12-01 00:00:00 +00:00
|
|
|
assert(JvmtiExport::should_post_single_step(), "must be single stepping");
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
|
|
|
// update information about current location and post a step event
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_SINGLE_STEP, ("[%s] Trg Single Step triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
if (!state->hide_single_stepping()) {
|
|
|
|
if (state->is_pending_step_for_popframe()) {
|
|
|
|
state->process_pending_step_for_popframe();
|
|
|
|
}
|
|
|
|
if (state->is_pending_step_for_earlyret()) {
|
|
|
|
state->process_pending_step_for_earlyret();
|
|
|
|
}
|
|
|
|
JvmtiExport::post_single_step(thread, mh(), location);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void JvmtiExport::expose_single_stepping(JavaThread *thread) {
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state != NULL) {
|
|
|
|
state->clear_hide_single_stepping();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool JvmtiExport::hide_single_stepping(JavaThread *thread) {
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state != NULL && state->is_enabled(JVMTI_EVENT_SINGLE_STEP)) {
|
|
|
|
state->set_hide_single_stepping();
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_class_load(JavaThread *thread, Klass* klass) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_CLASS_LOAD, ("[%s] Trg Class Load triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiThreadState* state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_CLASS_LOAD)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
continue;
|
|
|
|
}
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_CLASS_LOAD, ("[%s] Evt Class Load sent %s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
2017-03-15 10:25:37 -04:00
|
|
|
klass==NULL? "NULL" : klass->external_name() ));
|
|
|
|
JvmtiClassEventMark jem(thread, klass);
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventClassLoad callback = env->callbacks()->ClassLoad;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(), jem.jni_class());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_class_prepare(JavaThread *thread, Klass* klass) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_CLASS_PREPARE, ("[%s] Trg Class Prepare triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiThreadState* state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_CLASS_PREPARE)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
continue;
|
|
|
|
}
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_CLASS_PREPARE, ("[%s] Evt Class Prepare sent %s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
2017-03-15 10:25:37 -04:00
|
|
|
klass==NULL? "NULL" : klass->external_name() ));
|
|
|
|
JvmtiClassEventMark jem(thread, klass);
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventClassPrepare callback = env->callbacks()->ClassPrepare;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(), jem.jni_class());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_class_unload(Klass* klass) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
Thread *thread = Thread::current();
|
|
|
|
HandleMark hm(thread);
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(EXT_EVENT_CLASS_UNLOAD, ("[?] Trg Class Unload triggered" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
if (JvmtiEventController::is_enabled((jvmtiEvent)EXT_EVENT_CLASS_UNLOAD)) {
|
|
|
|
assert(thread->is_VM_thread(), "wrong thread");
|
|
|
|
|
|
|
|
// get JavaThread for whom we are proxy
|
2017-01-31 14:33:36 -08:00
|
|
|
Thread *calling_thread = ((VMThread *)thread)->vm_operation()->calling_thread();
|
|
|
|
if (!calling_thread->is_Java_thread()) {
|
|
|
|
// cannot post an event to a non-JavaThread
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
JavaThread *real_thread = (JavaThread *)calling_thread;
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
continue;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
if (env->is_enabled((jvmtiEvent)EXT_EVENT_CLASS_UNLOAD)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(EXT_EVENT_CLASS_UNLOAD, ("[?] Evt Class Unload sent %s",
|
2017-03-15 10:25:37 -04:00
|
|
|
klass==NULL? "NULL" : klass->external_name() ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// do everything manually, since this is a proxy - needs special care
|
|
|
|
JNIEnv* jni_env = real_thread->jni_environment();
|
|
|
|
jthread jt = (jthread)JNIHandles::make_local(real_thread, real_thread->threadObj());
|
2017-03-15 10:25:37 -04:00
|
|
|
jclass jk = (jclass)JNIHandles::make_local(real_thread, klass->java_mirror());
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// Before we call the JVMTI agent, we have to set the state in the
|
|
|
|
// thread for which we are proxying.
|
|
|
|
JavaThreadState prev_state = real_thread->thread_state();
|
2014-03-17 19:29:29 -07:00
|
|
|
assert(((Thread *)real_thread)->is_ConcurrentGC_thread() ||
|
|
|
|
(real_thread->is_Java_thread() && prev_state == _thread_blocked),
|
|
|
|
"should be ConcurrentGCThread or JavaThread at safepoint");
|
2007-12-01 00:00:00 +00:00
|
|
|
real_thread->set_thread_state(_thread_in_native);
|
|
|
|
|
|
|
|
jvmtiExtensionEvent callback = env->ext_callbacks()->ClassUnload;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jni_env, jt, jk);
|
|
|
|
}
|
|
|
|
|
|
|
|
assert(real_thread->thread_state() == _thread_in_native,
|
|
|
|
"JavaThread should be in native");
|
|
|
|
real_thread->set_thread_state(prev_state);
|
|
|
|
|
|
|
|
JNIHandles::destroy_local(jk);
|
|
|
|
JNIHandles::destroy_local(jt);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void JvmtiExport::post_thread_start(JavaThread *thread) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
assert(thread->thread_state() == _thread_in_vm, "must be in vm state");
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_THREAD_START, ("[%s] Trg Thread Start event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
// do JVMTI thread initialization (if needed)
|
|
|
|
JvmtiEventController::thread_started(thread);
|
|
|
|
|
|
|
|
// Do not post thread start event for hidden java thread.
|
|
|
|
if (JvmtiEventController::is_enabled(JVMTI_EVENT_THREAD_START) &&
|
|
|
|
!thread->is_hidden_from_external_view()) {
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
continue;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
if (env->is_enabled(JVMTI_EVENT_THREAD_START)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_THREAD_START, ("[%s] Evt Thread Start event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread) ));
|
|
|
|
|
|
|
|
JvmtiThreadEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventThreadStart callback = env->callbacks()->ThreadStart;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void JvmtiExport::post_thread_end(JavaThread *thread) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_THREAD_END, ("[%s] Trg Thread End event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Do not post thread end event for hidden java thread.
|
|
|
|
if (state->is_enabled(JVMTI_EVENT_THREAD_END) &&
|
|
|
|
!thread->is_hidden_from_external_view()) {
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_THREAD_END)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
continue;
|
|
|
|
}
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_THREAD_END, ("[%s] Evt Thread End event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread) ));
|
|
|
|
|
|
|
|
JvmtiThreadEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventThreadEnd callback = env->callbacks()->ThreadEnd;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_object_free(JvmtiEnv* env, jlong tag) {
|
|
|
|
assert(SafepointSynchronize::is_at_safepoint(), "must be executed at safepoint");
|
|
|
|
assert(env->is_enabled(JVMTI_EVENT_OBJECT_FREE), "checking");
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_OBJECT_FREE, ("[?] Trg Object Free triggered" ));
|
|
|
|
EVT_TRACE(JVMTI_EVENT_OBJECT_FREE, ("[?] Evt Object Free sent"));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
jvmtiEventObjectFree callback = env->callbacks()->ObjectFree;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), tag);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_resource_exhausted(jint resource_exhausted_flags, const char* description) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_RESOURCE_EXHAUSTED, ("Trg resource exhausted event triggered" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_RESOURCE_EXHAUSTED)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_RESOURCE_EXHAUSTED, ("Evt resource exhausted event sent" ));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JavaThread *thread = JavaThread::current();
|
|
|
|
JvmtiThreadEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventResourceExhausted callback = env->callbacks()->ResourceExhausted;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(),
|
|
|
|
resource_exhausted_flags, NULL, description);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_method_entry(JavaThread *thread, Method* method, frame current_frame) {
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_METHOD_ENTRY, ("[%s] Trg Method Entry triggered %s.%s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string() ));
|
|
|
|
|
|
|
|
JvmtiThreadState* state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL || !state->is_interp_only_mode()) {
|
|
|
|
// for any thread that actually wants method entry, interp_only_mode is set
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
state->incr_cur_stack_depth();
|
|
|
|
|
|
|
|
if (state->is_enabled(JVMTI_EVENT_METHOD_ENTRY)) {
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_METHOD_ENTRY)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_METHOD_ENTRY, ("[%s] Evt Method Entry sent %s.%s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiMethodEventMark jem(thread, mh);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventMethodEntry callback = env->callbacks()->MethodEntry;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(), jem.jni_methodID());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_method_exit(JavaThread *thread, Method* method, frame current_frame) {
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_METHOD_EXIT, ("[%s] Trg Method Exit triggered %s.%s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string() ));
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL || !state->is_interp_only_mode()) {
|
|
|
|
// for any thread that actually wants method exit, interp_only_mode is set
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// return a flag when a method terminates by throwing an exception
|
|
|
|
// i.e. if an exception is thrown and it's not caught by the current method
|
|
|
|
bool exception_exit = state->is_exception_detected() && !state->is_exception_caught();
|
|
|
|
|
|
|
|
|
|
|
|
if (state->is_enabled(JVMTI_EVENT_METHOD_EXIT)) {
|
|
|
|
Handle result;
|
|
|
|
jvalue value;
|
|
|
|
value.j = 0L;
|
|
|
|
|
|
|
|
// if the method hasn't been popped because of an exception then we populate
|
|
|
|
// the return_value parameter for the callback. At this point we only have
|
|
|
|
// the address of a "raw result" and we just call into the interpreter to
|
|
|
|
// convert this into a jvalue.
|
|
|
|
if (!exception_exit) {
|
|
|
|
oop oop_result;
|
|
|
|
BasicType type = current_frame.interpreter_frame_result(&oop_result, &value);
|
|
|
|
if (type == T_OBJECT || type == T_ARRAY) {
|
|
|
|
result = Handle(thread, oop_result);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_METHOD_EXIT)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_METHOD_EXIT, ("[%s] Evt Method Exit sent %s.%s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiMethodEventMark jem(thread, mh);
|
|
|
|
if (result.not_null()) {
|
|
|
|
value.l = JNIHandles::make_local(thread, result());
|
|
|
|
}
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventMethodExit callback = env->callbacks()->MethodExit;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), exception_exit, value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-04 10:25:44 -07:00
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->has_frame_pops()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
int cur_frame_number = state->cur_stack_depth();
|
|
|
|
|
|
|
|
if (ets->is_frame_pop(cur_frame_number)) {
|
|
|
|
// we have a NotifyFramePop entry for this frame.
|
|
|
|
// now check that this env/thread wants this event
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_FRAME_POP)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_FRAME_POP, ("[%s] Evt Frame Pop sent %s.%s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string() ));
|
|
|
|
|
|
|
|
// we also need to issue a frame pop event for this frame
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiMethodEventMark jem(thread, mh);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventFramePop callback = env->callbacks()->FramePop;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), exception_exit);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// remove the frame's entry
|
|
|
|
ets->clear_frame_pop(cur_frame_number);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
state->decr_cur_stack_depth();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Todo: inline this for optimization
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_single_step(JavaThread *thread, Method* method, address location) {
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
ets->compare_and_set_current_location(mh(), location, JVMTI_EVENT_SINGLE_STEP);
|
|
|
|
if (!ets->single_stepping_posted() && ets->is_enabled(JVMTI_EVENT_SINGLE_STEP)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_SINGLE_STEP, ("[%s] Evt Single Step sent %s.%s @ " INTX_FORMAT,
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string(),
|
|
|
|
location - mh()->code_base() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiLocationEventMark jem(thread, mh, location);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventSingleStep callback = env->callbacks()->SingleStep;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), jem.location());
|
|
|
|
}
|
|
|
|
|
|
|
|
ets->set_single_stepping_posted();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_exception_throw(JavaThread *thread, Method* method, address location, oop exception) {
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
Handle exception_handle(thread, exception);
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_EXCEPTION, ("[%s] Trg Exception thrown triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
if (!state->is_exception_detected()) {
|
|
|
|
state->set_exception_detected();
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_EXCEPTION) && (exception != NULL)) {
|
|
|
|
|
|
|
|
EVT_TRACE(JVMTI_EVENT_EXCEPTION,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] Evt Exception thrown sent %s.%s @ " INTX_FORMAT,
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string(),
|
|
|
|
location - mh()->code_base() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiExceptionEventMark jem(thread, mh, location, exception_handle);
|
|
|
|
|
|
|
|
// It's okay to clear these exceptions here because we duplicate
|
|
|
|
// this lookup in InterpreterRuntime::exception_handler_for_exception.
|
|
|
|
EXCEPTION_MARK;
|
|
|
|
|
|
|
|
bool should_repeat;
|
|
|
|
vframeStream st(thread);
|
|
|
|
assert(!st.at_end(), "cannot be at end");
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
Method* current_method = NULL;
|
2013-01-08 13:01:19 -05:00
|
|
|
// A GC may occur during the Method::fast_exception_handler_bci_for()
|
|
|
|
// call below if it needs to load the constraint class. Using a
|
|
|
|
// methodHandle to keep the 'current_method' from being deallocated
|
|
|
|
// if GC happens.
|
|
|
|
methodHandle current_mh = methodHandle(thread, current_method);
|
2007-12-01 00:00:00 +00:00
|
|
|
int current_bci = -1;
|
|
|
|
do {
|
|
|
|
current_method = st.method();
|
2013-01-08 13:01:19 -05:00
|
|
|
current_mh = methodHandle(thread, current_method);
|
2007-12-01 00:00:00 +00:00
|
|
|
current_bci = st.bci();
|
|
|
|
do {
|
|
|
|
should_repeat = false;
|
2017-03-15 10:25:37 -04:00
|
|
|
Klass* eh_klass = exception_handle()->klass();
|
2013-01-08 13:01:19 -05:00
|
|
|
current_bci = Method::fast_exception_handler_bci_for(
|
|
|
|
current_mh, eh_klass, current_bci, THREAD);
|
2007-12-01 00:00:00 +00:00
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
exception_handle = Handle(thread, PENDING_EXCEPTION);
|
2007-12-01 00:00:00 +00:00
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
should_repeat = true;
|
|
|
|
}
|
|
|
|
} while (should_repeat && (current_bci != -1));
|
|
|
|
st.next();
|
|
|
|
} while ((current_bci < 0) && (!st.at_end()));
|
|
|
|
|
|
|
|
jmethodID catch_jmethodID;
|
|
|
|
if (current_bci < 0) {
|
|
|
|
catch_jmethodID = 0;
|
|
|
|
current_bci = 0;
|
|
|
|
} else {
|
2013-01-08 13:01:19 -05:00
|
|
|
catch_jmethodID = jem.to_jmethodID(current_mh);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventException callback = env->callbacks()->Exception;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), jem.location(),
|
|
|
|
jem.exception(),
|
|
|
|
catch_jmethodID, current_bci);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// frames may get popped because of this throw, be safe - invalidate cached depth
|
|
|
|
state->invalidate_cur_stack_depth();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::notice_unwind_due_to_exception(JavaThread *thread, Method* method, address location, oop exception, bool in_handler_frame) {
|
2007-12-01 00:00:00 +00:00
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
Handle exception_handle(thread, exception);
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_EXCEPTION_CATCH,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] Trg unwind_due_to_exception triggered %s.%s @ %s" INTX_FORMAT " - %s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string(),
|
|
|
|
location==0? "no location:" : "",
|
|
|
|
location==0? 0 : location - mh()->code_base(),
|
|
|
|
in_handler_frame? "in handler frame" : "not handler frame" ));
|
|
|
|
|
|
|
|
if (state->is_exception_detected()) {
|
|
|
|
|
|
|
|
state->invalidate_cur_stack_depth();
|
|
|
|
if (!in_handler_frame) {
|
|
|
|
// Not in exception handler.
|
|
|
|
if(state->is_interp_only_mode()) {
|
|
|
|
// method exit and frame pop events are posted only in interp mode.
|
|
|
|
// When these events are enabled code should be in running in interp mode.
|
|
|
|
JvmtiExport::post_method_exit(thread, method, thread->last_frame());
|
|
|
|
// The cached cur_stack_depth might have changed from the
|
|
|
|
// operations of frame pop or method exit. We are not 100% sure
|
|
|
|
// the cached cur_stack_depth is still valid depth so invalidate
|
|
|
|
// it.
|
|
|
|
state->invalidate_cur_stack_depth();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// In exception handler frame. Report exception catch.
|
|
|
|
assert(location != NULL, "must be a known location");
|
|
|
|
// Update cur_stack_depth - the frames above the current frame
|
|
|
|
// have been unwound due to this exception:
|
|
|
|
assert(!state->is_exception_caught(), "exception must not be caught yet.");
|
|
|
|
state->set_exception_caught();
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_EXCEPTION_CATCH) && (exception_handle() != NULL)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_EXCEPTION_CATCH,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] Evt ExceptionCatch sent %s.%s @ " INTX_FORMAT,
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string(),
|
|
|
|
location - mh()->code_base() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiExceptionEventMark jem(thread, mh, location, exception_handle);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventExceptionCatch callback = env->callbacks()->ExceptionCatch;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), jem.location(),
|
|
|
|
jem.exception());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
oop JvmtiExport::jni_GetField_probe(JavaThread *thread, jobject jobj, oop obj,
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
Klass* klass, jfieldID fieldID, bool is_static) {
|
2007-12-01 00:00:00 +00:00
|
|
|
if (*((int *)get_field_access_count_addr()) > 0 && thread->has_last_Java_frame()) {
|
|
|
|
// At least one field access watch is set so we have more work
|
|
|
|
// to do. This wrapper is used by entry points that allow us
|
|
|
|
// to create handles in post_field_access_by_jni().
|
|
|
|
post_field_access_by_jni(thread, obj, klass, fieldID, is_static);
|
|
|
|
// event posting can block so refetch oop if we were passed a jobj
|
|
|
|
if (jobj != NULL) return JNIHandles::resolve_non_null(jobj);
|
|
|
|
}
|
|
|
|
return obj;
|
|
|
|
}
|
|
|
|
|
|
|
|
oop JvmtiExport::jni_GetField_probe_nh(JavaThread *thread, jobject jobj, oop obj,
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
Klass* klass, jfieldID fieldID, bool is_static) {
|
2007-12-01 00:00:00 +00:00
|
|
|
if (*((int *)get_field_access_count_addr()) > 0 && thread->has_last_Java_frame()) {
|
|
|
|
// At least one field access watch is set so we have more work
|
|
|
|
// to do. This wrapper is used by "quick" entry points that don't
|
|
|
|
// allow us to create handles in post_field_access_by_jni(). We
|
|
|
|
// override that with a ResetNoHandleMark.
|
|
|
|
ResetNoHandleMark rnhm;
|
|
|
|
post_field_access_by_jni(thread, obj, klass, fieldID, is_static);
|
|
|
|
// event posting can block so refetch oop if we were passed a jobj
|
|
|
|
if (jobj != NULL) return JNIHandles::resolve_non_null(jobj);
|
|
|
|
}
|
|
|
|
return obj;
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_field_access_by_jni(JavaThread *thread, oop obj,
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
Klass* klass, jfieldID fieldID, bool is_static) {
|
2007-12-01 00:00:00 +00:00
|
|
|
// We must be called with a Java context in order to provide reasonable
|
|
|
|
// values for the klazz, method, and location fields. The callers of this
|
|
|
|
// function don't make the call unless there is a Java context.
|
|
|
|
assert(thread->has_last_Java_frame(), "must be called with a Java context");
|
|
|
|
|
|
|
|
ResourceMark rm;
|
|
|
|
fieldDescriptor fd;
|
|
|
|
// if get_field_descriptor finds fieldID to be invalid, then we just bail
|
|
|
|
bool valid_fieldID = JvmtiEnv::get_field_descriptor(klass, fieldID, &fd);
|
|
|
|
assert(valid_fieldID == true,"post_field_access_by_jni called with invalid fieldID");
|
|
|
|
if (!valid_fieldID) return;
|
|
|
|
// field accesses are not watched so bail
|
|
|
|
if (!fd.is_field_access_watched()) return;
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
Handle h_obj;
|
|
|
|
if (!is_static) {
|
|
|
|
// non-static field accessors have an object, but we need a handle
|
|
|
|
assert(obj != NULL, "non-static needs an object");
|
|
|
|
h_obj = Handle(thread, obj);
|
|
|
|
}
|
|
|
|
post_field_access(thread,
|
|
|
|
thread->last_frame().interpreter_frame_method(),
|
|
|
|
thread->last_frame().interpreter_frame_bcp(),
|
2017-03-15 10:25:37 -04:00
|
|
|
klass, h_obj, fieldID);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_field_access(JavaThread *thread, Method* method,
|
2017-03-15 10:25:37 -04:00
|
|
|
address location, Klass* field_klass, Handle object, jfieldID field) {
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_FIELD_ACCESS, ("[%s] Trg Field Access event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_FIELD_ACCESS)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_FIELD_ACCESS, ("[%s] Evt Field Access event sent %s.%s @ " INTX_FORMAT,
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string(),
|
|
|
|
location - mh()->code_base() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiLocationEventMark jem(thread, mh, location);
|
2017-03-15 10:25:37 -04:00
|
|
|
jclass field_jclass = jem.to_jclass(field_klass);
|
2007-12-01 00:00:00 +00:00
|
|
|
jobject field_jobject = jem.to_jobject(object());
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventFieldAccess callback = env->callbacks()->FieldAccess;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), jem.location(),
|
|
|
|
field_jclass, field_jobject, field);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
oop JvmtiExport::jni_SetField_probe(JavaThread *thread, jobject jobj, oop obj,
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
Klass* klass, jfieldID fieldID, bool is_static,
|
2007-12-01 00:00:00 +00:00
|
|
|
char sig_type, jvalue *value) {
|
|
|
|
if (*((int *)get_field_modification_count_addr()) > 0 && thread->has_last_Java_frame()) {
|
|
|
|
// At least one field modification watch is set so we have more work
|
|
|
|
// to do. This wrapper is used by entry points that allow us
|
|
|
|
// to create handles in post_field_modification_by_jni().
|
|
|
|
post_field_modification_by_jni(thread, obj, klass, fieldID, is_static, sig_type, value);
|
|
|
|
// event posting can block so refetch oop if we were passed a jobj
|
|
|
|
if (jobj != NULL) return JNIHandles::resolve_non_null(jobj);
|
|
|
|
}
|
|
|
|
return obj;
|
|
|
|
}
|
|
|
|
|
|
|
|
oop JvmtiExport::jni_SetField_probe_nh(JavaThread *thread, jobject jobj, oop obj,
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
Klass* klass, jfieldID fieldID, bool is_static,
|
2007-12-01 00:00:00 +00:00
|
|
|
char sig_type, jvalue *value) {
|
|
|
|
if (*((int *)get_field_modification_count_addr()) > 0 && thread->has_last_Java_frame()) {
|
|
|
|
// At least one field modification watch is set so we have more work
|
|
|
|
// to do. This wrapper is used by "quick" entry points that don't
|
|
|
|
// allow us to create handles in post_field_modification_by_jni(). We
|
|
|
|
// override that with a ResetNoHandleMark.
|
|
|
|
ResetNoHandleMark rnhm;
|
|
|
|
post_field_modification_by_jni(thread, obj, klass, fieldID, is_static, sig_type, value);
|
|
|
|
// event posting can block so refetch oop if we were passed a jobj
|
|
|
|
if (jobj != NULL) return JNIHandles::resolve_non_null(jobj);
|
|
|
|
}
|
|
|
|
return obj;
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_field_modification_by_jni(JavaThread *thread, oop obj,
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
Klass* klass, jfieldID fieldID, bool is_static,
|
2007-12-01 00:00:00 +00:00
|
|
|
char sig_type, jvalue *value) {
|
|
|
|
// We must be called with a Java context in order to provide reasonable
|
|
|
|
// values for the klazz, method, and location fields. The callers of this
|
|
|
|
// function don't make the call unless there is a Java context.
|
|
|
|
assert(thread->has_last_Java_frame(), "must be called with Java context");
|
|
|
|
|
|
|
|
ResourceMark rm;
|
|
|
|
fieldDescriptor fd;
|
|
|
|
// if get_field_descriptor finds fieldID to be invalid, then we just bail
|
|
|
|
bool valid_fieldID = JvmtiEnv::get_field_descriptor(klass, fieldID, &fd);
|
|
|
|
assert(valid_fieldID == true,"post_field_modification_by_jni called with invalid fieldID");
|
|
|
|
if (!valid_fieldID) return;
|
|
|
|
// field modifications are not watched so bail
|
|
|
|
if (!fd.is_field_modification_watched()) return;
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
|
|
|
|
Handle h_obj;
|
|
|
|
if (!is_static) {
|
|
|
|
// non-static field accessors have an object, but we need a handle
|
|
|
|
assert(obj != NULL, "non-static needs an object");
|
|
|
|
h_obj = Handle(thread, obj);
|
|
|
|
}
|
|
|
|
post_field_modification(thread,
|
|
|
|
thread->last_frame().interpreter_frame_method(),
|
|
|
|
thread->last_frame().interpreter_frame_bcp(),
|
2017-03-15 10:25:37 -04:00
|
|
|
klass, h_obj, fieldID, sig_type, value);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_raw_field_modification(JavaThread *thread, Method* method,
|
2017-03-15 10:25:37 -04:00
|
|
|
address location, Klass* field_klass, Handle object, jfieldID field,
|
2007-12-01 00:00:00 +00:00
|
|
|
char sig_type, jvalue *value) {
|
|
|
|
|
2015-10-13 18:13:34 -04:00
|
|
|
if (sig_type == 'I' || sig_type == 'Z' || sig_type == 'B' || sig_type == 'C' || sig_type == 'S') {
|
2007-12-01 00:00:00 +00:00
|
|
|
// 'I' instructions are used for byte, char, short and int.
|
|
|
|
// determine which it really is, and convert
|
|
|
|
fieldDescriptor fd;
|
2017-03-15 10:25:37 -04:00
|
|
|
bool found = JvmtiEnv::get_field_descriptor(field_klass, field, &fd);
|
2007-12-01 00:00:00 +00:00
|
|
|
// should be found (if not, leave as is)
|
|
|
|
if (found) {
|
|
|
|
jint ival = value->i;
|
|
|
|
// convert value from int to appropriate type
|
|
|
|
switch (fd.field_type()) {
|
|
|
|
case T_BOOLEAN:
|
|
|
|
sig_type = 'Z';
|
|
|
|
value->i = 0; // clear it
|
|
|
|
value->z = (jboolean)ival;
|
|
|
|
break;
|
|
|
|
case T_BYTE:
|
|
|
|
sig_type = 'B';
|
|
|
|
value->i = 0; // clear it
|
|
|
|
value->b = (jbyte)ival;
|
|
|
|
break;
|
|
|
|
case T_CHAR:
|
|
|
|
sig_type = 'C';
|
|
|
|
value->i = 0; // clear it
|
|
|
|
value->c = (jchar)ival;
|
|
|
|
break;
|
|
|
|
case T_SHORT:
|
|
|
|
sig_type = 'S';
|
|
|
|
value->i = 0; // clear it
|
|
|
|
value->s = (jshort)ival;
|
|
|
|
break;
|
|
|
|
case T_INT:
|
|
|
|
// nothing to do
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
// this is an integer instruction, should be one of above
|
|
|
|
ShouldNotReachHere();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-05-15 11:30:54 +02:00
|
|
|
assert(sig_type != '[', "array should have sig_type == 'L'");
|
|
|
|
bool handle_created = false;
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
// convert oop to JNI handle.
|
2013-05-15 11:30:54 +02:00
|
|
|
if (sig_type == 'L') {
|
|
|
|
handle_created = true;
|
2007-12-01 00:00:00 +00:00
|
|
|
value->l = (jobject)JNIHandles::make_local(thread, (oop)value->l);
|
|
|
|
}
|
|
|
|
|
|
|
|
post_field_modification(thread, method, location, field_klass, object, field, sig_type, value);
|
|
|
|
|
|
|
|
// Destroy the JNI handle allocated above.
|
2013-05-15 11:30:54 +02:00
|
|
|
if (handle_created) {
|
2007-12-01 00:00:00 +00:00
|
|
|
JNIHandles::destroy_local(value->l);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_field_modification(JavaThread *thread, Method* method,
|
2017-03-15 10:25:37 -04:00
|
|
|
address location, Klass* field_klass, Handle object, jfieldID field,
|
2007-12-01 00:00:00 +00:00
|
|
|
char sig_type, jvalue *value_ptr) {
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_FIELD_MODIFICATION,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] Trg Field Modification event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_FIELD_MODIFICATION)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_FIELD_MODIFICATION,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] Evt Field Modification event sent %s.%s @ " INTX_FORMAT,
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->klass_name()->as_C_string(),
|
|
|
|
(mh() == NULL) ? "NULL" : mh()->name()->as_C_string(),
|
|
|
|
location - mh()->code_base() ));
|
|
|
|
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiLocationEventMark jem(thread, mh, location);
|
2017-03-15 10:25:37 -04:00
|
|
|
jclass field_jclass = jem.to_jclass(field_klass);
|
2007-12-01 00:00:00 +00:00
|
|
|
jobject field_jobject = jem.to_jobject(object());
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventFieldModification callback = env->callbacks()->FieldModification;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), jem.location(),
|
|
|
|
field_jclass, field_jobject, field, sig_type, *value_ptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
void JvmtiExport::post_native_method_bind(Method* method, address* function_ptr) {
|
2007-12-01 00:00:00 +00:00
|
|
|
JavaThread* thread = JavaThread::current();
|
|
|
|
assert(thread->thread_state() == _thread_in_vm, "must be in vm state");
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
methodHandle mh(thread, method);
|
|
|
|
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_NATIVE_METHOD_BIND, ("[%s] Trg Native Method Bind event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
if (JvmtiEventController::is_enabled(JVMTI_EVENT_NATIVE_METHOD_BIND)) {
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_NATIVE_METHOD_BIND)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_NATIVE_METHOD_BIND, ("[%s] Evt Native Method Bind event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread) ));
|
|
|
|
|
|
|
|
JvmtiMethodEventMark jem(thread, mh);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
JNIEnv* jni_env = (env->phase() == JVMTI_PHASE_PRIMORDIAL) ? NULL : jem.jni_env();
|
2007-12-01 00:00:00 +00:00
|
|
|
jvmtiEventNativeMethodBind callback = env->callbacks()->NativeMethodBind;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jni_env, jem.jni_thread(),
|
|
|
|
jem.jni_methodID(), (void*)(*function_ptr), (void**)function_ptr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-01-13 09:39:46 -07:00
|
|
|
// Returns a record containing inlining information for the given nmethod
|
|
|
|
jvmtiCompiledMethodLoadInlineRecord* create_inline_record(nmethod* nm) {
|
|
|
|
jint numstackframes = 0;
|
|
|
|
jvmtiCompiledMethodLoadInlineRecord* record = (jvmtiCompiledMethodLoadInlineRecord*)NEW_RESOURCE_OBJ(jvmtiCompiledMethodLoadInlineRecord);
|
|
|
|
record->header.kind = JVMTI_CMLR_INLINE_INFO;
|
|
|
|
record->header.next = NULL;
|
|
|
|
record->header.majorinfoversion = JVMTI_CMLR_MAJOR_VERSION_1;
|
|
|
|
record->header.minorinfoversion = JVMTI_CMLR_MINOR_VERSION_0;
|
|
|
|
record->numpcs = 0;
|
|
|
|
for(PcDesc* p = nm->scopes_pcs_begin(); p < nm->scopes_pcs_end(); p++) {
|
|
|
|
if(p->scope_decode_offset() == DebugInformationRecorder::serialized_null) continue;
|
|
|
|
record->numpcs++;
|
|
|
|
}
|
|
|
|
record->pcinfo = (PCStackInfo*)(NEW_RESOURCE_ARRAY(PCStackInfo, record->numpcs));
|
|
|
|
int scope = 0;
|
|
|
|
for(PcDesc* p = nm->scopes_pcs_begin(); p < nm->scopes_pcs_end(); p++) {
|
|
|
|
if(p->scope_decode_offset() == DebugInformationRecorder::serialized_null) continue;
|
|
|
|
void* pc_address = (void*)p->real_pc(nm);
|
|
|
|
assert(pc_address != NULL, "pc_address must be non-null");
|
|
|
|
record->pcinfo[scope].pc = pc_address;
|
|
|
|
numstackframes=0;
|
|
|
|
for(ScopeDesc* sd = nm->scope_desc_at(p->real_pc(nm));sd != NULL;sd = sd->sender()) {
|
|
|
|
numstackframes++;
|
|
|
|
}
|
|
|
|
assert(numstackframes != 0, "numstackframes must be nonzero.");
|
|
|
|
record->pcinfo[scope].methods = (jmethodID *)NEW_RESOURCE_ARRAY(jmethodID, numstackframes);
|
|
|
|
record->pcinfo[scope].bcis = (jint *)NEW_RESOURCE_ARRAY(jint, numstackframes);
|
|
|
|
record->pcinfo[scope].numstackframes = numstackframes;
|
|
|
|
int stackframe = 0;
|
|
|
|
for(ScopeDesc* sd = nm->scope_desc_at(p->real_pc(nm));sd != NULL;sd = sd->sender()) {
|
|
|
|
// sd->method() can be NULL for stubs but not for nmethods. To be completely robust, include an assert that we should never see a null sd->method()
|
6964458: Reimplement class meta-data storage to use native memory
Remove PermGen, allocate meta-data in metaspace linked to class loaders, rewrite GC walking, rewrite and rename metadata to be C++ classes
Co-authored-by: Stefan Karlsson <stefan.karlsson@oracle.com>
Co-authored-by: Mikael Gerdin <mikael.gerdin@oracle.com>
Co-authored-by: Tom Rodriguez <tom.rodriguez@oracle.com>
Reviewed-by: jmasa, stefank, never, coleenp, kvn, brutisso, mgerdin, dholmes, jrose, twisti, roland
2012-09-01 13:25:18 -04:00
|
|
|
assert(sd->method() != NULL, "sd->method() cannot be null.");
|
2010-01-13 09:39:46 -07:00
|
|
|
record->pcinfo[scope].methods[stackframe] = sd->method()->jmethod_id();
|
|
|
|
record->pcinfo[scope].bcis[stackframe] = sd->bci();
|
|
|
|
stackframe++;
|
|
|
|
}
|
|
|
|
scope++;
|
|
|
|
}
|
|
|
|
return record;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
void JvmtiExport::post_compiled_method_load(nmethod *nm) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (JvmtiEnv::get_phase() < JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
JavaThread* thread = JavaThread::current();
|
|
|
|
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_COMPILED_METHOD_LOAD,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] method compile load event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_COMPILED_METHOD_LOAD)) {
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
continue;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
EVT_TRACE(JVMTI_EVENT_COMPILED_METHOD_LOAD,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] class compile method load event sent %s.%s ",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
|
|
|
(nm->method() == NULL) ? "NULL" : nm->method()->klass_name()->as_C_string(),
|
|
|
|
(nm->method() == NULL) ? "NULL" : nm->method()->name()->as_C_string()));
|
|
|
|
ResourceMark rm(thread);
|
2011-02-02 14:38:01 -05:00
|
|
|
HandleMark hm(thread);
|
2010-01-13 09:39:46 -07:00
|
|
|
|
|
|
|
// Add inlining information
|
|
|
|
jvmtiCompiledMethodLoadInlineRecord* inlinerecord = create_inline_record(nm);
|
|
|
|
// Pass inlining information through the void pointer
|
|
|
|
JvmtiCompiledMethodLoadEventMark jem(thread, nm, inlinerecord);
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventCompiledMethodLoad callback = env->callbacks()->CompiledMethodLoad;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_methodID(),
|
|
|
|
jem.code_size(), jem.code_data(), jem.map_length(),
|
|
|
|
jem.map(), jem.compile_info());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// post a COMPILED_METHOD_LOAD event for a given environment
|
|
|
|
void JvmtiExport::post_compiled_method_load(JvmtiEnv* env, const jmethodID method, const jint length,
|
|
|
|
const void *code_begin, const jint map_length,
|
|
|
|
const jvmtiAddrLocationMap* map)
|
|
|
|
{
|
8142968: Module System implementation
Initial integration of JEP 200, JEP 260, JEP 261, and JEP 282
Co-authored-by: Alex Buckley <alex.buckley@oracle.com>
Co-authored-by: Jonathan Gibbons <jonathan.gibbons@oracle.com>
Co-authored-by: Karen Kinnear <karen.kinnear@oracle.com>
Co-authored-by: Mandy Chung <mandy.chung@oracle.com>
Co-authored-by: Mark Reinhold <mark.reinhold@oracle.com>
Co-authored-by: Harold Seigel <harold.seigel@oracle.com>
Co-authored-by: Lois Foltan <lois.foltan@oracle.com>
Co-authored-by: Calvin Cheung <calvin.cheung@oracle.com>
Co-authored-by: Christian Tornqvist <christian.tornqvist@oracle.com>
Co-authored-by: Erik Joelsson <erik.joelsson@oracle.com>
Co-authored-by: George Triantafillou <george.triantafillou@oracle.com>
Co-authored-by: Igor Ignatyev <igor.ignatyev@oracle.com>
Co-authored-by: Ioi Lam <ioi.lam@oracle.com>
Co-authored-by: James Laskey <james.laskey@oracle.com>
Co-authored-by: Jean-Francois Denise <jean-francois.denise@oracle.com>
Co-authored-by: Jiangli Zhou <jiangli.zhou@oracle.com>
Co-authored-by: Markus Gronlund <markus.gronlund@oracle.com>
Co-authored-by: Serguei Spitsyn <serguei.spitsyn@oracle.com>
Co-authored-by: Staffan Larsen <staffan.larsen@oracle.com>
Co-authored-by: Sundararajan Athijegannathan <sundararajan.athijegannathan@oracle.com>
Reviewed-by: acorn, ccheung, coleenp, ctornqvi, dholmes, dsimms, gtriantafill, iklam, jiangli, mgronlun, mseledtsov, cjplummer, sspitsyn, stefank, twisti, hseigel, lfoltan, alanb, mchung, dfazunen
2016-03-17 19:04:01 +00:00
|
|
|
if (env->phase() <= JVMTI_PHASE_PRIMORDIAL) {
|
|
|
|
return;
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
JavaThread* thread = JavaThread::current();
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_COMPILED_METHOD_LOAD,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] method compile load event triggered (by GenerateEvents)",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_COMPILED_METHOD_LOAD)) {
|
|
|
|
|
|
|
|
EVT_TRACE(JVMTI_EVENT_COMPILED_METHOD_LOAD,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] class compile method load event sent (by GenerateEvents), jmethodID=" PTR_FORMAT,
|
2015-10-09 09:42:33 +02:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread), p2i(method)));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JvmtiEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventCompiledMethodLoad callback = env->callbacks()->CompiledMethodLoad;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), method,
|
|
|
|
length, code_begin, map_length,
|
|
|
|
map, NULL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_dynamic_code_generated_internal(const char *name, const void *code_begin, const void *code_end) {
|
2011-04-28 08:24:46 -07:00
|
|
|
assert(name != NULL && name[0] != '\0', "sanity check");
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
JavaThread* thread = JavaThread::current();
|
2011-02-26 13:33:23 -05:00
|
|
|
// In theory everyone coming thru here is in_vm but we need to be certain
|
|
|
|
// because a callee will do a vm->native transition
|
|
|
|
ThreadInVMfromUnknown __tiv;
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_DYNAMIC_CODE_GENERATED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] method dynamic code generated event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_DYNAMIC_CODE_GENERATED)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_DYNAMIC_CODE_GENERATED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] dynamic code generated event sent for %s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread), name));
|
|
|
|
JvmtiEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jint length = (jint)pointer_delta(code_end, code_begin, sizeof(char));
|
|
|
|
jvmtiEventDynamicCodeGenerated callback = env->callbacks()->DynamicCodeGenerated;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), name, (void*)code_begin, length);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_dynamic_code_generated(const char *name, const void *code_begin, const void *code_end) {
|
|
|
|
jvmtiPhase phase = JvmtiEnv::get_phase();
|
|
|
|
if (phase == JVMTI_PHASE_PRIMORDIAL || phase == JVMTI_PHASE_START) {
|
|
|
|
post_dynamic_code_generated_internal(name, code_begin, code_end);
|
2011-02-26 13:33:23 -05:00
|
|
|
} else {
|
|
|
|
// It may not be safe to post the event from this thread. Defer all
|
|
|
|
// postings to the service thread so that it can perform them in a safe
|
|
|
|
// context and in-order.
|
|
|
|
MutexLockerEx ml(Service_lock, Mutex::_no_safepoint_check_flag);
|
|
|
|
JvmtiDeferredEvent event = JvmtiDeferredEvent::dynamic_code_generated_event(
|
|
|
|
name, code_begin, code_end);
|
|
|
|
JvmtiDeferredEventQueue::enqueue(event);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// post a DYNAMIC_CODE_GENERATED event for a given environment
|
|
|
|
// used by GenerateEvents
|
|
|
|
void JvmtiExport::post_dynamic_code_generated(JvmtiEnv* env, const char *name,
|
|
|
|
const void *code_begin, const void *code_end)
|
|
|
|
{
|
|
|
|
JavaThread* thread = JavaThread::current();
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_DYNAMIC_CODE_GENERATED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] dynamic code generated event triggered (by GenerateEvents)",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_DYNAMIC_CODE_GENERATED)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_DYNAMIC_CODE_GENERATED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] dynamic code generated event sent for %s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread), name));
|
|
|
|
JvmtiEventMark jem(thread);
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jint length = (jint)pointer_delta(code_end, code_begin, sizeof(char));
|
|
|
|
jvmtiEventDynamicCodeGenerated callback = env->callbacks()->DynamicCodeGenerated;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), name, (void*)code_begin, length);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// post a DynamicCodeGenerated event while holding locks in the VM.
|
|
|
|
void JvmtiExport::post_dynamic_code_generated_while_holding_locks(const char* name,
|
|
|
|
address code_begin, address code_end)
|
|
|
|
{
|
|
|
|
// register the stub with the current dynamic code event collector
|
|
|
|
JvmtiThreadState* state = JvmtiThreadState::state_for(JavaThread::current());
|
2009-03-02 14:00:23 -07:00
|
|
|
// state can only be NULL if the current thread is exiting which
|
|
|
|
// should not happen since we're trying to post an event
|
|
|
|
guarantee(state != NULL, "attempt to register stub via an exiting thread");
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiDynamicCodeEventCollector* collector = state->get_dynamic_code_event_collector();
|
|
|
|
guarantee(collector != NULL, "attempt to register stub without event collector");
|
|
|
|
collector->register_stub(name, code_begin, code_end);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Collect all the vm internally allocated objects which are visible to java world
|
|
|
|
void JvmtiExport::record_vm_internal_object_allocation(oop obj) {
|
2015-12-04 04:06:37 -05:00
|
|
|
Thread* thread = Thread::current_or_null();
|
2007-12-01 00:00:00 +00:00
|
|
|
if (thread != NULL && thread->is_Java_thread()) {
|
|
|
|
// Can not take safepoint here.
|
2016-01-14 13:26:19 +01:00
|
|
|
NoSafepointVerifier no_sfpt;
|
2007-12-01 00:00:00 +00:00
|
|
|
// Can not take safepoint here so can not use state_for to get
|
|
|
|
// jvmti thread state.
|
|
|
|
JvmtiThreadState *state = ((JavaThread*)thread)->jvmti_thread_state();
|
|
|
|
if (state != NULL ) {
|
|
|
|
// state is non NULL when VMObjectAllocEventCollector is enabled.
|
|
|
|
JvmtiVMObjectAllocEventCollector *collector;
|
|
|
|
collector = state->get_vm_object_alloc_event_collector();
|
|
|
|
if (collector != NULL && collector->is_enabled()) {
|
|
|
|
// Don't record classes as these will be notified via the ClassLoad
|
|
|
|
// event.
|
2010-01-06 14:22:39 -08:00
|
|
|
if (obj->klass() != SystemDictionary::Class_klass()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
collector->record_allocation(obj);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_garbage_collection_finish() {
|
|
|
|
Thread *thread = Thread::current(); // this event is posted from VM-Thread.
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_GARBAGE_COLLECTION_FINISH,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] garbage collection finish event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_GARBAGE_COLLECTION_FINISH)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_GARBAGE_COLLECTION_FINISH,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] garbage collection finish event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiThreadEventTransition jet(thread);
|
|
|
|
// JNIEnv is NULL here because this event is posted from VM Thread
|
|
|
|
jvmtiEventGarbageCollectionFinish callback = env->callbacks()->GarbageCollectionFinish;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_garbage_collection_start() {
|
|
|
|
Thread* thread = Thread::current(); // this event is posted from vm-thread.
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_GARBAGE_COLLECTION_START,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] garbage collection start event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_GARBAGE_COLLECTION_START)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_GARBAGE_COLLECTION_START,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] garbage collection start event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiThreadEventTransition jet(thread);
|
|
|
|
// JNIEnv is NULL here because this event is posted from VM Thread
|
|
|
|
jvmtiEventGarbageCollectionStart callback = env->callbacks()->GarbageCollectionStart;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_data_dump() {
|
|
|
|
Thread *thread = Thread::current();
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_DATA_DUMP_REQUEST,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] data dump request event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_DATA_DUMP_REQUEST)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_DATA_DUMP_REQUEST,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] data dump request event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiThreadEventTransition jet(thread);
|
|
|
|
// JNIEnv is NULL here because this event is posted from VM Thread
|
|
|
|
jvmtiEventDataDumpRequest callback = env->callbacks()->DataDumpRequest;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_monitor_contended_enter(JavaThread *thread, ObjectMonitor *obj_mntr) {
|
|
|
|
oop object = (oop)obj_mntr->object();
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
Handle h(thread, object);
|
|
|
|
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_MONITOR_CONTENDED_ENTER,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] montior contended enter event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_MONITOR_CONTENDED_ENTER)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_MONITOR_CONTENDED_ENTER,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] monitor contended enter event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiMonitorEventMark jem(thread, h());
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventMonitorContendedEnter callback = env->callbacks()->MonitorContendedEnter;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(), jem.jni_object());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_monitor_contended_entered(JavaThread *thread, ObjectMonitor *obj_mntr) {
|
|
|
|
oop object = (oop)obj_mntr->object();
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
Handle h(thread, object);
|
|
|
|
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_MONITOR_CONTENDED_ENTERED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] montior contended entered event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_MONITOR_CONTENDED_ENTERED)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_MONITOR_CONTENDED_ENTERED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] monitor contended enter event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiMonitorEventMark jem(thread, h());
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventMonitorContendedEntered callback = env->callbacks()->MonitorContendedEntered;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(), jem.jni_object());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_monitor_wait(JavaThread *thread, oop object,
|
|
|
|
jlong timeout) {
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
Handle h(thread, object);
|
|
|
|
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_MONITOR_WAIT,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] montior wait event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_MONITOR_WAIT)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_MONITOR_WAIT,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] monitor wait event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiMonitorEventMark jem(thread, h());
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventMonitorWait callback = env->callbacks()->MonitorWait;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_object(), timeout);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::post_monitor_waited(JavaThread *thread, ObjectMonitor *obj_mntr, jboolean timed_out) {
|
|
|
|
oop object = (oop)obj_mntr->object();
|
|
|
|
JvmtiThreadState *state = thread->jvmti_thread_state();
|
|
|
|
if (state == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
HandleMark hm(thread);
|
|
|
|
Handle h(thread, object);
|
|
|
|
|
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_MONITOR_WAITED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] montior waited event triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
|
|
|
|
JvmtiEnvThreadStateIterator it(state);
|
|
|
|
for (JvmtiEnvThreadState* ets = it.first(); ets != NULL; ets = it.next(ets)) {
|
|
|
|
if (ets->is_enabled(JVMTI_EVENT_MONITOR_WAITED)) {
|
|
|
|
EVT_TRACE(JVMTI_EVENT_MONITOR_WAITED,
|
2016-04-19 14:14:04 +02:00
|
|
|
("[%s] monitor waited event sent",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
JvmtiMonitorEventMark jem(thread, h());
|
|
|
|
JvmtiEnv *env = ets->get_env();
|
|
|
|
JvmtiThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventMonitorWaited callback = env->callbacks()->MonitorWaited;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_object(), timed_out);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void JvmtiExport::post_vm_object_alloc(JavaThread *thread, oop object) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRIG_TRACE(JVMTI_EVENT_VM_OBJECT_ALLOC, ("[%s] Trg vm object alloc triggered",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread)));
|
|
|
|
if (object == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
HandleMark hm(thread);
|
|
|
|
Handle h(thread, object);
|
|
|
|
JvmtiEnvIterator it;
|
|
|
|
for (JvmtiEnv* env = it.first(); env != NULL; env = it.next(env)) {
|
|
|
|
if (env->is_enabled(JVMTI_EVENT_VM_OBJECT_ALLOC)) {
|
2016-04-19 14:14:04 +02:00
|
|
|
EVT_TRACE(JVMTI_EVENT_VM_OBJECT_ALLOC, ("[%s] Evt vmobject alloc sent %s",
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiTrace::safe_get_thread_name(thread),
|
2016-04-14 11:55:28 +02:00
|
|
|
object==NULL? "NULL" : object->klass()->external_name()));
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
JvmtiVMObjectAllocEventMark jem(thread, h());
|
|
|
|
JvmtiJavaThreadEventTransition jet(thread);
|
|
|
|
jvmtiEventVMObjectAlloc callback = env->callbacks()->VMObjectAlloc;
|
|
|
|
if (callback != NULL) {
|
|
|
|
(*callback)(env->jvmti_external(), jem.jni_env(), jem.jni_thread(),
|
|
|
|
jem.jni_jobject(), jem.jni_class(), jem.size());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
void JvmtiExport::cleanup_thread(JavaThread* thread) {
|
|
|
|
assert(JavaThread::current() == thread, "thread is not current");
|
2011-01-11 10:06:00 -05:00
|
|
|
MutexLocker mu(JvmtiThreadState_lock);
|
2007-12-01 00:00:00 +00:00
|
|
|
|
2011-01-11 10:06:00 -05:00
|
|
|
if (thread->jvmti_thread_state() != NULL) {
|
|
|
|
// This has to happen after the thread state is removed, which is
|
|
|
|
// why it is not in post_thread_end_event like its complement
|
|
|
|
// Maybe both these functions should be rolled into the posts?
|
|
|
|
JvmtiEventController::thread_ended(thread);
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
2014-02-24 10:28:22 +01:00
|
|
|
void JvmtiExport::clear_detected_exception(JavaThread* thread) {
|
|
|
|
assert(JavaThread::current() == thread, "thread is not current");
|
|
|
|
|
|
|
|
JvmtiThreadState* state = thread->jvmti_thread_state();
|
|
|
|
if (state != NULL) {
|
2016-12-20 15:40:01 +03:00
|
|
|
state->clear_exception_state();
|
2014-02-24 10:28:22 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
void JvmtiExport::oops_do(OopClosure* f) {
|
|
|
|
JvmtiCurrentBreakpoints::oops_do(f);
|
|
|
|
JvmtiVMObjectAllocEventCollector::oops_do_for_all_threads(f);
|
|
|
|
}
|
|
|
|
|
2015-09-16 16:25:02 +02:00
|
|
|
void JvmtiExport::weak_oops_do(BoolObjectClosure* is_alive, OopClosure* f) {
|
|
|
|
JvmtiTagMap::weak_oops_do(is_alive, f);
|
2011-01-19 13:51:53 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiExport::gc_epilogue() {
|
|
|
|
JvmtiCurrentBreakpoints::gc_epilogue();
|
|
|
|
}
|
|
|
|
|
2007-12-01 00:00:00 +00:00
|
|
|
// Onload raw monitor transition.
|
|
|
|
void JvmtiExport::transition_pending_onload_raw_monitors() {
|
|
|
|
JvmtiPendingMonitors::transition_raw_monitors();
|
|
|
|
}
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////
|
2016-03-25 12:54:16 +03:00
|
|
|
#if INCLUDE_SERVICES
|
|
|
|
// Attach is disabled if SERVICES is not included
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// type for the Agent_OnAttach entry point
|
|
|
|
extern "C" {
|
|
|
|
typedef jint (JNICALL *OnAttachEntry_t)(JavaVM*, char *, void *);
|
|
|
|
}
|
|
|
|
|
2016-02-18 23:26:43 +09:00
|
|
|
jint JvmtiExport::load_agent_library(const char *agent, const char *absParam,
|
|
|
|
const char *options, outputStream* st) {
|
2017-11-29 09:26:58 +09:00
|
|
|
char ebuf[1024] = {0};
|
2007-12-01 00:00:00 +00:00
|
|
|
char buffer[JVM_MAXPATHLEN];
|
2012-11-07 17:53:02 -05:00
|
|
|
void* library = NULL;
|
2007-12-01 00:00:00 +00:00
|
|
|
jint result = JNI_ERR;
|
2013-08-23 20:33:02 -04:00
|
|
|
const char *on_attach_symbols[] = AGENT_ONATTACH_SYMBOLS;
|
|
|
|
size_t num_symbol_entries = ARRAY_SIZE(on_attach_symbols);
|
2007-12-01 00:00:00 +00:00
|
|
|
|
|
|
|
// The abs paramter should be "true" or "false"
|
|
|
|
bool is_absolute_path = (absParam != NULL) && (strcmp(absParam,"true")==0);
|
|
|
|
|
2013-08-23 20:33:02 -04:00
|
|
|
// Initially marked as invalid. It will be set to valid if we can find the agent
|
|
|
|
AgentLibrary *agent_lib = new AgentLibrary(agent, options, is_absolute_path, NULL);
|
2007-12-01 00:00:00 +00:00
|
|
|
|
2013-08-23 20:33:02 -04:00
|
|
|
// Check for statically linked in agent. If not found then if the path is
|
|
|
|
// absolute we attempt to load the library. Otherwise we try to load it
|
|
|
|
// from the standard dll directory.
|
2007-12-01 00:00:00 +00:00
|
|
|
|
2013-08-23 20:33:02 -04:00
|
|
|
if (!os::find_builtin_agent(agent_lib, on_attach_symbols, num_symbol_entries)) {
|
|
|
|
if (is_absolute_path) {
|
|
|
|
library = os::dll_load(agent, ebuf, sizeof ebuf);
|
|
|
|
} else {
|
|
|
|
// Try to load the agent from the standard dll directory
|
2017-08-17 17:26:02 +02:00
|
|
|
if (os::dll_locate_lib(buffer, sizeof(buffer), Arguments::get_dll_dir(),
|
2013-08-23 20:33:02 -04:00
|
|
|
agent)) {
|
2012-11-07 17:53:02 -05:00
|
|
|
library = os::dll_load(buffer, ebuf, sizeof ebuf);
|
|
|
|
}
|
2013-08-23 20:33:02 -04:00
|
|
|
if (library == NULL) {
|
2017-08-17 17:26:02 +02:00
|
|
|
// not found - try OS default library path
|
|
|
|
if (os::dll_build_name(buffer, sizeof(buffer), agent)) {
|
2013-08-23 20:33:02 -04:00
|
|
|
library = os::dll_load(buffer, ebuf, sizeof ebuf);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (library != NULL) {
|
|
|
|
agent_lib->set_os_lib(library);
|
|
|
|
agent_lib->set_valid();
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// If the library was loaded then we attempt to invoke the Agent_OnAttach
|
|
|
|
// function
|
2013-08-23 20:33:02 -04:00
|
|
|
if (agent_lib->valid()) {
|
2007-12-01 00:00:00 +00:00
|
|
|
// Lookup the Agent_OnAttach function
|
|
|
|
OnAttachEntry_t on_attach_entry = NULL;
|
2013-08-23 20:33:02 -04:00
|
|
|
on_attach_entry = CAST_TO_FN_PTR(OnAttachEntry_t,
|
|
|
|
os::find_agent_function(agent_lib, false, on_attach_symbols, num_symbol_entries));
|
2007-12-01 00:00:00 +00:00
|
|
|
if (on_attach_entry == NULL) {
|
|
|
|
// Agent_OnAttach missing - unload library
|
2013-08-23 20:33:02 -04:00
|
|
|
if (!agent_lib->is_static_lib()) {
|
|
|
|
os::dll_unload(library);
|
|
|
|
}
|
2017-11-29 09:26:58 +09:00
|
|
|
st->print_cr("%s is not available in %s",
|
|
|
|
on_attach_symbols[0], agent_lib->name());
|
2013-08-23 20:33:02 -04:00
|
|
|
delete agent_lib;
|
2007-12-01 00:00:00 +00:00
|
|
|
} else {
|
|
|
|
// Invoke the Agent_OnAttach function
|
|
|
|
JavaThread* THREAD = JavaThread::current();
|
|
|
|
{
|
|
|
|
extern struct JavaVM_ main_vm;
|
|
|
|
JvmtiThreadEventMark jem(THREAD);
|
|
|
|
JvmtiJavaThreadEventTransition jet(THREAD);
|
|
|
|
|
|
|
|
result = (*on_attach_entry)(&main_vm, (char*)options, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Agent_OnAttach may have used JNI
|
|
|
|
if (HAS_PENDING_EXCEPTION) {
|
|
|
|
CLEAR_PENDING_EXCEPTION;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If OnAttach returns JNI_OK then we add it to the list of
|
|
|
|
// agent libraries so that we can call Agent_OnUnload later.
|
|
|
|
if (result == JNI_OK) {
|
2013-08-23 20:33:02 -04:00
|
|
|
Arguments::add_loaded_agent(agent_lib);
|
|
|
|
} else {
|
|
|
|
delete agent_lib;
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Agent_OnAttach executed so completion status is JNI_OK
|
2017-11-29 09:26:58 +09:00
|
|
|
st->print_cr("return code: %d", result);
|
2007-12-01 00:00:00 +00:00
|
|
|
result = JNI_OK;
|
|
|
|
}
|
2017-11-29 09:26:58 +09:00
|
|
|
} else {
|
|
|
|
st->print_cr("%s was not loaded.", agent);
|
|
|
|
if (*ebuf != '\0') {
|
|
|
|
st->print_cr("%s", ebuf);
|
|
|
|
}
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2016-03-25 12:54:16 +03:00
|
|
|
#endif // INCLUDE_SERVICES
|
2007-12-01 00:00:00 +00:00
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// Setup current current thread for event collection.
|
|
|
|
void JvmtiEventCollector::setup_jvmti_thread_state() {
|
|
|
|
// set this event collector to be the current one.
|
|
|
|
JvmtiThreadState* state = JvmtiThreadState::state_for(JavaThread::current());
|
2009-03-02 14:00:23 -07:00
|
|
|
// state can only be NULL if the current thread is exiting which
|
|
|
|
// should not happen since we're trying to configure for event collection
|
|
|
|
guarantee(state != NULL, "exiting thread called setup_jvmti_thread_state");
|
2007-12-01 00:00:00 +00:00
|
|
|
if (is_vm_object_alloc_event()) {
|
|
|
|
_prev = state->get_vm_object_alloc_event_collector();
|
|
|
|
state->set_vm_object_alloc_event_collector((JvmtiVMObjectAllocEventCollector *)this);
|
|
|
|
} else if (is_dynamic_code_event()) {
|
|
|
|
_prev = state->get_dynamic_code_event_collector();
|
|
|
|
state->set_dynamic_code_event_collector((JvmtiDynamicCodeEventCollector *)this);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Unset current event collection in this thread and reset it with previous
|
|
|
|
// collector.
|
|
|
|
void JvmtiEventCollector::unset_jvmti_thread_state() {
|
|
|
|
JvmtiThreadState* state = JavaThread::current()->jvmti_thread_state();
|
|
|
|
if (state != NULL) {
|
|
|
|
// restore the previous event collector (if any)
|
|
|
|
if (is_vm_object_alloc_event()) {
|
|
|
|
if (state->get_vm_object_alloc_event_collector() == this) {
|
|
|
|
state->set_vm_object_alloc_event_collector((JvmtiVMObjectAllocEventCollector *)_prev);
|
|
|
|
} else {
|
|
|
|
// this thread's jvmti state was created during the scope of
|
|
|
|
// the event collector.
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (is_dynamic_code_event()) {
|
|
|
|
if (state->get_dynamic_code_event_collector() == this) {
|
|
|
|
state->set_dynamic_code_event_collector((JvmtiDynamicCodeEventCollector *)_prev);
|
|
|
|
} else {
|
|
|
|
// this thread's jvmti state was created during the scope of
|
|
|
|
// the event collector.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// create the dynamic code event collector
|
|
|
|
JvmtiDynamicCodeEventCollector::JvmtiDynamicCodeEventCollector() : _code_blobs(NULL) {
|
|
|
|
if (JvmtiExport::should_post_dynamic_code_generated()) {
|
|
|
|
setup_jvmti_thread_state();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// iterate over any code blob descriptors collected and post a
|
|
|
|
// DYNAMIC_CODE_GENERATED event to the profiler.
|
|
|
|
JvmtiDynamicCodeEventCollector::~JvmtiDynamicCodeEventCollector() {
|
|
|
|
assert(!JavaThread::current()->owns_locks(), "all locks must be released to post deferred events");
|
|
|
|
// iterate over any code blob descriptors that we collected
|
|
|
|
if (_code_blobs != NULL) {
|
|
|
|
for (int i=0; i<_code_blobs->length(); i++) {
|
|
|
|
JvmtiCodeBlobDesc* blob = _code_blobs->at(i);
|
|
|
|
JvmtiExport::post_dynamic_code_generated(blob->name(), blob->code_begin(), blob->code_end());
|
|
|
|
FreeHeap(blob);
|
|
|
|
}
|
|
|
|
delete _code_blobs;
|
|
|
|
}
|
|
|
|
unset_jvmti_thread_state();
|
|
|
|
}
|
|
|
|
|
|
|
|
// register a stub
|
|
|
|
void JvmtiDynamicCodeEventCollector::register_stub(const char* name, address start, address end) {
|
|
|
|
if (_code_blobs == NULL) {
|
2012-06-28 17:03:16 -04:00
|
|
|
_code_blobs = new (ResourceObj::C_HEAP, mtInternal) GrowableArray<JvmtiCodeBlobDesc*>(1,true);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
_code_blobs->append(new JvmtiCodeBlobDesc(name, start, end));
|
|
|
|
}
|
|
|
|
|
|
|
|
// Setup current thread to record vm allocated objects.
|
|
|
|
JvmtiVMObjectAllocEventCollector::JvmtiVMObjectAllocEventCollector() : _allocated(NULL) {
|
|
|
|
if (JvmtiExport::should_post_vm_object_alloc()) {
|
|
|
|
_enable = true;
|
|
|
|
setup_jvmti_thread_state();
|
|
|
|
} else {
|
|
|
|
_enable = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Post vm_object_alloc event for vm allocated objects visible to java
|
|
|
|
// world.
|
|
|
|
JvmtiVMObjectAllocEventCollector::~JvmtiVMObjectAllocEventCollector() {
|
|
|
|
if (_allocated != NULL) {
|
|
|
|
set_enabled(false);
|
|
|
|
for (int i = 0; i < _allocated->length(); i++) {
|
|
|
|
oop obj = _allocated->at(i);
|
2018-03-21 13:07:19 -07:00
|
|
|
JvmtiExport::post_vm_object_alloc(JavaThread::current(), obj);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
delete _allocated;
|
|
|
|
}
|
|
|
|
unset_jvmti_thread_state();
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiVMObjectAllocEventCollector::record_allocation(oop obj) {
|
|
|
|
assert(is_enabled(), "VM object alloc event collector is not enabled");
|
|
|
|
if (_allocated == NULL) {
|
2012-06-28 17:03:16 -04:00
|
|
|
_allocated = new (ResourceObj::C_HEAP, mtInternal) GrowableArray<oop>(1, true);
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
_allocated->push(obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
// GC support.
|
|
|
|
void JvmtiVMObjectAllocEventCollector::oops_do(OopClosure* f) {
|
|
|
|
if (_allocated != NULL) {
|
|
|
|
for(int i=_allocated->length() - 1; i >= 0; i--) {
|
|
|
|
if (_allocated->at(i) != NULL) {
|
|
|
|
f->do_oop(_allocated->adr_at(i));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void JvmtiVMObjectAllocEventCollector::oops_do_for_all_threads(OopClosure* f) {
|
|
|
|
// no-op if jvmti not enabled
|
|
|
|
if (!JvmtiEnv::environments_might_exist()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-11-22 17:54:50 -08:00
|
|
|
for (JavaThreadIteratorWithHandle jtiwh; JavaThread *jthr = jtiwh.next(); ) {
|
2007-12-01 00:00:00 +00:00
|
|
|
JvmtiThreadState *state = jthr->jvmti_thread_state();
|
|
|
|
if (state != NULL) {
|
|
|
|
JvmtiVMObjectAllocEventCollector *collector;
|
|
|
|
collector = state->get_vm_object_alloc_event_collector();
|
|
|
|
while (collector != NULL) {
|
|
|
|
collector->oops_do(f);
|
|
|
|
collector = (JvmtiVMObjectAllocEventCollector *)collector->get_prev();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Disable collection of VMObjectAlloc events
|
|
|
|
NoJvmtiVMObjectAllocMark::NoJvmtiVMObjectAllocMark() : _collector(NULL) {
|
|
|
|
// a no-op if VMObjectAlloc event is not enabled
|
|
|
|
if (!JvmtiExport::should_post_vm_object_alloc()) {
|
|
|
|
return;
|
|
|
|
}
|
2015-12-04 04:06:37 -05:00
|
|
|
Thread* thread = Thread::current_or_null();
|
2007-12-01 00:00:00 +00:00
|
|
|
if (thread != NULL && thread->is_Java_thread()) {
|
|
|
|
JavaThread* current_thread = (JavaThread*)thread;
|
|
|
|
JvmtiThreadState *state = current_thread->jvmti_thread_state();
|
|
|
|
if (state != NULL) {
|
|
|
|
JvmtiVMObjectAllocEventCollector *collector;
|
|
|
|
collector = state->get_vm_object_alloc_event_collector();
|
|
|
|
if (collector != NULL && collector->is_enabled()) {
|
|
|
|
_collector = collector;
|
|
|
|
_collector->set_enabled(false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Re-Enable collection of VMObjectAlloc events (if previously enabled)
|
|
|
|
NoJvmtiVMObjectAllocMark::~NoJvmtiVMObjectAllocMark() {
|
|
|
|
if (was_enabled()) {
|
|
|
|
_collector->set_enabled(true);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2011-01-10 17:14:53 -05:00
|
|
|
JvmtiGCMarker::JvmtiGCMarker() {
|
2007-12-01 00:00:00 +00:00
|
|
|
// if there aren't any JVMTI environments then nothing to do
|
|
|
|
if (!JvmtiEnv::environments_might_exist()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (JvmtiExport::should_post_garbage_collection_start()) {
|
|
|
|
JvmtiExport::post_garbage_collection_start();
|
|
|
|
}
|
|
|
|
|
2011-01-10 17:14:53 -05:00
|
|
|
if (SafepointSynchronize::is_at_safepoint()) {
|
|
|
|
// Do clean up tasks that need to be done at a safepoint
|
|
|
|
JvmtiEnvBase::check_for_periodic_clean_up();
|
2007-12-01 00:00:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
JvmtiGCMarker::~JvmtiGCMarker() {
|
|
|
|
// if there aren't any JVMTI environments then nothing to do
|
|
|
|
if (!JvmtiEnv::environments_might_exist()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// JVMTI notify gc finish
|
|
|
|
if (JvmtiExport::should_post_garbage_collection_finish()) {
|
|
|
|
JvmtiExport::post_garbage_collection_finish();
|
|
|
|
}
|
|
|
|
}
|