0N/A<?
xml version="1.0"?>
1879N/A Copyright (c) 2002, 2010, Oracle and/or its affiliates. All rights reserved. 0N/A DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 0N/A This code is free software; you can redistribute it and/or modify it 0N/A under the terms of the GNU General Public License version 2 only, as 0N/A published by the Free Software Foundation. 0N/A This code is distributed in the hope that it will be useful, but WITHOUT 0N/A ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 0N/A FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 0N/A version 2 for more details (a copy is included in the LICENSE file that 0N/A accompanied this code). 0N/A You should have received a copy of the GNU General Public License version 0N/A 2 along with this work; if not, write to the Free Software Foundation, 0N/A Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 1472N/A Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA 0N/A<
xsl:
output method="text" indent="no" omit-
xml-
declaration="yes"/>
0N/A<
xsl:
param name="trace"></
xsl:
param>
0N/A<
xsl:
param name="interface"></
xsl:
param>
0N/A<
xsl:
template match="specification">
0N/A <
xsl:
call-
template name="sourceHeader"/>
0N/A <
xsl:
if test="$trace = 'Trace'">
0N/A <
xsl:
if test="$trace != 'Trace'">
0N/Aconst char* JvmtiUtil::_error_names[] = {
0N/A <
xsl:
call-
template name="fillEntityName">
0N/A </
xsl:
call-
template>
0N/Aconst bool JvmtiUtil::_event_threaded[] = {
0N/A <
xsl:
call-
template name="fillEventThreaded">
0N/A </
xsl:
call-
template>
0N/A <
xsl:
call-
template name="eventCapabilitiesTest"/>
0N/A <
xsl:
if test="$trace = 'Trace'">
0N/A<!-- all this just to return the highest event number --> 0N/A <
xsl:
variable name="maxEvent">
0N/A <
xsl:
variable name="mynum" select="@num"/>
0N/A <
xsl:
value-
of select="@num"/>
0N/A <
xsl:
text>jbyte JvmtiTrace::_event_trace_flags[</
xsl:
text>
0N/A <
xsl:
value-
of select="1+$maxEvent"/>
0N/Ajint JvmtiTrace::_max_event_index = </
xsl:
text>
0N/A <
xsl:
value-
of select="$maxEvent"/>
0N/Aconst char* JvmtiTrace::_event_names[] = {
0N/A <
xsl:
call-
template name="fillEntityName">
0N/A </
xsl:
call-
template>
0N/A <
xsl:
apply-
templates select="//constants[@kind='enum']"/>
0N/A <
xsl:
apply-
templates select="functionsection"/>
0N/A <
xsl:
if test="$trace='Trace'">
0N/A#endif /*JVMTI_TRACE */
0N/A<
xsl:
template match="constants">
0N/A <
xsl:
value-
of select="@label"/>
0N/Aconst char* </
xsl:
text>
0N/A <
xsl:
value-
of select="@id"/>
0N/A <
xsl:
text>ConstantNames[] = {
0N/A <
xsl:
apply-
templates select="constant" mode="constname"/>
0N/A <
xsl:
value-
of select="@label"/>
0N/A <
xsl:
value-
of select="@id"/>
0N/A <
xsl:
text>ConstantValues[] = {
0N/A <
xsl:
apply-
templates select="constant" mode="constvalue"/>
0N/A<
xsl:
template match="constant" mode="constname">
0N/A <
xsl:
text> "</
xsl:
text>
0N/A <
xsl:
value-
of select="@id"/>
0N/A<
xsl:
template match="constant" mode="constvalue">
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="@num"/>
0N/A<
xsl:
template name="eventCapabilitiesTest">
0N/A// Check Event Capabilities
0N/Aconst bool JvmtiUtil::has_event_capability(jvmtiEvent event_type, const jvmtiCapabilities* capabilities_ptr) {
0N/A switch (event_type) {
0N/A <
xsl:
if test="count($capa)">
0N/A <
xsl:
text> case </
xsl:
text>
0N/A <
xsl:
value-
of select="@const"/>
0N/A return capabilities_ptr-></
xsl:
text>
0N/A <
xsl:
value-
of select="$capa/@id"/>
0N/A // if it does not have a capability it is required
0N/A<
xsl:
template match="functionsection">
0N/A <
xsl:
if test="$trace='Trace'">
0N/A<!-- all this just to return the highest function number --> 0N/A <
xsl:
variable name="maxFunction">
0N/A <
xsl:
variable name="mynum" select="@num"/>
0N/A <
xsl:
value-
of select="@num"/>
0N/A <
xsl:
text>jbyte JvmtiTrace::_trace_flags[</
xsl:
text>
0N/A <
xsl:
value-
of select="1+$maxFunction"/>
0N/Ajint JvmtiTrace::_max_function_index = </
xsl:
text>
0N/A <
xsl:
value-
of select="$maxFunction"/>
0N/Aconst char* JvmtiTrace::_function_names[] = {
0N/A <
xsl:
call-
template name="fillEntityName">
0N/A </
xsl:
call-
template>
0N/Ashort JvmtiTrace::_exclude_functions[] = {
0N/A <
xsl:
sort select="@num"/>
0N/A </
xsl:
apply-
templates>
0N/A <
xsl:
apply-
templates select="category" mode="wrapper"/>
0N/A} /* end extern "C" */
0N/A// JVMTI API functions
0N/Astruct jvmtiInterface_1_ jvmti</
xsl:
text>
0N/A <
xsl:
value-
of select="$trace"/>
0N/A <
xsl:
text>_Interface = {
0N/A <
xsl:
call-
template name="fillFuncStruct">
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template match="function" mode="functionid">
0N/A <
xsl:
text>jvmti</
xsl:
text>
0N/A <
xsl:
value-
of select="$trace"/>
0N/A <
xsl:
text>_</
xsl:
text>
0N/A <
xsl:
value-
of select="@id"/>
0N/A<
xsl:
template name="fillFuncStructDoit">
0N/A <
xsl:
param name="func"/>
0N/A <
xsl:
param name="index"/>
0N/A <
xsl:
text> /* </
xsl:
text>
0N/A <
xsl:
number value="$index" format=" 1"/>
0N/A <
xsl:
text> : </
xsl:
text>
0N/A <
xsl:
when test="count($func)=1">
0N/A <
xsl:
apply-
templates select="$func" mode="functionid"/>
0N/A <
xsl:
text> RESERVED */
0N/A<!-- generic function iterator applied to the function structure --> 0N/A<
xsl:
template name="fillFuncStruct">
0N/A <
xsl:
param name="funcs"/>
0N/A <
xsl:
param name="index" select="1"/>
0N/A <
xsl:
call-
template name="fillFuncStructDoit">
0N/A <
xsl:
with-
param name="func" select="$funcs[@num=$index]"/>
0N/A <
xsl:
with-
param name="index" select="$index"/>
0N/A </
xsl:
call-
template>
0N/A <
xsl:
if test="count($funcs[@num > $index]) > 0">
0N/A <
xsl:
call-
template name="fillFuncStruct">
0N/A <
xsl:
with-
param name="funcs" select="$funcs"/>
0N/A <
xsl:
with-
param name="index" select="1+$index"/>
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template name="fillEntityNameDoit">
0N/A <
xsl:
param name="entity"/>
0N/A <
xsl:
param name="index"/>
0N/A <
xsl:
when test="count($entity) > 0">
0N/A <
xsl:
text> "</
xsl:
text>
0N/A <
xsl:
value-
of select="$entity[position()=1]/@id"/>
0N/A <
xsl:
text>"</
xsl:
text>
0N/A <
xsl:
text> NULL</
xsl:
text>
0N/A<!-- generic entity (with id and num) iterator applied to entity names --> 0N/A<
xsl:
template name="fillEntityName">
0N/A <
xsl:
param name="entities"/>
0N/A <
xsl:
param name="index" select="0"/>
0N/A <
xsl:
call-
template name="fillEntityNameDoit">
0N/A <
xsl:
with-
param name="entity" select="$entities[@num=$index]"/>
0N/A <
xsl:
with-
param name="index" select="$index"/>
0N/A </
xsl:
call-
template>
0N/A <
xsl:
if test="count($entities[@num > $index]) > 0">
0N/A <
xsl:
call-
template name="fillEntityName">
0N/A <
xsl:
with-
param name="entities" select="$entities"/>
0N/A <
xsl:
with-
param name="index" select="1+$index"/>
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template name="fillEventThreadedDoit">
0N/A <
xsl:
param name="entity"/>
0N/A <
xsl:
param name="index"/>
0N/A <
xsl:
when test="count($entity) > 0">
0N/A <
xsl:
when test="count($entity[position()=1]/@filtered)=0">
0N/A <
xsl:
text> false</
xsl:
text>
0N/A <
xsl:
text> true</
xsl:
text>
0N/A <
xsl:
text> false</
xsl:
text>
0N/A<
xsl:
template name="fillEventThreaded">
0N/A <
xsl:
param name="entities"/>
0N/A <
xsl:
param name="index" select="0"/>
0N/A <
xsl:
call-
template name="fillEventThreadedDoit">
0N/A <
xsl:
with-
param name="entity" select="$entities[@num=$index]"/>
0N/A <
xsl:
with-
param name="index" select="$index"/>
0N/A </
xsl:
call-
template>
0N/A <
xsl:
if test="count($entities[@num > $index]) > 0">
0N/A <
xsl:
call-
template name="fillEventThreaded">
0N/A <
xsl:
with-
param name="entities" select="$entities"/>
0N/A <
xsl:
with-
param name="index" select="1+$index"/>
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template match="function" mode="notrace">
0N/A <
xsl:
if test="count(@impl)=1 and contains(@impl,'notrace')">
0N/A <
xsl:
value-
of select="@num"/>
0N/A<
xsl:
template match="category" mode="wrapper">
0N/A // </
xsl:
text><
xsl:
value-
of select="@label"/><
xsl:
text> functions
0N/A <
xsl:
apply-
templates select="function[count(@hide)=0]"/>
0N/A<
xsl:
template match="function" mode="transition">
0N/A <
xsl:
param name="space">
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
when test="count(@callbacksafe)=0 or not(contains(@callbacksafe,'safe'))">
0N/A <
xsl:
text>if (this_thread == NULL || !this_thread->is_Java_thread()) {</
xsl:
text>
0N/A <
xsl:
when test="count(@phase)=0 or contains(@phase,'live') or contains(@phase,'start')">
0N/A <
xsl:
text>if (this_thread == NULL || (!this_thread->is_Java_thread() && !this_thread->is_VM_thread())) {</
xsl:
text>
0N/A <
xsl:
text>if (!this_thread->is_Java_thread()) {</
xsl:
text>
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text> if (trace_flags) {</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text> tty->print_cr("JVMTI [non-attached thread] %s %s", func_name,</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text> JvmtiUtil::error_name(JVMTI_ERROR_UNATTACHED_THREAD));</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text> }</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text> return JVMTI_ERROR_UNATTACHED_THREAD;</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text>}</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
if test="count(@impl)=0 or not(contains(@impl,'innative'))">
0N/A <
xsl:
text>JavaThread* current_thread = (JavaThread*)this_thread;</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text>ThreadInVMfromNative __tiv(current_thread);</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
2883N/A <
xsl:
text>VM_ENTRY_BASE(jvmtiError, </
xsl:
text>
0N/A <
xsl:
apply-
templates select="." mode="functionid"/>
0N/A <
xsl:
text> , current_thread)</
xsl:
text>
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text>debug_only(VMNativeEntryWrapper __vew;)</
xsl:
text>
0N/A <
xsl:
if test="count(@callbacksafe)=0 or not(contains(@callbacksafe,'safe'))">
0N/A <
xsl:
value-
of select="$space"/>
0N/A <
xsl:
text>CautiouslyPreserveExceptionMark __em(this_thread);</
xsl:
text>
0N/A<
xsl:
template match="required">
0N/A if (jvmti_env->get_capabilities()-></
xsl:
text>
0N/A <
xsl:
value-
of select="@id"/>
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> if (trace_flags) {
0N/A tty->print_cr("JVMTI [%s] %s %s", curr_thread_name, func_name,
0N/A JvmtiUtil::error_name(JVMTI_ERROR_MUST_POSSESS_CAPABILITY));
0N/A <
xsl:
text> return JVMTI_ERROR_MUST_POSSESS_CAPABILITY;
0N/A<
xsl:
template match="function">
0N/Astatic jvmtiError JNICALL
0N/A <
xsl:
apply-
templates select="." mode="functionid"/>
0N/A <
xsl:
text>(jvmtiEnv* env</
xsl:
text>
0N/A <
xsl:
apply-
templates select="parameters" mode="signature"/>
0N/A <
xsl:
if test="not(contains(@jkernel,'yes'))">
0N/A <
xsl:
text>
#ifdef JVMTI_KERNEL 
</
xsl:
text>
0N/A <
xsl:
text> return JVMTI_ERROR_NOT_AVAILABLE; 
</
xsl:
text>
0N/A <
xsl:
text>#else 
</
xsl:
text>
0N/A <
xsl:
apply-
templates select="." mode="traceSetUp"/>
0N/A <
xsl:
when test="count(@phase)=0 or contains(@phase,'live')">
0N/A <
xsl:
text> if(!JvmtiEnv::is_vm_live()) {
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> if (trace_flags) {
0N/A tty->print_cr("JVMTI [-] %s %s", func_name,
0N/A JvmtiUtil::error_name(JVMTI_ERROR_WRONG_PHASE));
0N/A <
xsl:
text> return JVMTI_ERROR_WRONG_PHASE;
0N/A Thread* this_thread = (Thread*)ThreadLocalStorage::thread(); </
xsl:
text>
0N/A <
xsl:
apply-
templates select="." mode="transition"/>
0N/A <
xsl:
if test="contains(@phase,'onload')">
0N/A <
xsl:
text> if(JvmtiEnv::get_phase()!=JVMTI_PHASE_ONLOAD</
xsl:
text>
0N/A <
xsl:
if test="not(contains(@phase,'onloadOnly'))">
0N/A <
xsl:
text> && JvmtiEnv::get_phase()!=JVMTI_PHASE_LIVE</
xsl:
text>
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> if (trace_flags) {
0N/A tty->print_cr("JVMTI [-] %s %s", func_name,
0N/A JvmtiUtil::error_name(JVMTI_ERROR_WRONG_PHASE));
0N/A <
xsl:
text> return JVMTI_ERROR_WRONG_PHASE;
0N/A <
xsl:
if test="contains(@phase,'start')">
0N/A <
xsl:
text> if(JvmtiEnv::get_phase()!=JVMTI_PHASE_START && JvmtiEnv::get_phase()!=JVMTI_PHASE_LIVE) {
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> if (trace_flags) {
0N/A tty->print_cr("JVMTI [-] %s %s", func_name,
0N/A JvmtiUtil::error_name(JVMTI_ERROR_WRONG_PHASE));
0N/A <
xsl:
text> return JVMTI_ERROR_WRONG_PHASE;
0N/A Thread* this_thread = (Thread*)ThreadLocalStorage::thread(); </
xsl:
text>
0N/A <
xsl:
apply-
templates select="." mode="transition"/>
0N/A JvmtiEnv* jvmti_env = JvmtiEnv::JvmtiEnv_from_jvmti_env(env);
0N/A if (!jvmti_env->is_valid()) {
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> if (trace_flags) {
0N/A tty->print_cr("JVMTI [%s] %s %s env=%d", curr_thread_name, func_name,
0N/A JvmtiUtil::error_name(JVMTI_ERROR_INVALID_ENVIRONMENT), env);
0N/A <
xsl:
text> return JVMTI_ERROR_INVALID_ENVIRONMENT;
0N/A <
xsl:
text> jvmtiError err;
0N/A <
xsl:
when test="count(@phase)=1 and not(contains(@phase,'live')) and not(contains(@phase,'start'))">
0N/A <
xsl:
when test="count(@callbacksafe)=0 or not(contains(@callbacksafe,'safe'))">
0N/A <
xsl:
text> if (Threads::number_of_threads() != 0) {
0N/A Thread* this_thread = (Thread*)ThreadLocalStorage::thread();</
xsl:
text>
0N/A <
xsl:
text> Thread* this_thread = NULL;
0N/A if (Threads::number_of_threads() == 0) {
0N/A this_thread = (Thread*)ThreadLocalStorage::thread();
0N/A transition = ((this_thread != NULL) && !this_thread->is_VM_thread() && !this_thread->is_ConcurrentGC_thread());
0N/A if (transition) {</
xsl:
text>
0N/A <!-- we allow use in early phases but there are threads now, --> 0N/A <!-- so do thread transition --> 0N/A <
xsl:
apply-
templates select="." mode="transition">
0N/A <
xsl:
with-
param name="space">
0N/A </
xsl:
apply-
templates>
0N/A <
xsl:
apply-
templates select="." mode="doCall"/>
0N/A <!-- we are pre-thread - no thread transition code --> 0N/A <
xsl:
apply-
templates select="." mode="doCall"/>
0N/A <
xsl:
apply-
templates select="." mode="doCall"/>
0N/A <
xsl:
text> return err;
0N/A <
xsl:
if test="not(contains(@jkernel,'yes'))">
0N/A <
xsl:
text>#endif // JVMTI_KERNEL
</
xsl:
text>
0N/A <
xsl:
text>}
</
xsl:
text>
0N/A<
xsl:
template match="function" mode="doCall">
0N/A <
xsl:
apply-
templates select="parameters" mode="dochecks"/>
0N/A <
xsl:
apply-
templates select="." mode="traceBefore"/>
0N/A <
xsl:
apply-
templates select="." mode="genCall"/>
0N/A <
xsl:
apply-
templates select="." mode="traceAfter"/>
0N/A<
xsl:
template match="function" mode="genCall">
0N/A <
xsl:
text> err = jvmti_env-></
xsl:
text>
0N/A <
xsl:
value-
of select="@id"/>
0N/A <
xsl:
text>(</
xsl:
text>
0N/A <
xsl:
apply-
templates select="parameters" mode="HotSpotValue"/>
0N/A<
xsl:
template match="function" mode="traceSetUp">
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> SafeResourceMark rm;
0N/A jint trace_flags = JvmtiTrace::trace_flags(</
xsl:
text>
0N/A <
xsl:
value-
of select="@num"/>
0N/A const char *func_name;
0N/A const char *curr_thread_name;
0N/A func_name = JvmtiTrace::function_name(</
xsl:
text>
0N/A <
xsl:
value-
of select="@num"/>
0N/A curr_thread_name = JvmtiTrace::safe_get_current_thread_name();
0N/A<
xsl:
template match="function" mode="traceBefore">
0N/A <
xsl:
if test="$trace='Trace'">
0N/A if ((trace_flags & JvmtiTrace::SHOW_IN) != 0) {
0N/A <
xsl:
apply-
templates select="." mode="traceIn"/>
0N/A<
xsl:
template match="param" mode="traceError">
0N/A <
xsl:
param name="err"/>
0N/A <
xsl:
param name="comment"></
xsl:
param>
0N/A <
xsl:
param name="extraValue"></
xsl:
param>
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> if ((trace_flags & JvmtiTrace::SHOW_ERROR) != 0) {
0N/A if ((trace_flags & JvmtiTrace::SHOW_IN) == 0) {
0N/A <
xsl:
apply-
templates select="../.." mode="traceIn">
0N/A <
xsl:
with-
param name="endParam" select="."/>
0N/A </
xsl:
apply-
templates>
0N/A tty->print_cr("JVMTI [%s] %s } %s - erroneous arg is </
xsl:
text>
0N/A <
xsl:
value-
of select="@id"/>
0N/A <
xsl:
value-
of select="$comment"/>
0N/A <
xsl:
text>", curr_thread_name, func_name,
0N/A JvmtiUtil::error_name(</
xsl:
text>
0N/A <
xsl:
value-
of select="$err"/>
0N/A <
xsl:
text>)</
xsl:
text>
0N/A <
xsl:
value-
of select="$extraValue"/>
0N/A <
xsl:
text> return </
xsl:
text>
0N/A <
xsl:
value-
of select="$err"/>
0N/A <
xsl:
text>;</
xsl:
text>
0N/A<
xsl:
template match="function" mode="traceAfter">
0N/A <
xsl:
if test="$trace='Trace'">
0N/A <
xsl:
text> if ( err != JVMTI_ERROR_NONE && (trace_flags & JvmtiTrace::SHOW_ERROR) != 0) {
0N/A if ((trace_flags & JvmtiTrace::SHOW_IN) == 0) {
0N/A <
xsl:
apply-
templates select="." mode="traceIn"/>
0N/A tty->print_cr("JVMTI [%s] %s } %s", curr_thread_name, func_name,
0N/A JvmtiUtil::error_name(err));
0N/A } else if ((trace_flags & JvmtiTrace::SHOW_OUT) != 0) {
0N/A tty->print_cr("JVMTI [%s] %s }", curr_thread_name, func_name);
0N/A<
xsl:
template match="function" mode="traceIn">
0N/A <
xsl:
param name="endParam"></
xsl:
param>
0N/A <
xsl:
text> tty->print_cr("JVMTI [%s] %s { </
xsl:
text>
0N/A <
xsl:
apply-
templates select="parameters" mode="traceInFormat">
0N/A <
xsl:
with-
param name="endParam" select="$endParam"/>
0N/A </
xsl:
apply-
templates>
0N/A <
xsl:
text>", curr_thread_name, func_name</
xsl:
text>
0N/A <
xsl:
apply-
templates select="parameters" mode="traceInValue">
0N/A <
xsl:
with-
param name="endParam" select="$endParam"/>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="parameters" mode="dochecks">
0N/A <
xsl:
apply-
templates select="param" mode="dochecks"/>
0N/A<
xsl:
template match="param" mode="dochecks">
0N/A <
xsl:
apply-
templates select="child::*[position()=1]" mode="dochecks">
0N/A <
xsl:
with-
param name="name" select="@id"/>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="outptr|outbuf|allocfieldbuf|ptrtype|inptr|inbuf|vmbuf|allocbuf|agentbuf|allocallocbuf" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
if test="count(nullok)=0">
0N/A <
xsl:
text> if (</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text> == NULL) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_NULL_POINTER</
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="jrawMonitorID" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> JvmtiRawMonitor *rmonitor = (JvmtiRawMonitor *)</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A if (rmonitor == NULL) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_MONITOR</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="comment"> - raw monitor is NULL</
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A if (!rmonitor->is_valid()) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_MONITOR</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="comment"> - not a raw monitor 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, rmonitor</
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="jthread" mode="dochecksbody">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> oop thread_oop = JNIHandles::resolve_external_guard(</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A if (thread_oop == NULL) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_THREAD</
xsl:
with-
param>
4348N/A <
xsl:
with-
param name="comment"> - jthread resolved to NULL - jthread = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
1142N/A if (!thread_oop->is_a(SystemDictionary::Thread_klass())) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_THREAD</
xsl:
with-
param>
4348N/A <
xsl:
with-
param name="comment"> - oop is not a thread - jthread = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A java_thread = java_lang_Thread::thread(thread_oop);
0N/A if (java_thread == NULL) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">
0N/A <
xsl:
text>JVMTI_ERROR_THREAD_NOT_ALIVE</
xsl:
text>
4348N/A <
xsl:
with-
param name="comment"> - not a Java thread - jthread = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="jthread" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <!-- If we convert and test threads --> 0N/A <
xsl:
if test="count(@impl)=0 or not(contains(@impl,'noconvert'))">
0N/A <
xsl:
text> JavaThread* java_thread;
0N/A <
xsl:
when test="count(@null)=0">
0N/A <
xsl:
apply-
templates select="." mode="dochecksbody">
0N/A <
xsl:
with-
param name="name" select="$name"/>
0N/A </
xsl:
apply-
templates>
0N/A <
xsl:
text> if (</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text> == NULL) {
0N/A java_thread = current_thread;
0N/A <
xsl:
apply-
templates select="." mode="dochecksbody">
0N/A <
xsl:
with-
param name="name" select="$name"/>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="jframeID" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_ILLEGAL_ARGUMENT</
xsl:
with-
param>
4348N/A <
xsl:
with-
param name="comment"> - negative depth - jthread = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="jclass" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
if test="count(@method)=0">
0N/A <
xsl:
text> oop k_mirror = JNIHandles::resolve_external_guard(</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A if (k_mirror == NULL) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_CLASS</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="comment"> - resolved to NULL - jclass = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
1142N/A if (!k_mirror->is_a(SystemDictionary::Class_klass())) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_CLASS</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="comment"> - not a class - jclass = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A <
xsl:
if test="count(@method|@field)=1">
0N/A if (java_lang_Class::is_primitive(k_mirror)) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_CLASS</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="comment"> - is a primitive class - jclass = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A klassOop k_oop = java_lang_Class::as_klassOop(k_mirror);
0N/A if (k_oop == NULL) {
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_CLASS</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="comment"> - no klassOop - jclass = 0x%x</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue">, <
xsl:
value-
of select="$name"/></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="jmethodID" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> methodOop method_oop = JNIHandles::checked_resolve_jmethod_id(</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>);
</
xsl:
text>
0N/A <
xsl:
text> if (method_oop == NULL) {
</
xsl:
text>
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_METHODID</
xsl:
with-
param>
0N/A <
xsl:
with-
param name="comment"></
xsl:
with-
param>
0N/A <
xsl:
with-
param name="extraValue"></
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A <
xsl:
text>
</
xsl:
text>
0N/A <
xsl:
text> }
</
xsl:
text>
0N/A <
xsl:
if test="count(@native)=1 and contains(@native,'error')">
0N/A <
xsl:
text> if (method_oop->is_native()) {
</
xsl:
text>
0N/A <
xsl:
text> return JVMTI_ERROR_NATIVE_METHOD;
</
xsl:
text>
0N/A <
xsl:
text> }
</
xsl:
text>
0N/A<
xsl:
template match="jfieldID" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> ResourceMark rm_fdesc(current_thread);
</
xsl:
text>
0N/A <
xsl:
text> fieldDescriptor fdesc;
</
xsl:
text>
0N/A <
xsl:
text> if (!JvmtiEnv::get_field_descriptor(k_oop, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>, &fdesc)) {
</
xsl:
text>
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_INVALID_FIELDID</
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A <
xsl:
text>
</
xsl:
text>
0N/A <
xsl:
text> }
</
xsl:
text>
0N/A<
xsl:
template match="jint" mode="dochecks">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
if test="count(@min)=1">
0N/A <
xsl:
text> if (</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text> < </
xsl:
text>
0N/A <
xsl:
value-
of select="@min"/>
0N/A <
xsl:
apply-
templates select=".." mode="traceError">
0N/A <
xsl:
with-
param name="err">JVMTI_ERROR_ILLEGAL_ARGUMENT</
xsl:
with-
param>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="jobject|jvalue|jthreadGroup|enum|jchar|jlong|jfloat|jdouble|jlocation|jboolean|char|uchar|size_t|void|struct" mode="dochecks">
0N/A<!-- iterate over parameters, stopping if specified is encountered --> 0N/A<
xsl:
template name="traceInValueParamsUpTo">
0N/A <
xsl:
param name="params"/>
0N/A <
xsl:
param name="endParam"></
xsl:
param>
0N/A <
xsl:
param name="index" select="1"/>
0N/A <
xsl:
variable name="cParam" select="$params[position()=$index]"/>
0N/A <
xsl:
if test="$cParam!=$endParam">
0N/A <
xsl:
apply-
templates select="$cParam" mode="traceInValue"/>
0N/A <
xsl:
if test="count($params) > $index">
0N/A <
xsl:
call-
template name="traceInValueParamsUpTo">
0N/A <
xsl:
with-
param name="params" select="$params"/>
0N/A <
xsl:
with-
param name="endParam" select="$endParam"/>
0N/A <
xsl:
with-
param name="index" select="1+$index"/>
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template name="traceInFormatParamsUpTo">
0N/A <
xsl:
param name="params"/>
0N/A <
xsl:
param name="endParam"></
xsl:
param>
0N/A <
xsl:
param name="index" select="1"/>
0N/A <
xsl:
variable name="cParam" select="$params[position()=$index]"/>
0N/A <
xsl:
if test="$cParam!=$endParam">
0N/A <
xsl:
apply-
templates select="$cParam" mode="traceInFormat"/>
0N/A <
xsl:
if test="count($params) > $index">
0N/A <
xsl:
call-
template name="traceInFormatParamsUpTo">
0N/A <
xsl:
with-
param name="params" select="$params"/>
0N/A <
xsl:
with-
param name="endParam" select="$endParam"/>
0N/A <
xsl:
with-
param name="index" select="1+$index"/>
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template match="parameters" mode="traceInFormat">
0N/A <
xsl:
param name="endParam"></
xsl:
param>
0N/A <
xsl:
call-
template name="traceInFormatParamsUpTo">
0N/A <
xsl:
with-
param name="params" select="param"/>
0N/A <
xsl:
with-
param name="endParam" select="$endParam"/>
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template match="parameters" mode="traceInValue">
0N/A <
xsl:
param name="endParam"></
xsl:
param>
0N/A <
xsl:
call-
template name="traceInValueParamsUpTo">
0N/A <
xsl:
with-
param name="params" select="param"/>
0N/A <
xsl:
with-
param name="endParam" select="$endParam"/>
0N/A </
xsl:
call-
template>
0N/A<
xsl:
template match="param" mode="traceInFormat">
0N/A <
xsl:
apply-
templates select="child::*[position()=1]" mode="traceInFormat">
0N/A <
xsl:
with-
param name="name" select="@id"/>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="param" mode="traceInValue">
0N/A <
xsl:
apply-
templates select="child::*[position()=1]" mode="traceInValue">
0N/A <
xsl:
with-
param name="name" select="@id"/>
0N/A </
xsl:
apply-
templates>
0N/A<
xsl:
template match="outptr|outbuf|allocfieldbuf|vmbuf|allocbuf|agentbuf|allocallocbuf" mode="traceInFormat">
0N/A<
xsl:
template match="outptr|outbuf|allocfieldbuf|vmbuf|allocbuf|agentbuf|allocallocbuf" mode="traceInValue">
0N/A<
xsl:
template match="inbuf" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
variable name="child" select="child::*[position()=1]"/>
0N/A <
xsl:
when test="name($child)='char'">
0N/A <
xsl:
text>='%s'</
xsl:
text>
0N/A <
xsl:
text>=0x%x</
xsl:
text>
0N/A<
xsl:
template match="inbuf" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A<
xsl:
template match="ptrtype" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
variable name="child" select="child::*[position()=1]"/>
0N/A <
xsl:
when test="name($child)='jclass'">
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=0x%x</
xsl:
text>
0N/A <
xsl:
apply-
templates select="$child" mode="traceInFormat"/>
0N/A<
xsl:
template match="ptrtype" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
variable name="child" select="child::*[position()=1]"/>
0N/A <
xsl:
when test="name($child)='jclass'">
0N/A <
xsl:
text>, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
apply-
templates select="$child" mode="traceInValue"/>
0N/A<
xsl:
template match="inptr" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=0x%x</
xsl:
text>
0N/A<
xsl:
template match="inptr" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A<
xsl:
template match="jrawMonitorID|jfieldID" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%s</
xsl:
text>
0N/A<
xsl:
template match="jclass" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
if test="count(@method)=0">
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%s</
xsl:
text>
0N/A<
xsl:
template match="jrawMonitorID" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>, rmonitor->get_name()</
xsl:
text>
0N/A<
xsl:
template match="jthread" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <!-- If we convert and test threads --> 0N/A <
xsl:
if test="count(@impl)=0 or not(contains(@impl,'noconvert'))">
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%s</
xsl:
text>
0N/A<
xsl:
template match="jthread" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <!-- If we convert and test threads --> 0N/A <
xsl:
if test="count(@impl)=0 or not(contains(@impl,'noconvert'))">
0N/A JvmtiTrace::safe_get_thread_name(java_thread)</
xsl:
text>
0N/A<
xsl:
template match="jframeID" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>depth=%d</
xsl:
text>
0N/A<
xsl:
template match="jframeID" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A<
xsl:
template match="jclass" mode="traceInValue">
0N/A <
xsl:
if test="count(@method)=0">
0N/A JvmtiTrace::get_class_name(k_mirror)</
xsl:
text>
0N/A<
xsl:
template match="jmethodID" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%s.%s</
xsl:
text>
0N/A<
xsl:
template match="jmethodID" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A method_oop == NULL? "NULL" : method_oop->klass_name()->as_C_string(),
0N/A method_oop == NULL? "NULL" : method_oop->name()->as_C_string()
0N/A<
xsl:
template match="jfieldID" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A<
xsl:
template match="enum" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%d:%s</
xsl:
text>
0N/A<
xsl:
template match="enum" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
when test=".='jvmtiError'">
0N/A <
xsl:
text>JvmtiUtil::error_name(</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
when test=".='jvmtiEvent'">
0N/A <
xsl:
text>JvmtiTrace::event_name(</
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>JvmtiTrace::enum_name(</
xsl:
text>
0N/A <
xsl:
value-
of select="."/>
0N/A <
xsl:
text>ConstantNames, </
xsl:
text>
0N/A <
xsl:
value-
of select="."/>
0N/A <
xsl:
text>ConstantValues, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>)</
xsl:
text>
0N/A<
xsl:
template match="jint|jlocation" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%d</
xsl:
text>
0N/A<
xsl:
template match="jlong" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%ld</
xsl:
text>
0N/A<
xsl:
template match="size_t" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=0x%zx</
xsl:
text>
0N/A<
xsl:
template match="jfloat|jdouble" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%f</
xsl:
text>
0N/A<
xsl:
template match="char" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%c</
xsl:
text>
0N/A<
xsl:
template match="uchar|jchar" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=0x%x</
xsl:
text>
0N/A<
xsl:
template match="jint|jlocation|jchar|jlong|jfloat|jdouble|char|uchar|size_t" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A<
xsl:
template match="jboolean" mode="traceInFormat">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text> </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>=%s</
xsl:
text>
0N/A<
xsl:
template match="jboolean" mode="traceInValue">
0N/A <
xsl:
param name="name"/>
0N/A <
xsl:
text>, </
xsl:
text>
0N/A <
xsl:
value-
of select="$name"/>
0N/A <
xsl:
text>? "true" : "false"</
xsl:
text>
0N/A<
xsl:
template match="jobject|jvalue|jthreadGroup|void|struct" mode="traceInFormat">
0N/A<
xsl:
template match="jobject|jvalue|jthreadGroup|void|struct" mode="traceInValue">