hotspot/src/share/vm/prims/jvm.h
author kevinw
Wed, 12 Jan 2011 15:44:16 +0000
changeset 7900 4c7fc6332f7e
parent 7439 572e3f624901
child 8106 19106a0203fb
permissions -rw-r--r--
6994753: Implement optional hook to a Java method at VM startup. Reviewed-by: mchung, acorn
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
7900
4c7fc6332f7e 6994753: Implement optional hook to a Java method at VM startup.
kevinw
parents: 7439
diff changeset
     2
 * Copyright (c) 1997, 2011, Oracle and/or its affiliates. All rights reserved.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 3829
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 3829
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 3829
diff changeset
    21
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    25
#ifndef SHARE_VM_PRIMS_JVM_H
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    26
#define SHARE_VM_PRIMS_JVM_H
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    27
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    28
#include "prims/jni.h"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    29
#include "runtime/reflectionCompat.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    30
#ifdef TARGET_OS_FAMILY_linux
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    31
# include "jvm_linux.h"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    32
#endif
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    33
#ifdef TARGET_OS_FAMILY_solaris
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    34
# include "jvm_solaris.h"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    35
#endif
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    36
#ifdef TARGET_OS_FAMILY_windows
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    37
# include "jvm_windows.h"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    38
#endif
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
    39
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
#ifndef _JAVASOFT_JVM_H_
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
#define _JAVASOFT_JVM_H_
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
// HotSpot integration note:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
// This file and jvm.h used with the JDK are identical,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
// except for the three includes removed below and the
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
// SUPPORT_OLD_REFLECTION sections cut out of the JDK's jvm.h.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
489c9b5090e2 Initial load
duke
parents:
diff changeset
    49
// #include <sys/stat.h>
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
// #include "jni.h"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
// #include "jvm_md.h"
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
#ifdef __cplusplus
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
extern "C" {
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
 * This file contains additional functions exported from the VM.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
 * These functions are complementary to the standard JNI support.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
 * There are three parts to this file:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
 * First, this file contains the VM-related functions needed by native
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
 * libraries in the standard Java API. For example, the java.lang.Object
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
 * class needs VM-level functions that wait for and notify monitors.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
 * Second, this file contains the functions and constant definitions
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
 * needed by the byte code verifier and class file format checker.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
 * These functions allow the verifier and format checker to be written
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
 * in a VM-independent way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
 * Third, this file contains various I/O and nerwork operations needed
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
 * by the standard Java I/O and network APIs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
 * Bump the version number when either of the following happens:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
 * 1. There is a change in JVM_* functions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
 * 2. There is a change in the contract between VM and Java classes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
 *    For example, if the VM relies on a new private field in Thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
 *    class.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
#define JVM_INTERFACE_VERSION 4
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
JVM_GetInterfaceVersion(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
/*************************************************************************
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
 PART 1: Functions for Native Libraries
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
 ************************************************************************/
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
 * java.lang.Object
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
JVM_IHashCode(JNIEnv *env, jobject obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
JVM_MonitorWait(JNIEnv *env, jobject obj, jlong ms);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
JVM_MonitorNotify(JNIEnv *env, jobject obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
JVM_MonitorNotifyAll(JNIEnv *env, jobject obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
JVM_Clone(JNIEnv *env, jobject obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
 * java.lang.String
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
JNIEXPORT jstring JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
JVM_InternString(JNIEnv *env, jstring str);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
 * java.lang.System
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
JNIEXPORT jlong JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
JVM_CurrentTimeMillis(JNIEnv *env, jclass ignored);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
JNIEXPORT jlong JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
JVM_NanoTime(JNIEnv *env, jclass ignored);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
JVM_ArrayCopy(JNIEnv *env, jclass ignored, jobject src, jint src_pos,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
              jobject dst, jint dst_pos, jint length);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
JVM_InitProperties(JNIEnv *env, jobject p);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
 * java.io.File
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
JVM_OnExit(void (*func)(void));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
 * java.lang.Runtime
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
JVM_Exit(jint code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
JVM_Halt(jint code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
JVM_GC(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
/* Returns the number of real-time milliseconds that have elapsed since the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
 * least-recently-inspected heap object was last inspected by the garbage
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
 * collector.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
 * For simple stop-the-world collectors this value is just the time
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
 * since the most recent collection.  For generational collectors it is the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
 * time since the oldest generation was most recently collected.  Other
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
 * collectors are free to return a pessimistic estimate of the elapsed time, or
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
 * simply the time since the last full collection was performed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
 * Note that in the presence of reference objects, a given object that is no
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
 * longer strongly reachable may have to be inspected multiple times before it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
 * can be reclaimed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
JNIEXPORT jlong JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
JVM_MaxObjectInspectionAge(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
JVM_TraceInstructions(jboolean on);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
JVM_TraceMethodCalls(jboolean on);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
JNIEXPORT jlong JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
JVM_TotalMemory(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
JNIEXPORT jlong JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
JVM_FreeMemory(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
JNIEXPORT jlong JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
JVM_MaxMemory(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
JVM_ActiveProcessorCount(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
JNIEXPORT void * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
JVM_LoadLibrary(const char *name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
JVM_UnloadLibrary(void * handle);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   193
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
JNIEXPORT void * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
JVM_FindLibraryEntry(void *handle, const char *name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   198
JVM_IsSupportedJNIVersion(jint version);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   199
489c9b5090e2 Initial load
duke
parents:
diff changeset
   200
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   201
 * java.lang.Float and java.lang.Double
489c9b5090e2 Initial load
duke
parents:
diff changeset
   202
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   203
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   204
JVM_IsNaN(jdouble d);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   205
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   207
 * java.lang.Throwable
489c9b5090e2 Initial load
duke
parents:
diff changeset
   208
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   209
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   210
JVM_FillInStackTrace(JNIEnv *env, jobject throwable);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   211
489c9b5090e2 Initial load
duke
parents:
diff changeset
   212
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
JVM_PrintStackTrace(JNIEnv *env, jobject throwable, jobject printable);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   214
489c9b5090e2 Initial load
duke
parents:
diff changeset
   215
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
JVM_GetStackTraceDepth(JNIEnv *env, jobject throwable);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   217
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   219
JVM_GetStackTraceElement(JNIEnv *env, jobject throwable, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   222
 * java.lang.Compiler
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   225
JVM_InitializeCompiler (JNIEnv *env, jclass compCls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
JVM_IsSilentCompiler(JNIEnv *env, jclass compCls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   229
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
JVM_CompileClass(JNIEnv *env, jclass compCls, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
489c9b5090e2 Initial load
duke
parents:
diff changeset
   233
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
JVM_CompileClasses(JNIEnv *env, jclass cls, jstring jname);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
JVM_CompilerCommand(JNIEnv *env, jclass compCls, jobject arg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   238
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
JVM_EnableCompiler(JNIEnv *env, jclass compCls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
JVM_DisableCompiler(JNIEnv *env, jclass compCls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
 * java.lang.Thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
JVM_StartThread(JNIEnv *env, jobject thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
489c9b5090e2 Initial load
duke
parents:
diff changeset
   251
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
JVM_StopThread(JNIEnv *env, jobject thread, jobject exception);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
JVM_IsThreadAlive(JNIEnv *env, jobject thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
489c9b5090e2 Initial load
duke
parents:
diff changeset
   257
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
JVM_SuspendThread(JNIEnv *env, jobject thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
JVM_ResumeThread(JNIEnv *env, jobject thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
JVM_SetThreadPriority(JNIEnv *env, jobject thread, jint prio);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   265
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
JVM_Yield(JNIEnv *env, jclass threadClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
JVM_Sleep(JNIEnv *env, jclass threadClass, jlong millis);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
JVM_CurrentThread(JNIEnv *env, jclass threadClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
JVM_CountStackFrames(JNIEnv *env, jobject thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
JVM_Interrupt(JNIEnv *env, jobject thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
JVM_IsInterrupted(JNIEnv *env, jobject thread, jboolean clearInterrupted);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
JVM_HoldsLock(JNIEnv *env, jclass threadClass, jobject obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   286
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
JVM_DumpAllStacks(JNIEnv *env, jclass unused);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
JVM_GetAllThreads(JNIEnv *env, jclass dummy);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
/* getStackTrace() and getAllStackTraces() method */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
JVM_DumpThreads(JNIEnv *env, jclass threadClass, jobjectArray threads);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   298
 * java.lang.SecurityManager
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
JVM_CurrentLoadedClass(JNIEnv *env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
JVM_CurrentClassLoader(JNIEnv *env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
489c9b5090e2 Initial load
duke
parents:
diff changeset
   306
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   307
JVM_GetClassContext(JNIEnv *env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
489c9b5090e2 Initial load
duke
parents:
diff changeset
   309
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
JVM_ClassDepth(JNIEnv *env, jstring name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
489c9b5090e2 Initial load
duke
parents:
diff changeset
   312
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   313
JVM_ClassLoaderDepth(JNIEnv *env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   314
489c9b5090e2 Initial load
duke
parents:
diff changeset
   315
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
 * java.lang.Package
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
JNIEXPORT jstring JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   319
JVM_GetSystemPackage(JNIEnv *env, jstring name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
JVM_GetSystemPackages(JNIEnv *env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
489c9b5090e2 Initial load
duke
parents:
diff changeset
   324
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
 * java.io.ObjectInputStream
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   327
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   328
JVM_AllocateNewObject(JNIEnv *env, jobject obj, jclass currClass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   329
                      jclass initClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   330
489c9b5090e2 Initial load
duke
parents:
diff changeset
   331
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   332
JVM_AllocateNewArray(JNIEnv *env, jobject obj, jclass currClass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
                     jint length);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   334
489c9b5090e2 Initial load
duke
parents:
diff changeset
   335
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   336
JVM_LatestUserDefinedLoader(JNIEnv *env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   337
489c9b5090e2 Initial load
duke
parents:
diff changeset
   338
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   339
 * This function has been deprecated and should not be considered
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
 * part of the specified JVM interface.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   341
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   342
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
JVM_LoadClass0(JNIEnv *env, jobject obj, jclass currClass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   344
               jstring currClassName);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   345
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
 * java.lang.reflect.Array
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   349
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   350
JVM_GetArrayLength(JNIEnv *env, jobject arr);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   351
489c9b5090e2 Initial load
duke
parents:
diff changeset
   352
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   353
JVM_GetArrayElement(JNIEnv *env, jobject arr, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   354
489c9b5090e2 Initial load
duke
parents:
diff changeset
   355
JNIEXPORT jvalue JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   356
JVM_GetPrimitiveArrayElement(JNIEnv *env, jobject arr, jint index, jint wCode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   357
489c9b5090e2 Initial load
duke
parents:
diff changeset
   358
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
JVM_SetArrayElement(JNIEnv *env, jobject arr, jint index, jobject val);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   360
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
JVM_SetPrimitiveArrayElement(JNIEnv *env, jobject arr, jint index, jvalue v,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
                             unsigned char vCode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
489c9b5090e2 Initial load
duke
parents:
diff changeset
   365
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   366
JVM_NewArray(JNIEnv *env, jclass eltClass, jint length);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   367
489c9b5090e2 Initial load
duke
parents:
diff changeset
   368
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   369
JVM_NewMultiArray(JNIEnv *env, jclass eltClass, jintArray dim);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   370
489c9b5090e2 Initial load
duke
parents:
diff changeset
   371
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   372
 * java.lang.Class and java.lang.ClassLoader
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
 * Returns the class in which the code invoking the native method
489c9b5090e2 Initial load
duke
parents:
diff changeset
   376
 * belongs.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
 * Note that in JDK 1.1, native methods did not create a frame.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   379
 * In 1.2, they do. Therefore native methods like Class.forName
489c9b5090e2 Initial load
duke
parents:
diff changeset
   380
 * can no longer look at the current frame for the caller class.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   381
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   382
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   383
JVM_GetCallerClass(JNIEnv *env, int n);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   384
489c9b5090e2 Initial load
duke
parents:
diff changeset
   385
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   386
 * Find primitive classes
489c9b5090e2 Initial load
duke
parents:
diff changeset
   387
 * utf: class name
489c9b5090e2 Initial load
duke
parents:
diff changeset
   388
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
JVM_FindPrimitiveClass(JNIEnv *env, const char *utf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
 * Link the class
489c9b5090e2 Initial load
duke
parents:
diff changeset
   394
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   395
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   396
JVM_ResolveClass(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   397
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   399
 * Find a class from a given class loader. Throw ClassNotFoundException
489c9b5090e2 Initial load
duke
parents:
diff changeset
   400
 * or NoClassDefFoundError depending on the value of the last
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
 * argument.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   404
JVM_FindClassFromClassLoader(JNIEnv *env, const char *name, jboolean init,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   405
                             jobject loader, jboolean throwError);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   406
489c9b5090e2 Initial load
duke
parents:
diff changeset
   407
/*
3578
411436f0a4a2 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 1550
diff changeset
   408
 * Find a class from a boot class loader. Returns NULL if class not found.
772
96110c02b165 6714758: hotspot: provide an entry point to the BootStrap Class loader[dholmes,acorn]
ksrini
parents: 363
diff changeset
   409
 */
96110c02b165 6714758: hotspot: provide an entry point to the BootStrap Class loader[dholmes,acorn]
ksrini
parents: 363
diff changeset
   410
JNIEXPORT jclass JNICALL
3578
411436f0a4a2 6864003: Modify JVM_FindClassFromBootLoader to return null if class not found
mchung
parents: 1550
diff changeset
   411
JVM_FindClassFromBootLoader(JNIEnv *env, const char *name);
772
96110c02b165 6714758: hotspot: provide an entry point to the BootStrap Class loader[dholmes,acorn]
ksrini
parents: 363
diff changeset
   412
96110c02b165 6714758: hotspot: provide an entry point to the BootStrap Class loader[dholmes,acorn]
ksrini
parents: 363
diff changeset
   413
/*
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   414
 * Find a class from a given class.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   415
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   416
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   417
JVM_FindClassFromClass(JNIEnv *env, const char *name, jboolean init,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   418
                             jclass from);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   419
489c9b5090e2 Initial load
duke
parents:
diff changeset
   420
/* Find a loaded class cached by the VM */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   421
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   422
JVM_FindLoadedClass(JNIEnv *env, jobject loader, jstring name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
/* Define a class */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   425
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   426
JVM_DefineClass(JNIEnv *env, const char *name, jobject loader, const jbyte *buf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   427
                jsize len, jobject pd);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   428
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
/* Define a class with a source (added in JDK1.5) */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   431
JVM_DefineClassWithSource(JNIEnv *env, const char *name, jobject loader,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   432
                          const jbyte *buf, jsize len, jobject pd,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   433
                          const char *source);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
3820
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   435
/* Define a class with a source with conditional verification (added HSX 14)
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   436
 * -Xverify:all will verify anyway, -Xverify:none will not verify,
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   437
 * -Xverify:remote (default) will obey this conditional
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   438
 * i.e. true = should_verify_class
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   439
 */
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   440
JNIEXPORT jclass JNICALL
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   441
JVM_DefineClassWithSourceCond(JNIEnv *env, const char *name,
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   442
                              jobject loader, const jbyte *buf,
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   443
                              jsize len, jobject pd, const char *source,
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   444
                              jboolean verify);
0a8fbbe180db 6830542: Performance: JVM_DefineClass already verified.
acorn
parents: 3578
diff changeset
   445
1550
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   446
/* Define a class with a source (MLVM) */
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   447
JNIEXPORT jclass JNICALL
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   448
JVM_DefineClassWithCP(JNIEnv *env, const char *name, jobject loader,
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   449
                      const jbyte *buf, jsize len, jobject pd,
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   450
                      const char *source,
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   451
                      // same args as JVM_DefineClassWithSource to this point
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   452
                      jobjectArray constants);
be2fc37a817f 6653858: dynamic languages need to be able to load anonymous classes
jrose
parents: 781
diff changeset
   453
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
 * Reflection support functions
489c9b5090e2 Initial load
duke
parents:
diff changeset
   456
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   457
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
JNIEXPORT jstring JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   459
JVM_GetClassName(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   460
489c9b5090e2 Initial load
duke
parents:
diff changeset
   461
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   462
JVM_GetClassInterfaces(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   465
JVM_GetClassLoader(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   466
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   468
JVM_IsInterface(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
489c9b5090e2 Initial load
duke
parents:
diff changeset
   470
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   471
JVM_GetClassSigners(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   472
489c9b5090e2 Initial load
duke
parents:
diff changeset
   473
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   474
JVM_SetClassSigners(JNIEnv *env, jclass cls, jobjectArray signers);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   475
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
JVM_GetProtectionDomain(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   478
489c9b5090e2 Initial load
duke
parents:
diff changeset
   479
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
JVM_SetProtectionDomain(JNIEnv *env, jclass cls, jobject protection_domain);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
JVM_IsArrayClass(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   484
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
JVM_IsPrimitiveClass(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
489c9b5090e2 Initial load
duke
parents:
diff changeset
   488
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   489
JVM_GetComponentType(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   492
JVM_GetClassModifiers(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
489c9b5090e2 Initial load
duke
parents:
diff changeset
   494
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   495
JVM_GetDeclaredClasses(JNIEnv *env, jclass ofClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   496
489c9b5090e2 Initial load
duke
parents:
diff changeset
   497
JNIEXPORT jclass JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   498
JVM_GetDeclaringClass(JNIEnv *env, jclass ofClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
489c9b5090e2 Initial load
duke
parents:
diff changeset
   500
/* Generics support (JDK 1.5) */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   501
JNIEXPORT jstring JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   502
JVM_GetClassSignature(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   503
489c9b5090e2 Initial load
duke
parents:
diff changeset
   504
/* Annotations support (JDK 1.5) */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   505
JNIEXPORT jbyteArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   506
JVM_GetClassAnnotations(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   507
489c9b5090e2 Initial load
duke
parents:
diff changeset
   508
/* Annotations support (JDK 1.6) */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
// field is a handle to a java.lang.reflect.Field object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   511
JNIEXPORT jbyteArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   512
JVM_GetFieldAnnotations(JNIEnv *env, jobject field);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   513
489c9b5090e2 Initial load
duke
parents:
diff changeset
   514
// method is a handle to a java.lang.reflect.Method object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   515
JNIEXPORT jbyteArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   516
JVM_GetMethodAnnotations(JNIEnv *env, jobject method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   517
489c9b5090e2 Initial load
duke
parents:
diff changeset
   518
// method is a handle to a java.lang.reflect.Method object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   519
JNIEXPORT jbyteArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   520
JVM_GetMethodDefaultAnnotationValue(JNIEnv *env, jobject method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   521
489c9b5090e2 Initial load
duke
parents:
diff changeset
   522
// method is a handle to a java.lang.reflect.Method object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   523
JNIEXPORT jbyteArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   524
JVM_GetMethodParameterAnnotations(JNIEnv *env, jobject method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
489c9b5090e2 Initial load
duke
parents:
diff changeset
   526
489c9b5090e2 Initial load
duke
parents:
diff changeset
   527
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   528
 * New (JDK 1.4) reflection implementation
489c9b5090e2 Initial load
duke
parents:
diff changeset
   529
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   530
489c9b5090e2 Initial load
duke
parents:
diff changeset
   531
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   532
JVM_GetClassDeclaredMethods(JNIEnv *env, jclass ofClass, jboolean publicOnly);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   533
489c9b5090e2 Initial load
duke
parents:
diff changeset
   534
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   535
JVM_GetClassDeclaredFields(JNIEnv *env, jclass ofClass, jboolean publicOnly);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   536
489c9b5090e2 Initial load
duke
parents:
diff changeset
   537
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   538
JVM_GetClassDeclaredConstructors(JNIEnv *env, jclass ofClass, jboolean publicOnly);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   539
489c9b5090e2 Initial load
duke
parents:
diff changeset
   540
/* Differs from JVM_GetClassModifiers in treatment of inner classes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   541
   This returns the access flags for the class as specified in the
489c9b5090e2 Initial load
duke
parents:
diff changeset
   542
   class file rather than searching the InnerClasses attribute (if
489c9b5090e2 Initial load
duke
parents:
diff changeset
   543
   present) to find the source-level access flags. Only the values of
489c9b5090e2 Initial load
duke
parents:
diff changeset
   544
   the low 13 bits (i.e., a mask of 0x1FFF) are guaranteed to be
489c9b5090e2 Initial load
duke
parents:
diff changeset
   545
   valid. */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   546
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   547
JVM_GetClassAccessFlags(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   548
489c9b5090e2 Initial load
duke
parents:
diff changeset
   549
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   550
 * Constant pool access; currently used to implement reflective access to annotations (JDK 1.5)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   551
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   552
489c9b5090e2 Initial load
duke
parents:
diff changeset
   553
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   554
JVM_GetClassConstantPool(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   555
489c9b5090e2 Initial load
duke
parents:
diff changeset
   556
JNIEXPORT jint JNICALL JVM_ConstantPoolGetSize
489c9b5090e2 Initial load
duke
parents:
diff changeset
   557
(JNIEnv *env, jobject unused, jobject jcpool);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   558
489c9b5090e2 Initial load
duke
parents:
diff changeset
   559
JNIEXPORT jclass JNICALL JVM_ConstantPoolGetClassAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   560
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   561
489c9b5090e2 Initial load
duke
parents:
diff changeset
   562
JNIEXPORT jclass JNICALL JVM_ConstantPoolGetClassAtIfLoaded
489c9b5090e2 Initial load
duke
parents:
diff changeset
   563
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   564
489c9b5090e2 Initial load
duke
parents:
diff changeset
   565
JNIEXPORT jobject JNICALL JVM_ConstantPoolGetMethodAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   566
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   567
489c9b5090e2 Initial load
duke
parents:
diff changeset
   568
JNIEXPORT jobject JNICALL JVM_ConstantPoolGetMethodAtIfLoaded
489c9b5090e2 Initial load
duke
parents:
diff changeset
   569
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   570
489c9b5090e2 Initial load
duke
parents:
diff changeset
   571
JNIEXPORT jobject JNICALL JVM_ConstantPoolGetFieldAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   573
489c9b5090e2 Initial load
duke
parents:
diff changeset
   574
JNIEXPORT jobject JNICALL JVM_ConstantPoolGetFieldAtIfLoaded
489c9b5090e2 Initial load
duke
parents:
diff changeset
   575
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   576
489c9b5090e2 Initial load
duke
parents:
diff changeset
   577
JNIEXPORT jobjectArray JNICALL JVM_ConstantPoolGetMemberRefInfoAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   578
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   579
489c9b5090e2 Initial load
duke
parents:
diff changeset
   580
JNIEXPORT jint JNICALL JVM_ConstantPoolGetIntAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   581
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   582
489c9b5090e2 Initial load
duke
parents:
diff changeset
   583
JNIEXPORT jlong JNICALL JVM_ConstantPoolGetLongAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   584
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   585
489c9b5090e2 Initial load
duke
parents:
diff changeset
   586
JNIEXPORT jfloat JNICALL JVM_ConstantPoolGetFloatAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   587
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   588
489c9b5090e2 Initial load
duke
parents:
diff changeset
   589
JNIEXPORT jdouble JNICALL JVM_ConstantPoolGetDoubleAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   590
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   591
489c9b5090e2 Initial load
duke
parents:
diff changeset
   592
JNIEXPORT jstring JNICALL JVM_ConstantPoolGetStringAt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   593
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   594
489c9b5090e2 Initial load
duke
parents:
diff changeset
   595
JNIEXPORT jstring JNICALL JVM_ConstantPoolGetUTF8At
489c9b5090e2 Initial load
duke
parents:
diff changeset
   596
(JNIEnv *env, jobject unused, jobject jcpool, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   597
489c9b5090e2 Initial load
duke
parents:
diff changeset
   598
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   599
 * java.security.*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   600
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   601
489c9b5090e2 Initial load
duke
parents:
diff changeset
   602
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   603
JVM_DoPrivileged(JNIEnv *env, jclass cls,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   604
                 jobject action, jobject context, jboolean wrapException);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   605
489c9b5090e2 Initial load
duke
parents:
diff changeset
   606
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   607
JVM_GetInheritedAccessControlContext(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   608
489c9b5090e2 Initial load
duke
parents:
diff changeset
   609
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   610
JVM_GetStackAccessControlContext(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   611
489c9b5090e2 Initial load
duke
parents:
diff changeset
   612
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   613
 * Signal support, used to implement the shutdown sequence.  Every VM must
489c9b5090e2 Initial load
duke
parents:
diff changeset
   614
 * support JVM_SIGINT and JVM_SIGTERM, raising the former for user interrupts
489c9b5090e2 Initial load
duke
parents:
diff changeset
   615
 * (^C) and the latter for external termination (kill, system shutdown, etc.).
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
 * Other platform-dependent signal values may also be supported.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   617
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   618
489c9b5090e2 Initial load
duke
parents:
diff changeset
   619
JNIEXPORT void * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
JVM_RegisterSignal(jint sig, void *handler);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   621
489c9b5090e2 Initial load
duke
parents:
diff changeset
   622
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   623
JVM_RaiseSignal(jint sig);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   624
489c9b5090e2 Initial load
duke
parents:
diff changeset
   625
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   626
JVM_FindSignal(const char *name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   627
489c9b5090e2 Initial load
duke
parents:
diff changeset
   628
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   629
 * Retrieve the assertion directives for the specified class.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   630
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   631
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   632
JVM_DesiredAssertionStatus(JNIEnv *env, jclass unused, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   633
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
 * Retrieve the assertion directives from the VM.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
JVM_AssertionStatusDirectives(JNIEnv *env, jclass unused);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   639
489c9b5090e2 Initial load
duke
parents:
diff changeset
   640
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   641
 * sun.misc.AtomicLong
489c9b5090e2 Initial load
duke
parents:
diff changeset
   642
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   643
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   644
JVM_SupportsCX8(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   645
489c9b5090e2 Initial load
duke
parents:
diff changeset
   646
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   647
JVM_CX8Field(JNIEnv *env, jobject obj, jfieldID fldID, jlong oldVal, jlong newVal);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   648
363
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   649
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   650
 * com.sun.dtrace.jsdt support
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   651
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   652
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   653
#define JVM_TRACING_DTRACE_VERSION 1
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   654
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   655
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   656
 * Structure to pass one probe description to JVM.
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   657
 *
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   658
 * The VM will overwrite the definition of the referenced method with
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   659
 * code that will fire the probe.
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   660
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   661
typedef struct {
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   662
    jmethodID method;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   663
    jstring   function;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   664
    jstring   name;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   665
    void*     reserved[4];     // for future use
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   666
} JVM_DTraceProbe;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   667
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   668
/**
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   669
 * Encapsulates the stability ratings for a DTrace provider field
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   670
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   671
typedef struct {
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   672
    jint nameStability;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   673
    jint dataStability;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   674
    jint dependencyClass;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   675
} JVM_DTraceInterfaceAttributes;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   676
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   677
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   678
 * Structure to pass one provider description to JVM
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   679
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   680
typedef struct {
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   681
    jstring                       name;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   682
    JVM_DTraceProbe*              probes;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   683
    jint                          probe_count;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   684
    JVM_DTraceInterfaceAttributes providerAttributes;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   685
    JVM_DTraceInterfaceAttributes moduleAttributes;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   686
    JVM_DTraceInterfaceAttributes functionAttributes;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   687
    JVM_DTraceInterfaceAttributes nameAttributes;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   688
    JVM_DTraceInterfaceAttributes argsAttributes;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   689
    void*                         reserved[4]; // for future use
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   690
} JVM_DTraceProvider;
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   691
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   692
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   693
 * Get the version number the JVM was built with
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   694
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   695
JNIEXPORT jint JNICALL
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   696
JVM_DTraceGetVersion(JNIEnv* env);
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   697
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   698
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   699
 * Register new probe with given signature, return global handle
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   700
 *
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   701
 * The version passed in is the version that the library code was
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   702
 * built with.
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   703
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   704
JNIEXPORT jlong JNICALL
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   705
JVM_DTraceActivate(JNIEnv* env, jint version, jstring module_name,
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   706
  jint providers_count, JVM_DTraceProvider* providers);
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   707
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   708
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   709
 * Check JSDT probe
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   710
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   711
JNIEXPORT jboolean JNICALL
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   712
JVM_DTraceIsProbeEnabled(JNIEnv* env, jmethodID method);
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   713
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   714
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   715
 * Destroy custom DOF
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   716
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   717
JNIEXPORT void JNICALL
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   718
JVM_DTraceDispose(JNIEnv* env, jlong handle);
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   719
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   720
/*
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   721
 * Check to see if DTrace is supported by OS
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   722
 */
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   723
JNIEXPORT jboolean JNICALL
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   724
JVM_DTraceIsSupported(JNIEnv* env);
99d43e8a76ad 6537506: Provide a mechanism for specifying Java-level USDT-like dtrace probes
kamg
parents: 1
diff changeset
   725
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   726
/*************************************************************************
489c9b5090e2 Initial load
duke
parents:
diff changeset
   727
 PART 2: Support for the Verifier and Class File Format Checker
489c9b5090e2 Initial load
duke
parents:
diff changeset
   728
 ************************************************************************/
489c9b5090e2 Initial load
duke
parents:
diff changeset
   729
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   730
 * Return the class name in UTF format. The result is valid
489c9b5090e2 Initial load
duke
parents:
diff changeset
   731
 * until JVM_ReleaseUTf is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   732
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   733
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   734
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   735
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   736
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   737
JVM_GetClassNameUTF(JNIEnv *env, jclass cb);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   738
489c9b5090e2 Initial load
duke
parents:
diff changeset
   739
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   740
 * Returns the constant pool types in the buffer provided by "types."
489c9b5090e2 Initial load
duke
parents:
diff changeset
   741
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   742
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   743
JVM_GetClassCPTypes(JNIEnv *env, jclass cb, unsigned char *types);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   744
489c9b5090e2 Initial load
duke
parents:
diff changeset
   745
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   746
 * Returns the number of Constant Pool entries.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   747
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   748
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   749
JVM_GetClassCPEntriesCount(JNIEnv *env, jclass cb);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   750
489c9b5090e2 Initial load
duke
parents:
diff changeset
   751
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   752
 * Returns the number of *declared* fields or methods.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   753
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   754
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   755
JVM_GetClassFieldsCount(JNIEnv *env, jclass cb);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   756
489c9b5090e2 Initial load
duke
parents:
diff changeset
   757
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   758
JVM_GetClassMethodsCount(JNIEnv *env, jclass cb);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
489c9b5090e2 Initial load
duke
parents:
diff changeset
   760
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   761
 * Returns the CP indexes of exceptions raised by a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   762
 * Places the result in the given buffer.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   763
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   764
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   765
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   766
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   767
JVM_GetMethodIxExceptionIndexes(JNIEnv *env, jclass cb, jint method_index,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   768
                                unsigned short *exceptions);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   769
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   770
 * Returns the number of exceptions raised by a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   771
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   772
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   773
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   774
JVM_GetMethodIxExceptionsCount(JNIEnv *env, jclass cb, jint method_index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   775
489c9b5090e2 Initial load
duke
parents:
diff changeset
   776
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   777
 * Returns the byte code sequence of a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   778
 * Places the result in the given buffer.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   779
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   780
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   781
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   782
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   783
JVM_GetMethodIxByteCode(JNIEnv *env, jclass cb, jint method_index,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   784
                        unsigned char *code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   785
489c9b5090e2 Initial load
duke
parents:
diff changeset
   786
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   787
 * Returns the length of the byte code sequence of a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   788
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   789
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   790
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   791
JVM_GetMethodIxByteCodeLength(JNIEnv *env, jclass cb, jint method_index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   792
489c9b5090e2 Initial load
duke
parents:
diff changeset
   793
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   794
 * A structure used to a capture exception table entry in a Java method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   795
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   796
typedef struct {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   797
    jint start_pc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   798
    jint end_pc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   799
    jint handler_pc;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   800
    jint catchType;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   801
} JVM_ExceptionTableEntryType;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   802
489c9b5090e2 Initial load
duke
parents:
diff changeset
   803
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   804
 * Returns the exception table entry at entry_index of a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   805
 * Places the result in the given buffer.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   806
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   807
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   808
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   809
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   810
JVM_GetMethodIxExceptionTableEntry(JNIEnv *env, jclass cb, jint method_index,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   811
                                   jint entry_index,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   812
                                   JVM_ExceptionTableEntryType *entry);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   813
489c9b5090e2 Initial load
duke
parents:
diff changeset
   814
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   815
 * Returns the length of the exception table of a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   816
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   817
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   818
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   819
JVM_GetMethodIxExceptionTableLength(JNIEnv *env, jclass cb, int index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   820
489c9b5090e2 Initial load
duke
parents:
diff changeset
   821
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   822
 * Returns the modifiers of a given field.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   823
 * The field is identified by field_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   824
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   825
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   826
JVM_GetFieldIxModifiers(JNIEnv *env, jclass cb, int index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   827
489c9b5090e2 Initial load
duke
parents:
diff changeset
   828
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   829
 * Returns the modifiers of a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   830
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   831
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   832
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   833
JVM_GetMethodIxModifiers(JNIEnv *env, jclass cb, int index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   834
489c9b5090e2 Initial load
duke
parents:
diff changeset
   835
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   836
 * Returns the number of local variables of a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   837
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   838
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   839
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   840
JVM_GetMethodIxLocalsCount(JNIEnv *env, jclass cb, int index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   841
489c9b5090e2 Initial load
duke
parents:
diff changeset
   842
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   843
 * Returns the number of arguments (including this pointer) of a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   844
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   845
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   846
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   847
JVM_GetMethodIxArgsSize(JNIEnv *env, jclass cb, int index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   848
489c9b5090e2 Initial load
duke
parents:
diff changeset
   849
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   850
 * Returns the maximum amount of stack (in words) used by a given method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   851
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   852
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   853
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   854
JVM_GetMethodIxMaxStack(JNIEnv *env, jclass cb, int index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   855
489c9b5090e2 Initial load
duke
parents:
diff changeset
   856
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   857
 * Is a given method a constructor.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   858
 * The method is identified by method_index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   859
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   860
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   861
JVM_IsConstructorIx(JNIEnv *env, jclass cb, int index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   862
489c9b5090e2 Initial load
duke
parents:
diff changeset
   863
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   864
 * Returns the name of a given method in UTF format.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   865
 * The result remains valid until JVM_ReleaseUTF is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   866
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   867
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   868
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   869
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   870
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   871
JVM_GetMethodIxNameUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   872
489c9b5090e2 Initial load
duke
parents:
diff changeset
   873
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   874
 * Returns the signature of a given method in UTF format.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   875
 * The result remains valid until JVM_ReleaseUTF is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   876
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   877
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   878
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   879
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   880
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   881
JVM_GetMethodIxSignatureUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   882
489c9b5090e2 Initial load
duke
parents:
diff changeset
   883
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   884
 * Returns the name of the field refered to at a given constant pool
489c9b5090e2 Initial load
duke
parents:
diff changeset
   885
 * index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   886
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   887
 * The result is in UTF format and remains valid until JVM_ReleaseUTF
489c9b5090e2 Initial load
duke
parents:
diff changeset
   888
 * is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   889
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   890
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   891
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   892
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   893
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   894
JVM_GetCPFieldNameUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   895
489c9b5090e2 Initial load
duke
parents:
diff changeset
   896
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   897
 * Returns the name of the method refered to at a given constant pool
489c9b5090e2 Initial load
duke
parents:
diff changeset
   898
 * index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   899
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   900
 * The result is in UTF format and remains valid until JVM_ReleaseUTF
489c9b5090e2 Initial load
duke
parents:
diff changeset
   901
 * is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   902
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   903
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   904
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   905
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   906
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   907
JVM_GetCPMethodNameUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   908
489c9b5090e2 Initial load
duke
parents:
diff changeset
   909
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   910
 * Returns the signature of the method refered to at a given constant pool
489c9b5090e2 Initial load
duke
parents:
diff changeset
   911
 * index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   912
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   913
 * The result is in UTF format and remains valid until JVM_ReleaseUTF
489c9b5090e2 Initial load
duke
parents:
diff changeset
   914
 * is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   915
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   916
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   917
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   918
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   919
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   920
JVM_GetCPMethodSignatureUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   921
489c9b5090e2 Initial load
duke
parents:
diff changeset
   922
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   923
 * Returns the signature of the field refered to at a given constant pool
489c9b5090e2 Initial load
duke
parents:
diff changeset
   924
 * index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   925
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   926
 * The result is in UTF format and remains valid until JVM_ReleaseUTF
489c9b5090e2 Initial load
duke
parents:
diff changeset
   927
 * is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   928
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   931
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   932
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   933
JVM_GetCPFieldSignatureUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   934
489c9b5090e2 Initial load
duke
parents:
diff changeset
   935
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   936
 * Returns the class name refered to at a given constant pool index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   937
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   938
 * The result is in UTF format and remains valid until JVM_ReleaseUTF
489c9b5090e2 Initial load
duke
parents:
diff changeset
   939
 * is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   940
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   941
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   942
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   943
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   944
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   945
JVM_GetCPClassNameUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   946
489c9b5090e2 Initial load
duke
parents:
diff changeset
   947
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   948
 * Returns the class name refered to at a given constant pool index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   949
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   950
 * The constant pool entry must refer to a CONSTANT_Fieldref.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   951
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   952
 * The result is in UTF format and remains valid until JVM_ReleaseUTF
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
 * is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   954
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   955
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   956
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   957
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   958
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   959
JVM_GetCPFieldClassNameUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   960
489c9b5090e2 Initial load
duke
parents:
diff changeset
   961
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   962
 * Returns the class name refered to at a given constant pool index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   963
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   964
 * The constant pool entry must refer to CONSTANT_Methodref or
489c9b5090e2 Initial load
duke
parents:
diff changeset
   965
 * CONSTANT_InterfaceMethodref.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   966
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   967
 * The result is in UTF format and remains valid until JVM_ReleaseUTF
489c9b5090e2 Initial load
duke
parents:
diff changeset
   968
 * is called.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   969
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   970
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   971
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   972
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   973
JNIEXPORT const char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   974
JVM_GetCPMethodClassNameUTF(JNIEnv *env, jclass cb, jint index);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   975
489c9b5090e2 Initial load
duke
parents:
diff changeset
   976
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   977
 * Returns the modifiers of a field in calledClass. The field is
489c9b5090e2 Initial load
duke
parents:
diff changeset
   978
 * referred to in class cb at constant pool entry index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   979
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   980
 * The caller must treat the string as a constant and not modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   981
 * in any way.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   982
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   983
 * Returns -1 if the field does not exist in calledClass.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   984
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   985
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   986
JVM_GetCPFieldModifiers(JNIEnv *env, jclass cb, int index, jclass calledClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   987
489c9b5090e2 Initial load
duke
parents:
diff changeset
   988
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   989
 * Returns the modifiers of a method in calledClass. The method is
489c9b5090e2 Initial load
duke
parents:
diff changeset
   990
 * referred to in class cb at constant pool entry index.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   991
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
   992
 * Returns -1 if the method does not exist in calledClass.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   993
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
   994
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   995
JVM_GetCPMethodModifiers(JNIEnv *env, jclass cb, int index, jclass calledClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   996
489c9b5090e2 Initial load
duke
parents:
diff changeset
   997
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
   998
 * Releases the UTF string obtained from the VM.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   999
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1000
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1001
JVM_ReleaseUTF(const char *utf);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1002
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1003
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1004
 * Compare if two classes are in the same package.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1005
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1006
JNIEXPORT jboolean JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1007
JVM_IsSameClassPackage(JNIEnv *env, jclass class1, jclass class2);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1008
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1009
/* Constants in class files */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1010
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1011
#define JVM_ACC_PUBLIC        0x0001  /* visible to everyone */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1012
#define JVM_ACC_PRIVATE       0x0002  /* visible only to the defining class */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1013
#define JVM_ACC_PROTECTED     0x0004  /* visible to subclasses */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1014
#define JVM_ACC_STATIC        0x0008  /* instance variable is static */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1015
#define JVM_ACC_FINAL         0x0010  /* no further subclassing, overriding */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1016
#define JVM_ACC_SYNCHRONIZED  0x0020  /* wrap method call in monitor lock */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1017
#define JVM_ACC_SUPER         0x0020  /* funky handling of invokespecial */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1018
#define JVM_ACC_VOLATILE      0x0040  /* can not cache in registers */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1019
#define JVM_ACC_BRIDGE        0x0040  /* bridge method generated by compiler */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1020
#define JVM_ACC_TRANSIENT     0x0080  /* not persistent */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1021
#define JVM_ACC_VARARGS       0x0080  /* method declared with variable number of args */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1022
#define JVM_ACC_NATIVE        0x0100  /* implemented in C */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1023
#define JVM_ACC_INTERFACE     0x0200  /* class is an interface */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1024
#define JVM_ACC_ABSTRACT      0x0400  /* no definition provided */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1025
#define JVM_ACC_STRICT        0x0800  /* strict floating point */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1026
#define JVM_ACC_SYNTHETIC     0x1000  /* compiler-generated class, method or field */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1027
#define JVM_ACC_ANNOTATION    0x2000  /* annotation type */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1028
#define JVM_ACC_ENUM          0x4000  /* field is declared as element of enum */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1029
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1030
#define JVM_ACC_PUBLIC_BIT        0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1031
#define JVM_ACC_PRIVATE_BIT       1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1032
#define JVM_ACC_PROTECTED_BIT     2
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1033
#define JVM_ACC_STATIC_BIT        3
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1034
#define JVM_ACC_FINAL_BIT         4
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1035
#define JVM_ACC_SYNCHRONIZED_BIT  5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1036
#define JVM_ACC_SUPER_BIT         5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1037
#define JVM_ACC_VOLATILE_BIT      6
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1038
#define JVM_ACC_BRIDGE_BIT        6
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1039
#define JVM_ACC_TRANSIENT_BIT     7
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1040
#define JVM_ACC_VARARGS_BIT       7
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1041
#define JVM_ACC_NATIVE_BIT        8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1042
#define JVM_ACC_INTERFACE_BIT     9
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1043
#define JVM_ACC_ABSTRACT_BIT      10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1044
#define JVM_ACC_STRICT_BIT        11
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1045
#define JVM_ACC_SYNTHETIC_BIT     12
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1046
#define JVM_ACC_ANNOTATION_BIT    13
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1047
#define JVM_ACC_ENUM_BIT          14
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1048
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1049
// NOTE: replicated in SA in vm/agent/sun/jvm/hotspot/utilities/ConstantTag.java
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1050
enum {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1051
    JVM_CONSTANT_Utf8 = 1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1052
    JVM_CONSTANT_Unicode,               /* unused */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1053
    JVM_CONSTANT_Integer,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1054
    JVM_CONSTANT_Float,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1055
    JVM_CONSTANT_Long,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1056
    JVM_CONSTANT_Double,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1057
    JVM_CONSTANT_Class,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1058
    JVM_CONSTANT_String,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1059
    JVM_CONSTANT_Fieldref,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1060
    JVM_CONSTANT_Methodref,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1061
    JVM_CONSTANT_InterfaceMethodref,
5882
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1062
    JVM_CONSTANT_NameAndType,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1063
    JVM_CONSTANT_MethodHandle           = 15,  // JSR 292
6062
bab93afe9df7 6964498: JSR 292 invokedynamic sites need local bootstrap methods
jrose
parents: 5882
diff changeset
  1064
    JVM_CONSTANT_MethodType             = 16,  // JSR 292
7114
65d21c4c6337 6984311: JSR 292 needs optional bootstrap method parameters
jrose
parents: 6062
diff changeset
  1065
    JVM_CONSTANT_InvokeDynamicTrans     = 17,  // JSR 292, only occurs in old class files
7436
dbc43da3d512 7001379: bootstrap method data needs to be moved from constant pool to a classfile attribute
jrose
parents: 7397
diff changeset
  1066
    JVM_CONSTANT_InvokeDynamic          = 18,  // JSR 292
dbc43da3d512 7001379: bootstrap method data needs to be moved from constant pool to a classfile attribute
jrose
parents: 7397
diff changeset
  1067
    JVM_CONSTANT_ExternalMax            = 18   // Last tag found in classfiles
5882
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1068
};
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1069
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1070
/* JVM_CONSTANT_MethodHandle subtypes */
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1071
enum {
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1072
    JVM_REF_getField                = 1,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1073
    JVM_REF_getStatic               = 2,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1074
    JVM_REF_putField                = 3,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1075
    JVM_REF_putStatic               = 4,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1076
    JVM_REF_invokeVirtual           = 5,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1077
    JVM_REF_invokeStatic            = 6,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1078
    JVM_REF_invokeSpecial           = 7,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1079
    JVM_REF_newInvokeSpecial        = 8,
6b2aecc4f7d8 6939203: JSR 292 needs method handle constants
jrose
parents: 5547
diff changeset
  1080
    JVM_REF_invokeInterface         = 9
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1081
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1082
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1083
/* Used in the newarray instruction. */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1084
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1085
#define JVM_T_BOOLEAN 4
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1086
#define JVM_T_CHAR    5
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1087
#define JVM_T_FLOAT   6
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1088
#define JVM_T_DOUBLE  7
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1089
#define JVM_T_BYTE    8
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1090
#define JVM_T_SHORT   9
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1091
#define JVM_T_INT    10
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1092
#define JVM_T_LONG   11
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1093
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1094
/* JVM method signatures */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1095
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1096
#define JVM_SIGNATURE_ARRAY             '['
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1097
#define JVM_SIGNATURE_BYTE              'B'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1098
#define JVM_SIGNATURE_CHAR              'C'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1099
#define JVM_SIGNATURE_CLASS             'L'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1100
#define JVM_SIGNATURE_ENDCLASS          ';'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1101
#define JVM_SIGNATURE_ENUM              'E'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1102
#define JVM_SIGNATURE_FLOAT             'F'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1103
#define JVM_SIGNATURE_DOUBLE            'D'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1104
#define JVM_SIGNATURE_FUNC              '('
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1105
#define JVM_SIGNATURE_ENDFUNC           ')'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1106
#define JVM_SIGNATURE_INT               'I'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1107
#define JVM_SIGNATURE_LONG              'J'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1108
#define JVM_SIGNATURE_SHORT             'S'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1109
#define JVM_SIGNATURE_VOID              'V'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1110
#define JVM_SIGNATURE_BOOLEAN           'Z'
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1111
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1112
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1113
 * A function defined by the byte-code verifier and called by the VM.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1114
 * This is not a function implemented in the VM.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1115
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1116
 * Returns JNI_FALSE if verification fails. A detailed error message
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1117
 * will be places in msg_buf, whose length is specified by buf_len.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1118
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1119
typedef jboolean (*verifier_fn_t)(JNIEnv *env,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1120
                                  jclass cb,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1121
                                  char * msg_buf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1122
                                  jint buf_len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1123
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1124
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1125
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1126
 * Support for a VM-independent class format checker.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1127
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1128
typedef struct {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1129
    unsigned long code;    /* byte code */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1130
    unsigned long excs;    /* exceptions */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1131
    unsigned long etab;    /* catch table */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1132
    unsigned long lnum;    /* line number */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1133
    unsigned long lvar;    /* local vars */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1134
} method_size_info;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1135
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1136
typedef struct {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1137
    unsigned int constants;    /* constant pool */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1138
    unsigned int fields;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1139
    unsigned int methods;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1140
    unsigned int interfaces;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1141
    unsigned int fields2;      /* number of static 2-word fields */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1142
    unsigned int innerclasses; /* # of records in InnerClasses attr */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1143
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1144
    method_size_info clinit;   /* memory used in clinit */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1145
    method_size_info main;     /* used everywhere else */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1146
} class_size_info;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1147
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1148
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1149
 * Functions defined in libjava.so to perform string conversions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1150
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1153
typedef jstring (*to_java_string_fn_t)(JNIEnv *env, char *str);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1154
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1155
typedef char *(*to_c_string_fn_t)(JNIEnv *env, jstring s, jboolean *b);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1156
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1157
/* This is the function defined in libjava.so that performs class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
 * format checks. This functions fills in size information about
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
 * the class file and returns:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1160
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
 *   0: good
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
 *  -1: out of memory
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
 *  -2: bad format
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1164
 *  -3: unsupported version
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1165
 *  -4: bad class name
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1166
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1167
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1168
typedef jint (*check_format_fn_t)(char *class_name,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1169
                                  unsigned char *data,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1170
                                  unsigned int data_size,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1171
                                  class_size_info *class_size,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1172
                                  char *message_buffer,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1173
                                  jint buffer_length,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
                                  jboolean measure_only,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1175
                                  jboolean check_relaxed);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1176
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
#define JVM_RECOGNIZED_CLASS_MODIFIERS (JVM_ACC_PUBLIC | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1178
                                        JVM_ACC_FINAL | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1179
                                        JVM_ACC_SUPER | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1180
                                        JVM_ACC_INTERFACE | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1181
                                        JVM_ACC_ABSTRACT | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1182
                                        JVM_ACC_ANNOTATION | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1183
                                        JVM_ACC_ENUM | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1184
                                        JVM_ACC_SYNTHETIC)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1185
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1186
#define JVM_RECOGNIZED_FIELD_MODIFIERS (JVM_ACC_PUBLIC | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1187
                                        JVM_ACC_PRIVATE | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1188
                                        JVM_ACC_PROTECTED | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1189
                                        JVM_ACC_STATIC | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1190
                                        JVM_ACC_FINAL | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1191
                                        JVM_ACC_VOLATILE | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1192
                                        JVM_ACC_TRANSIENT | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
                                        JVM_ACC_ENUM | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
                                        JVM_ACC_SYNTHETIC)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1195
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1196
#define JVM_RECOGNIZED_METHOD_MODIFIERS (JVM_ACC_PUBLIC | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1197
                                         JVM_ACC_PRIVATE | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
                                         JVM_ACC_PROTECTED | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
                                         JVM_ACC_STATIC | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
                                         JVM_ACC_FINAL | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
                                         JVM_ACC_SYNCHRONIZED | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1202
                                         JVM_ACC_BRIDGE | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
                                         JVM_ACC_VARARGS | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
                                         JVM_ACC_NATIVE | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
                                         JVM_ACC_ABSTRACT | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1206
                                         JVM_ACC_STRICT | \
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1207
                                         JVM_ACC_SYNTHETIC)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1208
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
 * This is the function defined in libjava.so to perform path
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1211
 * canonicalization. VM call this function before opening jar files
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1212
 * to load system classes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1213
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1214
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1215
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1216
typedef int (*canonicalize_fn_t)(JNIEnv *env, char *orig, char *out, int len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1217
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1218
/*************************************************************************
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1219
 PART 3: I/O and Network Support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1220
 ************************************************************************/
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1221
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1222
/* Note that the JVM IO functions are expected to return JVM_IO_ERR
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1223
 * when there is any kind of error. The caller can then use the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1224
 * platform specific support (e.g., errno) to get the detailed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1225
 * error info.  The JVM_GetLastErrorString procedure may also be used
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1226
 * to obtain a descriptive error string.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1227
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1228
#define JVM_IO_ERR  (-1)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1229
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1230
/* For interruptible IO. Returning JVM_IO_INTR indicates that an IO
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1231
 * operation has been disrupted by Thread.interrupt. There are a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1232
 * number of technical difficulties related to interruptible IO that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1233
 * need to be solved. For example, most existing programs do not handle
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1234
 * InterruptedIOExceptions specially, they simply treat those as any
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1235
 * IOExceptions, which typically indicate fatal errors.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1236
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1237
 * There are also two modes of operation for interruptible IO. In the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1238
 * resumption mode, an interrupted IO operation is guaranteed not to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1239
 * have any side-effects, and can be restarted. In the termination mode,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1240
 * an interrupted IO operation corrupts the underlying IO stream, so
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1241
 * that the only reasonable operation on an interrupted stream is to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1242
 * close that stream. The resumption mode seems to be impossible to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
 * implement on Win32 and Solaris. Implementing the termination mode is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1244
 * easier, but it's not clear that's the right semantics.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1245
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1246
 * Interruptible IO is not supported on Win32.It can be enabled/disabled
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1247
 * using a compile-time flag on Solaris. Third-party JVM ports do not
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1248
 * need to implement interruptible IO.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1249
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1250
#define JVM_IO_INTR (-2)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1251
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1252
/* Write a string into the given buffer, in the platform's local encoding,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1253
 * that describes the most recent system-level error to occur in this thread.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1254
 * Return the length of the string or zero if no error occurred.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1256
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1257
JVM_GetLastErrorString(char *buf, int len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1258
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1259
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1260
 * Convert a pathname into native format.  This function does syntactic
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1261
 * cleanup, such as removing redundant separator characters.  It modifies
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1262
 * the given pathname string in place.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
JNIEXPORT char * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1265
JVM_NativePath(char *);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1266
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1267
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1268
 * JVM I/O error codes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1269
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1270
#define JVM_EEXIST       -100
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1271
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1272
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1273
 * Open a file descriptor. This function returns a negative error code
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1274
 * on error, and a non-negative integer that is the file descriptor on
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1275
 * success.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1276
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1277
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1278
JVM_Open(const char *fname, jint flags, jint mode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1279
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1281
 * Close a file descriptor. This function returns -1 on error, and 0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1282
 * on success.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1284
 * fd        the file descriptor to close.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1285
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1286
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1287
JVM_Close(jint fd);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1288
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1289
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1290
 * Read data from a file decriptor into a char array.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1291
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
 * fd        the file descriptor to read from.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1293
 * buf       the buffer where to put the read data.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
 * nbytes    the number of bytes to read.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1296
 * This function returns -1 on error, and 0 on success.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1297
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
JVM_Read(jint fd, char *buf, jint nbytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1300
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1301
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1302
 * Write data from a char array to a file decriptor.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1303
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1304
 * fd        the file descriptor to read from.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1305
 * buf       the buffer from which to fetch the data.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1306
 * nbytes    the number of bytes to write.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1307
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1308
 * This function returns -1 on error, and 0 on success.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1309
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1310
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1311
JVM_Write(jint fd, char *buf, jint nbytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1312
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1313
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1314
 * Returns the number of bytes available for reading from a given file
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1315
 * descriptor
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1316
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1317
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1318
JVM_Available(jint fd, jlong *pbytes);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1319
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1320
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1321
 * Move the file descriptor pointer from whence by offset.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1322
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1323
 * fd        the file descriptor to move.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1324
 * offset    the number of bytes to move it by.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1325
 * whence    the start from where to move it.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1326
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1327
 * This function returns the resulting pointer location.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1328
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1329
JNIEXPORT jlong JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1330
JVM_Lseek(jint fd, jlong offset, jint whence);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1331
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1332
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1333
 * Set the length of the file associated with the given descriptor to the given
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1334
 * length.  If the new length is longer than the current length then the file
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1335
 * is extended; the contents of the extended portion are not defined.  The
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1336
 * value of the file pointer is undefined after this procedure returns.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1337
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1338
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1339
JVM_SetLength(jint fd, jlong length);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1340
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1341
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1342
 * Synchronize the file descriptor's in memory state with that of the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1343
 * physical device.  Return of -1 is an error, 0 is OK.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1344
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1345
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1346
JVM_Sync(jint fd);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1347
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1348
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1349
 * Networking library support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1350
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1351
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1352
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1353
JVM_InitializeSocketLibrary(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1354
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1355
struct sockaddr;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1357
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1358
JVM_Socket(jint domain, jint type, jint protocol);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1359
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1360
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1361
JVM_SocketClose(jint fd);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1362
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1363
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1364
JVM_SocketShutdown(jint fd, jint howto);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1365
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1366
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1367
JVM_Recv(jint fd, char *buf, jint nBytes, jint flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1368
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1369
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1370
JVM_Send(jint fd, char *buf, jint nBytes, jint flags);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1371
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1372
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1373
JVM_Timeout(int fd, long timeout);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1374
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1375
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1376
JVM_Listen(jint fd, jint count);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1377
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1378
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1379
JVM_Connect(jint fd, struct sockaddr *him, jint len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1380
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1381
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1382
JVM_Bind(jint fd, struct sockaddr *him, jint len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1383
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1384
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1385
JVM_Accept(jint fd, struct sockaddr *him, jint *len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1386
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1387
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1388
JVM_RecvFrom(jint fd, char *buf, int nBytes,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1389
                  int flags, struct sockaddr *from, int *fromlen);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1390
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1391
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1392
JVM_SendTo(jint fd, char *buf, int len,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1393
                int flags, struct sockaddr *to, int tolen);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1394
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1395
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1396
JVM_SocketAvailable(jint fd, jint *result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1397
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1398
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1399
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1400
JVM_GetSockName(jint fd, struct sockaddr *him, int *len);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1401
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1402
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1403
JVM_GetSockOpt(jint fd, int level, int optname, char *optval, int *optlen);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1404
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1405
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1406
JVM_SetSockOpt(jint fd, int level, int optname, const char *optval, int optlen);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1407
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1408
JNIEXPORT int JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1409
JVM_GetHostName(char* name, int namelen);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1410
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1411
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1412
 * The standard printing functions supported by the Java VM. (Should they
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1413
 * be renamed to JVM_* in the future?
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1414
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1415
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1416
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1417
 * BE CAREFUL! The following functions do not implement the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1418
 * full feature set of standard C printf formats.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1419
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1420
int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1421
jio_vsnprintf(char *str, size_t count, const char *fmt, va_list args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1422
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1423
int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1424
jio_snprintf(char *str, size_t count, const char *fmt, ...);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1425
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1426
int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1427
jio_fprintf(FILE *, const char *fmt, ...);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1428
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1429
int
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1430
jio_vfprintf(FILE *, const char *fmt, va_list args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1431
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1432
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1433
JNIEXPORT void * JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1434
JVM_RawMonitorCreate(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1435
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1436
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1437
JVM_RawMonitorDestroy(void *mon);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1438
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1439
JNIEXPORT jint JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1440
JVM_RawMonitorEnter(void *mon);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1441
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1442
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1443
JVM_RawMonitorExit(void *mon);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1444
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1445
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1446
#ifdef SUPPORT_OLD_REFLECTION
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1447
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1448
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1449
 * Support for old native code-based (pre-JDK 1.4) reflection implementation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1450
 * Disabled by default in the product build.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1451
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1452
 * See reflection.hpp for information on SUPPORT_OLD_REFLECTION
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1453
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1454
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1455
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1456
 * reflecting fields and methods.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1457
 * which: 0 --- MEMBER_PUBLIC
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1458
 *        1 --- MEMBER_DECLARED
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1459
 * NOTE: absent in product build by default
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1460
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1461
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1462
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1463
JVM_GetClassFields(JNIEnv *env, jclass cls, jint which);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1464
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1465
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1466
JVM_GetClassMethods(JNIEnv *env, jclass cls, jint which);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1467
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1468
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1469
JVM_GetClassConstructors(JNIEnv *env, jclass cls, jint which);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1470
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1471
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1472
JVM_GetClassField(JNIEnv *env, jclass cls, jstring name, jint which);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1473
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1474
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1475
JVM_GetClassMethod(JNIEnv *env, jclass cls, jstring name, jobjectArray types,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1476
                   jint which);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1477
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1478
JVM_GetClassConstructor(JNIEnv *env, jclass cls, jobjectArray types,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1479
                        jint which);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1480
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1481
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1482
 * Implements Class.newInstance
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1483
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1484
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1485
JVM_NewInstance(JNIEnv *env, jclass cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1486
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1487
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1488
 * java.lang.reflect.Field
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1489
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1490
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1491
JVM_GetField(JNIEnv *env, jobject field, jobject obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1492
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1493
JNIEXPORT jvalue JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1494
JVM_GetPrimitiveField(JNIEnv *env, jobject field, jobject obj,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1495
                      unsigned char wCode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1496
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1497
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1498
JVM_SetField(JNIEnv *env, jobject field, jobject obj, jobject val);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1499
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1500
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1501
JVM_SetPrimitiveField(JNIEnv *env, jobject field, jobject obj, jvalue v,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1502
                      unsigned char vCode);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1503
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1504
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1505
 * java.lang.reflect.Method
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1506
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1507
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1508
JVM_InvokeMethod(JNIEnv *env, jobject method, jobject obj, jobjectArray args0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1509
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1510
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1511
 * java.lang.reflect.Constructor
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1512
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1513
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1514
JVM_NewInstanceFromConstructor(JNIEnv *env, jobject c, jobjectArray args0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1515
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1516
#endif /* SUPPORT_OLD_REFLECTION */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1517
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1518
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1519
 * java.lang.management support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1520
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1521
JNIEXPORT void* JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1522
JVM_GetManagement(jint version);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1523
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1524
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1525
 * com.sun.tools.attach.VirtualMachine support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1526
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1527
 * Initialize the agent properties with the properties maintained in the VM.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1528
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1529
JNIEXPORT jobject JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1530
JVM_InitAgentProperties(JNIEnv *env, jobject agent_props);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1531
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1532
/* Generics reflection support.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1533
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1534
 * Returns information about the given class's EnclosingMethod
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1535
 * attribute, if present, or null if the class had no enclosing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1536
 * method.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1537
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1538
 * If non-null, the returned array contains three elements. Element 0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1539
 * is the java.lang.Class of which the enclosing method is a member,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1540
 * and elements 1 and 2 are the java.lang.Strings for the enclosing
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1541
 * method's name and descriptor, respectively.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1542
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1543
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1544
JVM_GetEnclosingMethodInfo(JNIEnv* env, jclass ofClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1545
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1546
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1547
 * Java thread state support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1548
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1549
enum {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1550
    JAVA_THREAD_STATE_NEW           = 0,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1551
    JAVA_THREAD_STATE_RUNNABLE      = 1,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1552
    JAVA_THREAD_STATE_BLOCKED       = 2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1553
    JAVA_THREAD_STATE_WAITING       = 3,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1554
    JAVA_THREAD_STATE_TIMED_WAITING = 4,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1555
    JAVA_THREAD_STATE_TERMINATED    = 5,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1556
    JAVA_THREAD_STATE_COUNT         = 6
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1557
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1558
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1559
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1560
 * Returns an array of the threadStatus values representing the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1561
 * given Java thread state.  Returns NULL if the VM version is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1562
 * incompatible with the JDK or doesn't support the given
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1563
 * Java thread state.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1564
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1565
JNIEXPORT jintArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1566
JVM_GetThreadStateValues(JNIEnv* env, jint javaThreadState);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1567
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1568
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1569
 * Returns an array of the substate names representing the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1570
 * given Java thread state.  Returns NULL if the VM version is
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1571
 * incompatible with the JDK or the VM doesn't support
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1572
 * the given Java thread state.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1573
 * values must be the jintArray returned from JVM_GetThreadStateValues
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1574
 * and javaThreadState.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1575
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1576
JNIEXPORT jobjectArray JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1577
JVM_GetThreadStateNames(JNIEnv* env, jint javaThreadState, jintArray values);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1578
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1579
/* =========================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1580
 * The following defines a private JVM interface that the JDK can query
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1581
 * for the JVM version and capabilities.  sun.misc.Version defines
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1582
 * the methods for getting the VM version and its capabilities.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1583
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1584
 * When a new bit is added, the following should be updated to provide
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1585
 * access to the new capability:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1586
 *    HS:   JVM_GetVersionInfo and Abstract_VM_Version class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1587
 *    SDK:  Version class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1588
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1589
 * Similary, a private JDK interface JDK_GetVersionInfo0 is defined for
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1590
 * JVM to query for the JDK version and capabilities.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1591
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1592
 * When a new bit is added, the following should be updated to provide
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1593
 * access to the new capability:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1594
 *    HS:   JDK_Version class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1595
 *    SDK:  JDK_GetVersionInfo0
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1596
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1597
 * ==========================================================================
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1598
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1599
typedef struct {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1600
    /* HotSpot Express VM version string:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1601
     * <major>.<minor>-bxx[-<identifier>][-<debug_flavor>]
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1602
     */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1603
    unsigned int jvm_version; /* Consists of major.minor.0.build */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1604
    unsigned int update_version : 8;         /* 0 in HotSpot Express VM */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1605
    unsigned int special_update_version : 8; /* 0 in HotSpot Express VM */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1606
    unsigned int reserved1 : 16;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1607
    unsigned int reserved2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1608
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1609
    /* The following bits represents JVM supports that JDK has dependency on.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1610
     * JDK can use these bits to determine which JVM version
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1611
     * and support it has to maintain runtime compatibility.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1612
     *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1613
     * When a new bit is added in a minor or update release, make sure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1614
     * the new bit is also added in the main/baseline.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1615
     */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1616
    unsigned int is_attachable : 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1617
    unsigned int is_kernel_jvm : 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1618
    unsigned int : 30;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1619
    unsigned int : 32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1620
    unsigned int : 32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1621
} jvm_version_info;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1622
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1623
#define JVM_VERSION_MAJOR(version) ((version & 0xFF000000) >> 24)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1624
#define JVM_VERSION_MINOR(version) ((version & 0x00FF0000) >> 16)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1625
// Micro version is 0 in HotSpot Express VM (set in jvm.cpp).
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1626
#define JVM_VERSION_MICRO(version) ((version & 0x0000FF00) >> 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1627
/* Build number is available in all HotSpot Express VM builds.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1628
 * It is defined in make/hotspot_version file.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1629
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1630
#define JVM_VERSION_BUILD(version) ((version & 0x000000FF))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1631
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1632
JNIEXPORT void JNICALL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1633
JVM_GetVersionInfo(JNIEnv* env, jvm_version_info* info, size_t info_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1634
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1635
typedef struct {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1636
    // Naming convention of RE build version string: n.n.n[_uu[c]][-<identifier>]-bxx
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1637
    unsigned int jdk_version;   /* Consists of major, minor, micro (n.n.n) */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1638
                                /* and build number (xx) */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1639
    unsigned int update_version : 8;         /* Update release version (uu) */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1640
    unsigned int special_update_version : 8; /* Special update release version (c)*/
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1641
    unsigned int reserved1 : 16;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1642
    unsigned int reserved2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1643
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1644
    /* The following bits represents new JDK supports that VM has dependency on.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1645
     * VM implementation can use these bits to determine which JDK version
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1646
     * and support it has to maintain runtime compatibility.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1647
     *
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1648
     * When a new bit is added in a minor or update release, make sure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1649
     * the new bit is also added in the main/baseline.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1650
     */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1651
    unsigned int thread_park_blocker : 1;
7900
4c7fc6332f7e 6994753: Implement optional hook to a Java method at VM startup.
kevinw
parents: 7439
diff changeset
  1652
    unsigned int post_vm_init_hook_enabled : 1;
4c7fc6332f7e 6994753: Implement optional hook to a Java method at VM startup.
kevinw
parents: 7439
diff changeset
  1653
    unsigned int : 30;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1654
    unsigned int : 32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1655
    unsigned int : 32;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1656
} jdk_version_info;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1657
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1658
#define JDK_VERSION_MAJOR(version) ((version & 0xFF000000) >> 24)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1659
#define JDK_VERSION_MINOR(version) ((version & 0x00FF0000) >> 16)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1660
#define JDK_VERSION_MICRO(version) ((version & 0x0000FF00) >> 8)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1661
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1662
/* Build number is available only for RE build (i.e. JDK_BUILD_NUMBER is set to bNN)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1663
 * It will be zero for internal builds.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1664
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1665
#define JDK_VERSION_BUILD(version) ((version & 0x000000FF))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1666
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1667
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1668
 * This is the function JDK_GetVersionInfo0 defined in libjava.so
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1669
 * that is dynamically looked up by JVM.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1670
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1671
typedef void (*jdk_version_info_fn_t)(jdk_version_info* info, size_t info_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1672
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1673
/*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1674
 * This structure is used by the launcher to get the default thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1675
 * stack size from the VM using JNI_GetDefaultJavaVMInitArgs() with a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1676
 * version of 1.1.  As it is not supported otherwise, it has been removed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1677
 * from jni.h
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1678
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1679
typedef struct JDK1_1InitArgs {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1680
    jint version;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1681
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1682
    char **properties;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1683
    jint checkSource;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1684
    jint nativeStackSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1685
    jint javaStackSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1686
    jint minHeapSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1687
    jint maxHeapSize;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1688
    jint verifyMode;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1689
    char *classpath;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1690
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1691
    jint (JNICALL *vfprintf)(FILE *fp, const char *format, va_list args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1692
    void (JNICALL *exit)(jint code);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1693
    void (JNICALL *abort)(void);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1694
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1695
    jint enableClassGC;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1696
    jint enableVerboseGC;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1697
    jint disableAsyncGC;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1698
    jint verbose;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1699
    jboolean debugging;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1700
    jint debugPort;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1701
} JDK1_1InitArgs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1702
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1703
#ifdef __cplusplus
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1704
} /* extern "C" */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1705
#endif /* __cplusplus */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1706
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1707
#endif /* !_JAVASOFT_JVM_H_ */
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
  1708
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 7114
diff changeset
  1709
#endif // SHARE_VM_PRIMS_JVM_H