Merge
This commit is contained in:
commit
cfe7bd538a
@ -9995,6 +9995,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">
|
||||||
@ -12405,7 +12416,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,
|
||||||
@ -12421,7 +12432,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
|
||||||
@ -12471,6 +12488,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">
|
||||||
@ -12543,7 +12561,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,
|
||||||
@ -14420,6 +14438,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>
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user