This commit is contained in:
Serguei Spitsyn 2016-04-28 09:10:10 +00:00
commit 7d20b786fd
4 changed files with 34 additions and 4 deletions

View File

@ -9994,6 +9994,17 @@ myInit() {
See <eventlink id="VMStart"/>. See <eventlink id="VMStart"/>.
</description> </description>
</capabilityfield> </capabilityfield>
<capabilityfield id="can_generate_early_class_hook_events" since="9">
<description>
Can generate the <eventlink id="ClassFileLoadHook"/> events
in the primordial phase. If this capability and
<internallink id="jvmtiCapabilities.can_generate_all_class_hook_events">
<code>can_generate_all_class_hook_events</code></internallink>
are enabled then the <eventlink id="ClassFileLoadHook"/> events
can be posted for classes loaded in the primordial phase.
See <eventlink id="ClassFileLoadHook"/>.
</description>
</capabilityfield>
</capabilitiestypedef> </capabilitiestypedef>
<function id="GetPotentialCapabilities" jkernel="yes" phase="onload" num="140"> <function id="GetPotentialCapabilities" jkernel="yes" phase="onload" num="140">
@ -12404,7 +12415,7 @@ myInit() {
</parameters> </parameters>
</event> </event>
<event label="Class File Load Hook" phase="start" <event label="Class File Load Hook" phase="any"
id="ClassFileLoadHook" const="JVMTI_EVENT_CLASS_FILE_LOAD_HOOK" num="54"> id="ClassFileLoadHook" const="JVMTI_EVENT_CLASS_FILE_LOAD_HOOK" num="54">
<description> <description>
This event is sent when the VM obtains class file data, This event is sent when the VM obtains class file data,
@ -12420,7 +12431,13 @@ myInit() {
<internallink id="bci">bytecode instrumentation</internallink> <internallink id="bci">bytecode instrumentation</internallink>
for usage information. for usage information.
<p/> <p/>
This event may be sent before the VM is initialized (the start When the capabilities
<internallink id="jvmtiCapabilities.can_generate_early_class_hook_events">
<code>can_generate_early_class_hook_events</code></internallink> and
<internallink id="jvmtiCapabilities.can_generate_all_class_hook_events">
<code>can_generate_all_class_hook_events</code></internallink>
are enabled then this event may be sent in the primordial phase.
Otherwise, this event may be sent before the VM is initialized (the start
<functionlink id="GetPhase">phase</functionlink>). <functionlink id="GetPhase">phase</functionlink>).
Some classes might not be compatible Some classes might not be compatible
with the function (eg. ROMized classes) and this event will not be with the function (eg. ROMized classes) and this event will not be
@ -12470,6 +12487,7 @@ myInit() {
<origin>jvmpi</origin> <origin>jvmpi</origin>
<capabilities> <capabilities>
<capability id="can_generate_all_class_hook_events"></capability> <capability id="can_generate_all_class_hook_events"></capability>
<capability id="can_generate_early_class_hook_events"></capability>
</capabilities> </capabilities>
<parameters> <parameters>
<param id="jni_env"> <param id="jni_env">
@ -12542,7 +12560,7 @@ myInit() {
<event label="VM Start Event" <event label="VM Start Event"
id="VMStart" const="JVMTI_EVENT_VM_START" num="57" phase="start"> id="VMStart" const="JVMTI_EVENT_VM_START" num="57" phase="start">
<description> <description>
The VM initialization event signals the start of the VM. The VM start event signals the start of the VM.
At this time JNI is live but the VM is not yet fully initialized. At this time JNI is live but the VM is not yet fully initialized.
Once this event is generated, the agent is free to call any JNI function. Once this event is generated, the agent is free to call any JNI function.
This event signals the beginning of the start phase, This event signals the beginning of the start phase,
@ -14419,6 +14437,10 @@ typedef void (JNICALL *jvmtiEventVMInit)
- Add new capability can_generate_early_vmstart - Add new capability can_generate_early_vmstart
- Allow CompiledMethodLoad events at start phase - Allow CompiledMethodLoad events at start phase
</change> </change>
<change date="14 April 2016" version="9.0.0">
Support for modules:
- Add new capability can_generate_early_class_hook_events
</change>
</changehistory> </changehistory>
</specification> </specification>

View File

@ -162,6 +162,11 @@ class JvmtiEnvBase : public CHeapObj<mtInternal> {
jvmtiCapabilities *get_prohibited_capabilities() { return &_prohibited_capabilities; } jvmtiCapabilities *get_prohibited_capabilities() { return &_prohibited_capabilities; }
bool early_class_hook_env() {
return get_capabilities()->can_generate_early_class_hook_events != 0
&& get_capabilities()->can_generate_all_class_hook_events != 0;
}
bool early_vmstart_env() { bool early_vmstart_env() {
return get_capabilities()->can_generate_early_vmstart != 0; return get_capabilities()->can_generate_early_vmstart != 0;
} }

View File

@ -667,7 +667,7 @@ class JvmtiClassFileLoadHookPoster : public StackObj {
} }
void post_to_env(JvmtiEnv* env, bool caching_needed) { void post_to_env(JvmtiEnv* env, bool caching_needed) {
if (env->phase() == JVMTI_PHASE_PRIMORDIAL) { if (env->phase() == JVMTI_PHASE_PRIMORDIAL && !env->early_class_hook_env()) {
return; return;
} }
unsigned char *new_data = NULL; unsigned char *new_data = NULL;

View File

@ -136,6 +136,7 @@ jvmtiCapabilities JvmtiManageCapabilities::init_onload_capabilities() {
jc.can_get_owned_monitor_stack_depth_info = 1; jc.can_get_owned_monitor_stack_depth_info = 1;
jc.can_get_current_contended_monitor = 1; jc.can_get_current_contended_monitor = 1;
jc.can_generate_early_vmstart = 1; jc.can_generate_early_vmstart = 1;
jc.can_generate_early_class_hook_events = 1;
return jc; return jc;
} }
@ -456,6 +457,8 @@ void JvmtiManageCapabilities:: print(const jvmtiCapabilities* cap) {
log_trace(jvmti)("can_generate_resource_exhaustion_threads_events"); log_trace(jvmti)("can_generate_resource_exhaustion_threads_events");
if (cap->can_generate_early_vmstart) if (cap->can_generate_early_vmstart)
log_trace(jvmti)("can_generate_early_vmstart"); log_trace(jvmti)("can_generate_early_vmstart");
if (cap->can_generate_early_class_hook_events)
log_trace(jvmti)("can_generate_early_class_hook_events");
} }
#endif #endif