src/hotspot/share/prims/jni.cpp
author lfoltan
Mon, 21 Oct 2019 13:13:16 -0400
changeset 58722 cba8afa5cfed
parent 58545 725244418646
child 58775 ba524a5f7cc2
permissions -rw-r--r--
8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently Summary: Increase the use of type signature constants instead of hard coded characters within the JVM. Reviewed-by: coleenp, dholmes, fparain Contributed-by: lois.foltan@oracle.com, john.r.rose@oracle.com
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
/*
53193
184c51e48260 8216262: Remove develop flag DelayCompilationDuringStartup
redestad
parents: 53060
diff changeset
     2
 * Copyright (c) 1997, 2019, Oracle and/or its affiliates. All rights reserved.
13958
f5598a86c223 7170638: Use DTRACE_PROBE[N] in JNI Set and SetStatic Field.
coleenp
parents: 13952
diff changeset
     3
 * Copyright (c) 2012 Red Hat, Inc.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
 * This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
 * under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
 * published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
 * This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
 * version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
 * accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
 * You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
 * 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    19
 *
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5403
diff changeset
    20
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5403
diff changeset
    21
 * or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 5403
diff changeset
    22
 * questions.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
 *
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
 */
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    26
#include "precompiled.hpp"
47659
a8e9aff89f7b 8189608: Remove duplicated jni.h
ihse
parents: 47634
diff changeset
    27
#include "jni.h"
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
    28
#include "jvm.h"
14477
95e66ea71f71 6830717: replay of compilations would help with debugging
minqi
parents: 14391
diff changeset
    29
#include "ci/ciReplay.hpp"
13087
673ea6efaf18 7158800: Improve storage of symbol tables
coleenp
parents: 12939
diff changeset
    30
#include "classfile/altHashing.hpp"
34666
1c7168ea0034 8140485: Class load and creation cleanup
mgronlun
parents: 34649
diff changeset
    31
#include "classfile/classFileStream.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    32
#include "classfile/classLoader.hpp"
36508
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
    33
#include "classfile/javaClasses.hpp"
35498
392b50de06c6 8146401: Clean up oop.hpp: add inline directives and fix header files
goetz
parents: 35219
diff changeset
    34
#include "classfile/javaClasses.inline.hpp"
36508
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
    35
#include "classfile/modules.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    36
#include "classfile/symbolTable.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    37
#include "classfile/systemDictionary.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    38
#include "classfile/vmSymbols.hpp"
49669
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
    39
#include "gc/shared/gcLocker.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    40
#include "interpreter/linkResolver.hpp"
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
    41
#include "jfr/jfrEvents.hpp"
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
    42
#include "jfr/support/jfrThreadId.hpp"
49982
9042ffe5b7fe 8200729: Conditional compilation of GCs
stefank
parents: 49669
diff changeset
    43
#include "logging/log.hpp"
13195
be27e1b6a4b9 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 13087
diff changeset
    44
#include "memory/allocation.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    45
#include "memory/allocation.inline.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    46
#include "memory/oopFactory.hpp"
37248
11a660dbbb8e 8132524: Missing includes to resourceArea.hpp
jprovino
parents: 37179
diff changeset
    47
#include "memory/resourceArea.hpp"
49359
59f6547e151f 8199264: Remove universe.inline.hpp to simplify include dependencies
stefank
parents: 49192
diff changeset
    48
#include "memory/universe.hpp"
47998
fb0275c320a0 8189871: Refactor GC barriers to use declarative semantics
eosterlund
parents: 47796
diff changeset
    49
#include "oops/access.inline.hpp"
49041
44122f767467 8198286: Direct memory accessors in typeArrayOop.hpp should use Access API
eosterlund
parents: 49036
diff changeset
    50
#include "oops/arrayOop.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    51
#include "oops/instanceKlass.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    52
#include "oops/instanceOop.hpp"
57811
947252a54b98 8229838: Rename markOop files to markWord
stefank
parents: 57699
diff changeset
    53
#include "oops/markWord.hpp"
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
    54
#include "oops/method.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    55
#include "oops/objArrayKlass.hpp"
29081
c61eb4914428 8072911: Remove includes of oop.inline.hpp from .hpp files
stefank
parents: 27685
diff changeset
    56
#include "oops/objArrayOop.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    57
#include "oops/oop.inline.hpp"
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
    58
#include "oops/symbol.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    59
#include "oops/typeArrayKlass.hpp"
49036
bc92debe57e4 8197999: Accessors in typeArrayOopDesc should use new Access API
rkennke
parents: 48819
diff changeset
    60
#include "oops/typeArrayOop.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    61
#include "prims/jniCheck.hpp"
11480
1bf714e8adb4 7115199: Add event tracing hooks and Java Flight Recorder infrastructure
phh
parents: 11247
diff changeset
    62
#include "prims/jniExport.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    63
#include "prims/jniFastGetField.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    64
#include "prims/jvm_misc.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    65
#include "prims/jvmtiExport.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    66
#include "prims/jvmtiThreadState.hpp"
40655
9f644073d3a0 8157907: Incorrect inclusion of atomic.hpp instead of atomic.inline.hpp
dholmes
parents: 38704
diff changeset
    67
#include "runtime/atomic.hpp"
51467
12997ebbc0d8 8209647: constantPoolHandle::constantPoolHandle(ConstantPool*) when precompiled header is disabled
iklam
parents: 50601
diff changeset
    68
#include "runtime/fieldDescriptor.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    69
#include "runtime/handles.inline.hpp"
49449
ef5d5d343e2a 8199263: Split interfaceSupport.hpp to not require including .inline.hpp files
coleenp
parents: 49362
diff changeset
    70
#include "runtime/interfaceSupport.inline.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    71
#include "runtime/java.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    72
#include "runtime/javaCalls.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    73
#include "runtime/jfieldIDWorkaround.hpp"
49192
6734eeef4283 8198474: Move JNIHandles::resolve into jniHandles.inline.hpp
kbarrett
parents: 49041
diff changeset
    74
#include "runtime/jniHandles.inline.hpp"
50429
83aec1d357d4 8204301: Make OrderAccess functions available to hpp rather than inline.hpp files
coleenp
parents: 50389
diff changeset
    75
#include "runtime/orderAccess.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    76
#include "runtime/reflection.hpp"
49594
898ef81cbc0e 8200106: Move NoSafepointVerifier out from gcLocker.hpp
stefank
parents: 49466
diff changeset
    77
#include "runtime/safepointVerifiers.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    78
#include "runtime/sharedRuntime.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    79
#include "runtime/signature.hpp"
14583
d70ee55535f4 8003935: Simplify the needed includes for using Thread::current()
stefank
parents: 14490
diff changeset
    80
#include "runtime/thread.inline.hpp"
52877
9e041366c764 8214850: Rename vm_operations.?pp files to vmOperations.?pp files
tschatzl
parents: 52396
diff changeset
    81
#include "runtime/vmOperations.hpp"
25946
1572c9f03fb9 8046598: Scalable Native memory tracking development
zgu
parents: 25633
diff changeset
    82
#include "services/memTracker.hpp"
7397
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    83
#include "services/runtimeService.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    84
#include "utilities/defaultStream.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    85
#include "utilities/dtrace.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    86
#include "utilities/events.hpp"
5b173b4ca846 6989984: Use standard include model for Hospot
stefank
parents: 6176
diff changeset
    87
#include "utilities/histogram.hpp"
27684
e0391b2bf625 8064581: Move INCLUDE_ALL_GCS include section to the end of the include list
stefank
parents: 27679
diff changeset
    88
#include "utilities/macros.hpp"
46589
f1c04490ded1 8182848: Some functions misplaced in debug.hpp
coleenp
parents: 46431
diff changeset
    89
#include "utilities/vmError.hpp"
58545
725244418646 8165056: move JIT Compiler related files from runtime/ to compiler/ directory
xliu
parents: 58273
diff changeset
    90
#if INCLUDE_JVMCI
725244418646 8165056: move JIT Compiler related files from runtime/ to compiler/ directory
xliu
parents: 58273
diff changeset
    91
#include "jvmci/jvmciCompiler.hpp"
725244418646 8165056: move JIT Compiler related files from runtime/ to compiler/ directory
xliu
parents: 58273
diff changeset
    92
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
47613
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
    94
static jint CurrentVersion = JNI_VERSION_10;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
30143
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
    96
#ifdef _WIN32
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
    97
extern LONG WINAPI topLevelExceptionFilter(_EXCEPTION_POINTERS* );
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
    98
#endif
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
// The DT_RETURN_MARK macros create a scoped object to fire the dtrace
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
// '-return' probe regardless of the return path is taken out of the function.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
// Methods that have multiple return paths use this to avoid having to
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
// instrument each return path.  Methods that use CHECK or THROW must use this
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
// since those macros can cause an immedate uninstrumented return.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
// In order to get the return value, a reference to the variable containing
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
// the return value must be passed to the contructor of the object, and
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
// the return value must be set before return (since the mark object has
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
// a reference to it).
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
// Example:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
// DT_RETURN_MARK_DECL(SomeFunc, int);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
// JNI_ENTRY(int, SomeFunc, ...)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
//   int return_value = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
//   DT_RETURN_MARK(SomeFunc, int, (const int&)return_value);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
//   foo(CHECK_0)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
//   return_value = 5;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
//   return return_value;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
// JNI_END
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   120
#define DT_RETURN_MARK_DECL(name, type, probe)                             \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   121
  DTRACE_ONLY(                                                             \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   122
    class DTraceReturnProbeMark_##name {                                   \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   123
     public:                                                               \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   124
      const type& _ret_ref;                                                \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   125
      DTraceReturnProbeMark_##name(const type& v) : _ret_ref(v) {}         \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   126
      ~DTraceReturnProbeMark_##name() {                                    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   127
        probe;                                                             \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   128
      }                                                                    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   129
    }                                                                      \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   130
  )
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   131
// Void functions are simpler since there's no return value
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   132
#define DT_VOID_RETURN_MARK_DECL(name, probe)                              \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   133
  DTRACE_ONLY(                                                             \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   134
    class DTraceReturnProbeMark_##name {                                   \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   135
     public:                                                               \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   136
      ~DTraceReturnProbeMark_##name() {                                    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   137
        probe;                                                             \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   138
      }                                                                    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   139
    }                                                                      \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   140
  )
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
// Place these macros in the function to mark the return.  Non-void
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
// functions need the type and address of the return value.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
#define DT_RETURN_MARK(name, type, ref) \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
  DTRACE_ONLY( DTraceReturnProbeMark_##name dtrace_return_mark(ref) )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
#define DT_VOID_RETURN_MARK(name) \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
  DTRACE_ONLY( DTraceReturnProbeMark_##name dtrace_return_mark )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
// Use these to select distinct code for floating-point vs. non-floating point
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
// situations.  Used from within common macros where we need slightly
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
// different behavior for Float/Double
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
#define FP_SELECT_Boolean(intcode, fpcode) intcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
#define FP_SELECT_Byte(intcode, fpcode)    intcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
#define FP_SELECT_Char(intcode, fpcode)    intcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
#define FP_SELECT_Short(intcode, fpcode)   intcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
#define FP_SELECT_Object(intcode, fpcode)  intcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
#define FP_SELECT_Int(intcode, fpcode)     intcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
#define FP_SELECT_Long(intcode, fpcode)    intcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
#define FP_SELECT_Float(intcode, fpcode)   fpcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
#define FP_SELECT_Double(intcode, fpcode)  fpcode
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
#define FP_SELECT(TypeName, intcode, fpcode) \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
  FP_SELECT_##TypeName(intcode, fpcode)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
// Choose DT_RETURN_MARK macros  based on the type: float/double -> void
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
// (dtrace doesn't do FP yet)
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   167
#define DT_RETURN_MARK_DECL_FOR(TypeName, name, type, probe)    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   168
  FP_SELECT(TypeName, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   169
    DT_RETURN_MARK_DECL(name, type, probe), DT_VOID_RETURN_MARK_DECL(name, probe) )
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
#define DT_RETURN_MARK_FOR(TypeName, name, type, ref) \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
  FP_SELECT(TypeName, \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
    DT_RETURN_MARK(name, type, ref), DT_VOID_RETURN_MARK(name) )
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
// out-of-line helpers for class jfieldIDWorkaround:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   177
bool jfieldIDWorkaround::is_valid_jfieldID(Klass* k, jfieldID id) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
  if (jfieldIDWorkaround::is_instance_jfieldID(k, id)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
    uintptr_t as_uint = (uintptr_t) id;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
    intptr_t offset = raw_instance_offset(id);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
    if (is_checked_jfieldID(id)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
      if (!klass_hash_ok(k, id)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
        return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
    }
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   186
    return InstanceKlass::cast(k)->contains_field_offset(offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
    JNIid* result = (JNIid*) id;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
    return result != NULL && result->is_static_field_id();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
    return result != NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   193
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   194
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   195
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   196
489c9b5090e2 Initial load
duke
parents:
diff changeset
   197
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   198
intptr_t jfieldIDWorkaround::encode_klass_hash(Klass* k, intptr_t offset) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   199
  if (offset <= small_offset_mask) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   200
    Klass* field_klass = k;
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   201
    Klass* super_klass = field_klass->super();
360
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 1
diff changeset
   202
    // With compressed oops the most super class with nonstatic fields would
21d113ecbf6a 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 1
diff changeset
   203
    // be the owner of fields embedded in the header.
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   204
    while (InstanceKlass::cast(super_klass)->has_nonstatic_fields() &&
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   205
           InstanceKlass::cast(super_klass)->contains_field_offset(offset)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   206
      field_klass = super_klass;   // super contains the field also
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   207
      super_klass = field_klass->super();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   208
    }
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35219
diff changeset
   209
    debug_only(NoSafepointVerifier nosafepoint;)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   210
    uintptr_t klass_hash = field_klass->identity_hash();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   211
    return ((klass_hash & klass_mask) << klass_shift) | checked_mask_in_place;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   212
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   213
#if 0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   214
    #ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   215
    {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   216
      ResourceMark rm;
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   217
      warning("VerifyJNIFields: long offset %d in %s", offset, k->external_name());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   218
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   219
    #endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   220
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   221
    return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   222
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   223
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   224
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   225
bool jfieldIDWorkaround::klass_hash_ok(Klass* k, jfieldID id) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   226
  uintptr_t as_uint = (uintptr_t) id;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   227
  intptr_t klass_hash = (as_uint >> klass_shift) & klass_mask;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   228
  do {
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35219
diff changeset
   229
    debug_only(NoSafepointVerifier nosafepoint;)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   230
    // Could use a non-blocking query for identity_hash here...
489c9b5090e2 Initial load
duke
parents:
diff changeset
   231
    if ((k->identity_hash() & klass_mask) == klass_hash)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   232
      return true;
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   233
    k = k->super();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   234
  } while (k != NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   235
  return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   236
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   237
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   238
void jfieldIDWorkaround::verify_instance_jfieldID(Klass* k, jfieldID id) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   239
  guarantee(jfieldIDWorkaround::is_instance_jfieldID(k, id), "must be an instance field" );
489c9b5090e2 Initial load
duke
parents:
diff changeset
   240
  uintptr_t as_uint = (uintptr_t) id;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   241
  intptr_t offset = raw_instance_offset(id);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   242
  if (VerifyJNIFields) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   243
    if (is_checked_jfieldID(id)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   244
      guarantee(klass_hash_ok(k, id),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   245
    "Bug in native code: jfieldID class must match object");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   246
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   247
#if 0
489c9b5090e2 Initial load
duke
parents:
diff changeset
   248
      #ifndef PRODUCT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   249
      if (Verbose) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   250
  ResourceMark rm;
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   251
  warning("VerifyJNIFields: unverified offset %d for %s", offset, k->external_name());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   252
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   253
      #endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   254
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   255
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   256
  }
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   257
  guarantee(InstanceKlass::cast(k)->contains_field_offset(offset),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   258
      "Bug in native code: jfieldID offset must address interior of object");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   259
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   260
489c9b5090e2 Initial load
duke
parents:
diff changeset
   261
// Wrapper to trace JNI functions
489c9b5090e2 Initial load
duke
parents:
diff changeset
   262
489c9b5090e2 Initial load
duke
parents:
diff changeset
   263
#ifdef ASSERT
489c9b5090e2 Initial load
duke
parents:
diff changeset
   264
  Histogram* JNIHistogram;
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
   265
  static volatile int JNIHistogram_lock = 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   266
489c9b5090e2 Initial load
duke
parents:
diff changeset
   267
  class JNIHistogramElement : public HistogramElement {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   268
    public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   269
     JNIHistogramElement(const char* name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   270
  };
489c9b5090e2 Initial load
duke
parents:
diff changeset
   271
489c9b5090e2 Initial load
duke
parents:
diff changeset
   272
  JNIHistogramElement::JNIHistogramElement(const char* elementName) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   273
    _name = elementName;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   274
    uintx count = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   275
489c9b5090e2 Initial load
duke
parents:
diff changeset
   276
    while (Atomic::cmpxchg(1, &JNIHistogram_lock, 0) != 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   277
      while (OrderAccess::load_acquire(&JNIHistogram_lock) != 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   278
        count +=1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   279
        if ( (WarnOnStalledSpinLock > 0)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   280
          && (count % WarnOnStalledSpinLock == 0)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   281
          warning("JNIHistogram_lock seems to be stalled");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   282
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   283
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   284
     }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   285
489c9b5090e2 Initial load
duke
parents:
diff changeset
   286
489c9b5090e2 Initial load
duke
parents:
diff changeset
   287
    if(JNIHistogram == NULL)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   288
      JNIHistogram = new Histogram("JNI Call Counts",100);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   289
489c9b5090e2 Initial load
duke
parents:
diff changeset
   290
    JNIHistogram->add_element(this);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   291
    Atomic::dec(&JNIHistogram_lock);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   292
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   293
489c9b5090e2 Initial load
duke
parents:
diff changeset
   294
  #define JNICountWrapper(arg)                                     \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   295
     static JNIHistogramElement* e = new JNIHistogramElement(arg); \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   296
      /* There is a MT-race condition in VC++. So we need to make sure that that e has been initialized */ \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   297
     if (e != NULL) e->increment_count()
34285
0b07014c15e9 8143155: Remove TraceRuntimeCalls, TraceJNICalls, and TraceJVMCalls rather than convert to UL
rprotacio
parents: 33813
diff changeset
   298
  #define JNIWrapper(arg) JNICountWrapper(arg);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   299
#else
489c9b5090e2 Initial load
duke
parents:
diff changeset
   300
  #define JNIWrapper(arg)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   301
#endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
   302
489c9b5090e2 Initial load
duke
parents:
diff changeset
   303
489c9b5090e2 Initial load
duke
parents:
diff changeset
   304
// Implementation of JNI entries
489c9b5090e2 Initial load
duke
parents:
diff changeset
   305
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   306
DT_RETURN_MARK_DECL(DefineClass, jclass
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   307
                    , HOTSPOT_JNI_DEFINECLASS_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   308
489c9b5090e2 Initial load
duke
parents:
diff changeset
   309
JNI_ENTRY(jclass, jni_DefineClass(JNIEnv *env, const char *name, jobject loaderRef,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   310
                                  const jbyte *buf, jsize bufLen))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   311
  JNIWrapper("DefineClass");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   312
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   313
  HOTSPOT_JNI_DEFINECLASS_ENTRY(
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   314
    env, (char*) name, loaderRef, (char*) buf, bufLen);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   315
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   316
  jclass cls = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   317
  DT_RETURN_MARK(DefineClass, jclass, (const jclass&)cls);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   318
12939
c0a910665895 7171703: JNI DefineClass crashes client VM when first parameter is NULL
fparain
parents: 11480
diff changeset
   319
  TempNewSymbol class_name = NULL;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   320
  // Since exceptions can be thrown, class initialization can take place
489c9b5090e2 Initial load
duke
parents:
diff changeset
   321
  // if name is NULL no check for class name in .class stream has to be made.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   322
  if (name != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   323
    const int str_len = (int)strlen(name);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   324
    if (str_len > Symbol::max_length()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   325
      // It's impossible to create this class;  the name cannot fit
489c9b5090e2 Initial load
duke
parents:
diff changeset
   326
      // into the constant pool.
46431
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   327
      Exceptions::fthrow(THREAD_AND_LOCATION,
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   328
                         vmSymbols::java_lang_NoClassDefFoundError(),
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   329
                         "Class name exceeds maximum length of %d: %s",
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   330
                         Symbol::max_length(),
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   331
                         name);
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   332
      return 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   333
    }
54847
59ea39bb2809 8223657: Remove unused THREAD argument from SymbolTable functions
coleenp
parents: 54669
diff changeset
   334
    class_name = SymbolTable::new_symbol(name);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   335
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   336
  ResourceMark rm(THREAD);
34666
1c7168ea0034 8140485: Class load and creation cleanup
mgronlun
parents: 34649
diff changeset
   337
  ClassFileStream st((u1*)buf, bufLen, NULL, ClassFileStream::verify);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   338
  Handle class_loader (THREAD, JNIHandles::resolve(loaderRef));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   339
489c9b5090e2 Initial load
duke
parents:
diff changeset
   340
  if (UsePerfData && !class_loader.is_null()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   341
    // check whether the current caller thread holds the lock or not.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   342
    // If not, increment the corresponding counter
489c9b5090e2 Initial load
duke
parents:
diff changeset
   343
    if (ObjectSynchronizer::
489c9b5090e2 Initial load
duke
parents:
diff changeset
   344
        query_lock_ownership((JavaThread*)THREAD, class_loader) !=
489c9b5090e2 Initial load
duke
parents:
diff changeset
   345
        ObjectSynchronizer::owner_self) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   346
      ClassLoader::sync_JNIDefineClassLockFreeCounter()->inc();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   347
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   348
  }
34666
1c7168ea0034 8140485: Class load and creation cleanup
mgronlun
parents: 34649
diff changeset
   349
  Klass* k = SystemDictionary::resolve_from_stream(class_name,
1c7168ea0034 8140485: Class load and creation cleanup
mgronlun
parents: 34649
diff changeset
   350
                                                   class_loader,
1c7168ea0034 8140485: Class load and creation cleanup
mgronlun
parents: 34649
diff changeset
   351
                                                   Handle(),
1c7168ea0034 8140485: Class load and creation cleanup
mgronlun
parents: 34649
diff changeset
   352
                                                   &st,
1c7168ea0034 8140485: Class load and creation cleanup
mgronlun
parents: 34649
diff changeset
   353
                                                   CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   354
38151
fffedc5e5cf8 8154110: Update class* and safepoint* logging subsystems
mockner
parents: 37483
diff changeset
   355
  if (log_is_enabled(Debug, class, resolve) && k != NULL) {
2269
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
   356
    trace_class_resolution(k);
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
   357
  }
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
   358
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   359
  cls = (jclass)JNIHandles::make_local(
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   360
    env, k->java_mirror());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   361
  return cls;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   362
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   363
489c9b5090e2 Initial load
duke
parents:
diff changeset
   364
489c9b5090e2 Initial load
duke
parents:
diff changeset
   365
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   366
DT_RETURN_MARK_DECL(FindClass, jclass
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   367
                    , HOTSPOT_JNI_FINDCLASS_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   368
489c9b5090e2 Initial load
duke
parents:
diff changeset
   369
JNI_ENTRY(jclass, jni_FindClass(JNIEnv *env, const char *name))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   370
  JNIWrapper("FindClass");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   371
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   372
  HOTSPOT_JNI_FINDCLASS_ENTRY(env, (char *)name);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   373
489c9b5090e2 Initial load
duke
parents:
diff changeset
   374
  jclass result = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   375
  DT_RETURN_MARK(FindClass, jclass, (const jclass&)result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   376
489c9b5090e2 Initial load
duke
parents:
diff changeset
   377
  // Sanity check the name:  it cannot be null or larger than the maximum size
489c9b5090e2 Initial load
duke
parents:
diff changeset
   378
  // name we can fit in the constant pool.
46431
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   379
  if (name == NULL) {
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   380
    THROW_MSG_0(vmSymbols::java_lang_NoClassDefFoundError(), "No class name given");
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   381
  }
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   382
  if ((int)strlen(name) > Symbol::max_length()) {
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   383
    Exceptions::fthrow(THREAD_AND_LOCATION,
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   384
                       vmSymbols::java_lang_NoClassDefFoundError(),
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   385
                       "Class name exceeds maximum length of %d: %s",
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   386
                       Symbol::max_length(),
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   387
                       name);
87b0d1afe03e 8056900: Enhance NoClassDefFound exception messaging
hseigel
parents: 46369
diff changeset
   388
    return 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   389
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   390
489c9b5090e2 Initial load
duke
parents:
diff changeset
   391
  //%note jni_3
489c9b5090e2 Initial load
duke
parents:
diff changeset
   392
  Handle protection_domain;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   393
  // Find calling class
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   394
  Klass* k = thread->security_get_caller_class(0);
47662
2493edd8b479 8189193: FindClass should only see classes from the boot loader called from its associated native library
mchung
parents: 47659
diff changeset
   395
  // default to the system loader when no context
2493edd8b479 8189193: FindClass should only see classes from the boot loader called from its associated native library
mchung
parents: 47659
diff changeset
   396
  Handle loader(THREAD, SystemDictionary::java_system_loader());
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   397
  if (k != NULL) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   398
    // Special handling to make sure JNI_OnLoad and JNI_OnUnload are executed
489c9b5090e2 Initial load
duke
parents:
diff changeset
   399
    // in the correct class context.
47613
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   400
    if (k->class_loader() == NULL &&
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   401
        k->name() == vmSymbols::java_lang_ClassLoader_NativeLibrary()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   402
      JavaValue result(T_OBJECT);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   403
      JavaCalls::call_static(&result, k,
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   404
                             vmSymbols::getFromClass_name(),
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   405
                             vmSymbols::void_class_signature(),
47613
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   406
                             CHECK_NULL);
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   407
      // When invoked from JNI_OnLoad, NativeLibrary::getFromClass returns
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   408
      // a non-NULL Class object.  When invoked from JNI_OnUnload,
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   409
      // it will return NULL to indicate no context.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   410
      oop mirror = (oop) result.get_jobject();
47613
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   411
      if (mirror != NULL) {
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   412
        Klass* fromClass = java_lang_Class::as_Klass(mirror);
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   413
        loader = Handle(THREAD, fromClass->class_loader());
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   414
        protection_domain = Handle(THREAD, fromClass->protection_domain());
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   415
      }
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   416
    } else {
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   417
      loader = Handle(THREAD, k->class_loader());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   418
    }
47613
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   419
  }
af241e3e5a13 8188052: JNI FindClass needs to specify the class loading context used for library lifecycle hooks
mchung
parents: 47216
diff changeset
   420
54847
59ea39bb2809 8223657: Remove unused THREAD argument from SymbolTable functions
coleenp
parents: 54669
diff changeset
   421
  TempNewSymbol sym = SymbolTable::new_symbol(name);
58056
db92a157dd70 8212117: Class.forName may return a reference to a loaded but not linked Class
bchristi
parents: 58043
diff changeset
   422
  result = find_class_from_class_loader(env, sym, true, true, loader,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   423
                                        protection_domain, true, thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   424
38151
fffedc5e5cf8 8154110: Update class* and safepoint* logging subsystems
mockner
parents: 37483
diff changeset
   425
  if (log_is_enabled(Debug, class, resolve) && result != NULL) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   426
    trace_class_resolution(java_lang_Class::as_Klass(JNIHandles::resolve_non_null(result)));
2269
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
   427
  }
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
   428
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   429
  return result;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   430
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   431
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   432
DT_RETURN_MARK_DECL(FromReflectedMethod, jmethodID
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   433
                    , HOTSPOT_JNI_FROMREFLECTEDMETHOD_RETURN((uintptr_t)_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   434
489c9b5090e2 Initial load
duke
parents:
diff changeset
   435
JNI_ENTRY(jmethodID, jni_FromReflectedMethod(JNIEnv *env, jobject method))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   436
  JNIWrapper("FromReflectedMethod");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   437
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   438
  HOTSPOT_JNI_FROMREFLECTEDMETHOD_ENTRY(env, method);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   439
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   440
  jmethodID ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   441
  DT_RETURN_MARK(FromReflectedMethod, jmethodID, (const jmethodID&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   442
489c9b5090e2 Initial load
duke
parents:
diff changeset
   443
  // method is a handle to a java.lang.reflect.Method object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   444
  oop reflected  = JNIHandles::resolve_non_null(method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   445
  oop mirror     = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   446
  int slot       = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   447
4571
80b553bddc26 6914300: ciEnv should export all well known classes
never
parents: 4561
diff changeset
   448
  if (reflected->klass() == SystemDictionary::reflect_Constructor_klass()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   449
    mirror = java_lang_reflect_Constructor::clazz(reflected);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   450
    slot   = java_lang_reflect_Constructor::slot(reflected);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   451
  } else {
4571
80b553bddc26 6914300: ciEnv should export all well known classes
never
parents: 4561
diff changeset
   452
    assert(reflected->klass() == SystemDictionary::reflect_Method_klass(), "wrong type");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   453
    mirror = java_lang_reflect_Method::clazz(reflected);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   454
    slot   = java_lang_reflect_Method::slot(reflected);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   455
  }
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   456
  Klass* k1 = java_lang_Class::as_Klass(mirror);
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   457
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   458
  // Make sure class is initialized before handing id's out to methods
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   459
  k1->initialize(CHECK_NULL);
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   460
  Method* m = InstanceKlass::cast(k1)->method_with_idnum(slot);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   461
  ret = m==NULL? NULL : m->jmethod_id();  // return NULL if reflected method deleted
489c9b5090e2 Initial load
duke
parents:
diff changeset
   462
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   463
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   464
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   465
DT_RETURN_MARK_DECL(FromReflectedField, jfieldID
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   466
                    , HOTSPOT_JNI_FROMREFLECTEDFIELD_RETURN((uintptr_t)_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   467
489c9b5090e2 Initial load
duke
parents:
diff changeset
   468
JNI_ENTRY(jfieldID, jni_FromReflectedField(JNIEnv *env, jobject field))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   469
  JNIWrapper("FromReflectedField");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   470
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   471
  HOTSPOT_JNI_FROMREFLECTEDFIELD_ENTRY(env, field);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   472
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   473
  jfieldID ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   474
  DT_RETURN_MARK(FromReflectedField, jfieldID, (const jfieldID&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   475
489c9b5090e2 Initial load
duke
parents:
diff changeset
   476
  // field is a handle to a java.lang.reflect.Field object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   477
  oop reflected   = JNIHandles::resolve_non_null(field);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   478
  oop mirror      = java_lang_reflect_Field::clazz(reflected);
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   479
  Klass* k1       = java_lang_Class::as_Klass(mirror);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   480
  int slot        = java_lang_reflect_Field::slot(reflected);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   481
  int modifiers   = java_lang_reflect_Field::modifiers(reflected);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   482
489c9b5090e2 Initial load
duke
parents:
diff changeset
   483
  // Make sure class is initialized before handing id's out to fields
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   484
  k1->initialize(CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   485
489c9b5090e2 Initial load
duke
parents:
diff changeset
   486
  // First check if this is a static field
489c9b5090e2 Initial load
duke
parents:
diff changeset
   487
  if (modifiers & JVM_ACC_STATIC) {
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   488
    intptr_t offset = InstanceKlass::cast(k1)->field_offset( slot );
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   489
    JNIid* id = InstanceKlass::cast(k1)->jni_id_for(offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   490
    assert(id != NULL, "corrupt Field object");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   491
    debug_only(id->set_is_static_field_id();)
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   492
    // A jfieldID for a static field is a JNIid specifying the field holder and the offset within the Klass*
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   493
    ret = jfieldIDWorkaround::to_static_jfieldID(id);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   494
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   495
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   496
489c9b5090e2 Initial load
duke
parents:
diff changeset
   497
  // The slot is the index of the field description in the field-array
489c9b5090e2 Initial load
duke
parents:
diff changeset
   498
  // The jfieldID is the offset of the field within the object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   499
  // It may also have hash bits for k, if VerifyJNIFields is turned on.
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   500
  intptr_t offset = InstanceKlass::cast(k1)->field_offset( slot );
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   501
  assert(InstanceKlass::cast(k1)->contains_field_offset(offset), "stay within object");
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   502
  ret = jfieldIDWorkaround::to_instance_jfieldID(k1, offset);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   503
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   504
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   505
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   506
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   507
DT_RETURN_MARK_DECL(ToReflectedMethod, jobject
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   508
                    , HOTSPOT_JNI_TOREFLECTEDMETHOD_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   509
489c9b5090e2 Initial load
duke
parents:
diff changeset
   510
JNI_ENTRY(jobject, jni_ToReflectedMethod(JNIEnv *env, jclass cls, jmethodID method_id, jboolean isStatic))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   511
  JNIWrapper("ToReflectedMethod");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   512
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   513
  HOTSPOT_JNI_TOREFLECTEDMETHOD_ENTRY(env, cls, (uintptr_t) method_id, isStatic);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   514
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   515
  jobject ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   516
  DT_RETURN_MARK(ToReflectedMethod, jobject, (const jobject&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   517
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   518
  methodHandle m (THREAD, Method::resolve_jmethod_id(method_id));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   519
  assert(m->is_static() == (isStatic != 0), "jni_ToReflectedMethod access flags doesn't match");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   520
  oop reflection_method;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   521
  if (m->is_initializer()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   522
    reflection_method = Reflection::new_constructor(m, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   523
  } else {
24456
8c7933fa5a1f 8025580: Temporary flags: UseNewReflection and ReflectionWrapResolutionErrors
coleenp
parents: 24424
diff changeset
   524
    reflection_method = Reflection::new_method(m, false, CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   525
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   526
  ret = JNIHandles::make_local(env, reflection_method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   527
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   528
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   529
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   530
DT_RETURN_MARK_DECL(GetSuperclass, jclass
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   531
                    , HOTSPOT_JNI_GETSUPERCLASS_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   532
489c9b5090e2 Initial load
duke
parents:
diff changeset
   533
JNI_ENTRY(jclass, jni_GetSuperclass(JNIEnv *env, jclass sub))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   534
  JNIWrapper("GetSuperclass");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   535
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   536
  HOTSPOT_JNI_GETSUPERCLASS_ENTRY(env, sub);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   537
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   538
  jclass obj = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   539
  DT_RETURN_MARK(GetSuperclass, jclass, (const jclass&)obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   540
489c9b5090e2 Initial load
duke
parents:
diff changeset
   541
  oop mirror = JNIHandles::resolve_non_null(sub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   542
  // primitive classes return NULL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   543
  if (java_lang_Class::is_primitive(mirror)) return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   544
489c9b5090e2 Initial load
duke
parents:
diff changeset
   545
  // Rules of Class.getSuperClass as implemented by KLass::java_super:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   546
  // arrays return Object
489c9b5090e2 Initial load
duke
parents:
diff changeset
   547
  // interfaces return NULL
489c9b5090e2 Initial load
duke
parents:
diff changeset
   548
  // proper classes return Klass::super()
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   549
  Klass* k = java_lang_Class::as_Klass(mirror);
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   550
  if (k->is_interface()) return NULL;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   551
489c9b5090e2 Initial load
duke
parents:
diff changeset
   552
  // return mirror for superclass
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   553
  Klass* super = k->java_super();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   554
  // super2 is the value computed by the compiler's getSuperClass intrinsic:
33611
9abd65805e19 8139203: Consistent naming for klass type predicates
coleenp
parents: 33576
diff changeset
   555
  debug_only(Klass* super2 = ( k->is_array_klass()
4571
80b553bddc26 6914300: ciEnv should export all well known classes
never
parents: 4561
diff changeset
   556
                                 ? SystemDictionary::Object_klass()
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   557
                                 : k->super() ) );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   558
  assert(super == super2,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   559
         "java_super computation depends on interface, array, other super");
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   560
  obj = (super == NULL) ? NULL : (jclass) JNIHandles::make_local(super->java_mirror());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   561
  return obj;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   562
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   563
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
   564
JNI_ENTRY_NO_PRESERVE(jboolean, jni_IsAssignableFrom(JNIEnv *env, jclass sub, jclass super))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   565
  JNIWrapper("IsSubclassOf");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   566
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   567
  HOTSPOT_JNI_ISASSIGNABLEFROM_ENTRY(env, sub, super);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   568
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   569
  oop sub_mirror   = JNIHandles::resolve_non_null(sub);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   570
  oop super_mirror = JNIHandles::resolve_non_null(super);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   571
  if (java_lang_Class::is_primitive(sub_mirror) ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
   572
      java_lang_Class::is_primitive(super_mirror)) {
58177
4932dce35882 8230841: Remove oopDesc::equals()
pliden
parents: 58056
diff changeset
   573
    jboolean ret = (sub_mirror == super_mirror);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   574
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   575
    HOTSPOT_JNI_ISASSIGNABLEFROM_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   576
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   577
  }
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   578
  Klass* sub_klass   = java_lang_Class::as_Klass(sub_mirror);
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   579
  Klass* super_klass = java_lang_Class::as_Klass(super_mirror);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   580
  assert(sub_klass != NULL && super_klass != NULL, "invalid arguments to jni_IsAssignableFrom");
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   581
  jboolean ret = sub_klass->is_subtype_of(super_klass) ?
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   582
                   JNI_TRUE : JNI_FALSE;
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   583
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   584
  HOTSPOT_JNI_ISASSIGNABLEFROM_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   585
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   586
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   587
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   588
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   589
DT_RETURN_MARK_DECL(Throw, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   590
                    , HOTSPOT_JNI_THROW_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   591
489c9b5090e2 Initial load
duke
parents:
diff changeset
   592
JNI_ENTRY(jint, jni_Throw(JNIEnv *env, jthrowable obj))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   593
  JNIWrapper("Throw");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   594
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   595
  HOTSPOT_JNI_THROW_ENTRY(env, obj);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   596
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   597
  jint ret = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   598
  DT_RETURN_MARK(Throw, jint, (const jint&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   599
489c9b5090e2 Initial load
duke
parents:
diff changeset
   600
  THROW_OOP_(JNIHandles::resolve(obj), JNI_OK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   601
  ShouldNotReachHere();
27679
06b3a53d7781 8064786: Fix debug build after 8062808: Turn on the -Wreturn-type warning
goetz
parents: 27247
diff changeset
   602
  return 0;  // Mute compiler.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   603
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   604
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   605
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   606
DT_RETURN_MARK_DECL(ThrowNew, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
   607
                    , HOTSPOT_JNI_THROWNEW_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   608
489c9b5090e2 Initial load
duke
parents:
diff changeset
   609
JNI_ENTRY(jint, jni_ThrowNew(JNIEnv *env, jclass clazz, const char *message))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   610
  JNIWrapper("ThrowNew");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   611
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   612
  HOTSPOT_JNI_THROWNEW_ENTRY(env, clazz, (char *) message);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   613
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   614
  jint ret = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   615
  DT_RETURN_MARK(ThrowNew, jint, (const jint&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   616
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   617
  InstanceKlass* k = InstanceKlass::cast(java_lang_Class::as_Klass(JNIHandles::resolve_non_null(clazz)));
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   618
  Symbol*  name = k->name();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   619
  Handle class_loader (THREAD,  k->class_loader());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   620
  Handle protection_domain (THREAD, k->protection_domain());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   621
  THROW_MSG_LOADER_(name, (char *)message, class_loader, protection_domain, JNI_OK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   622
  ShouldNotReachHere();
27679
06b3a53d7781 8064786: Fix debug build after 8062808: Turn on the -Wreturn-type warning
goetz
parents: 27247
diff changeset
   623
  return 0;  // Mute compiler.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   624
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   625
489c9b5090e2 Initial load
duke
parents:
diff changeset
   626
489c9b5090e2 Initial load
duke
parents:
diff changeset
   627
// JNI functions only transform a pending async exception to a synchronous
489c9b5090e2 Initial load
duke
parents:
diff changeset
   628
// exception in ExceptionOccurred and ExceptionCheck calls, since
489c9b5090e2 Initial load
duke
parents:
diff changeset
   629
// delivering an async exception in other places won't change the native
489c9b5090e2 Initial load
duke
parents:
diff changeset
   630
// code's control flow and would be harmful when native code further calls
489c9b5090e2 Initial load
duke
parents:
diff changeset
   631
// JNI functions with a pending exception. Async exception is also checked
489c9b5090e2 Initial load
duke
parents:
diff changeset
   632
// during the call, so ExceptionOccurred/ExceptionCheck won't return
489c9b5090e2 Initial load
duke
parents:
diff changeset
   633
// false but deliver the async exception at the very end during
489c9b5090e2 Initial load
duke
parents:
diff changeset
   634
// state transition.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   635
489c9b5090e2 Initial load
duke
parents:
diff changeset
   636
static void jni_check_async_exceptions(JavaThread *thread) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   637
  assert(thread == Thread::current(), "must be itself");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   638
  thread->check_and_handle_async_exceptions();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   639
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
   640
489c9b5090e2 Initial load
duke
parents:
diff changeset
   641
JNI_ENTRY_NO_PRESERVE(jthrowable, jni_ExceptionOccurred(JNIEnv *env))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   642
  JNIWrapper("ExceptionOccurred");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   643
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   644
  HOTSPOT_JNI_EXCEPTIONOCCURRED_ENTRY(env);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   645
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   646
  jni_check_async_exceptions(thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   647
  oop exception = thread->pending_exception();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   648
  jthrowable ret = (jthrowable) JNIHandles::make_local(env, exception);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   649
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   650
  HOTSPOT_JNI_EXCEPTIONOCCURRED_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   651
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   652
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   653
489c9b5090e2 Initial load
duke
parents:
diff changeset
   654
489c9b5090e2 Initial load
duke
parents:
diff changeset
   655
JNI_ENTRY_NO_PRESERVE(void, jni_ExceptionDescribe(JNIEnv *env))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   656
  JNIWrapper("ExceptionDescribe");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   657
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   658
  HOTSPOT_JNI_EXCEPTIONDESCRIBE_ENTRY(env);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   659
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   660
  if (thread->has_pending_exception()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   661
    Handle ex(thread, thread->pending_exception());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   662
    thread->clear_pending_exception();
4571
80b553bddc26 6914300: ciEnv should export all well known classes
never
parents: 4561
diff changeset
   663
    if (ex->is_a(SystemDictionary::ThreadDeath_klass())) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   664
      // Don't print anything if we are being killed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   665
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   666
      jio_fprintf(defaultStream::error_stream(), "Exception ");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   667
      if (thread != NULL && thread->threadObj() != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   668
        ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   669
        jio_fprintf(defaultStream::error_stream(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   670
        "in thread \"%s\" ", thread->get_thread_name());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   671
      }
4571
80b553bddc26 6914300: ciEnv should export all well known classes
never
parents: 4561
diff changeset
   672
      if (ex->is_a(SystemDictionary::Throwable_klass())) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   673
        JavaValue result(T_VOID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   674
        JavaCalls::call_virtual(&result,
489c9b5090e2 Initial load
duke
parents:
diff changeset
   675
                                ex,
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
   676
                                SystemDictionary::Throwable_klass(),
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   677
                                vmSymbols::printStackTrace_name(),
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   678
                                vmSymbols::void_method_signature(),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   679
                                THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   680
        // If an exception is thrown in the call it gets thrown away. Not much
489c9b5090e2 Initial load
duke
parents:
diff changeset
   681
        // we can do with it. The native code that calls this, does not check
489c9b5090e2 Initial load
duke
parents:
diff changeset
   682
        // for the exception - hence, it might still be in the thread when DestroyVM gets
489c9b5090e2 Initial load
duke
parents:
diff changeset
   683
        // called, potentially causing a few asserts to trigger - since no pending exception
489c9b5090e2 Initial load
duke
parents:
diff changeset
   684
        // is expected.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   685
        CLEAR_PENDING_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   686
      } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   687
        ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   688
        jio_fprintf(defaultStream::error_stream(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
   689
        ". Uncaught exception of type %s.",
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
   690
        ex->klass()->external_name());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   691
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   692
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   693
  }
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   694
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   695
  HOTSPOT_JNI_EXCEPTIONDESCRIBE_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   696
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   697
489c9b5090e2 Initial load
duke
parents:
diff changeset
   698
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
   699
JNI_ENTRY_NO_PRESERVE(void, jni_ExceptionClear(JNIEnv *env))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   700
  JNIWrapper("ExceptionClear");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   701
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   702
  HOTSPOT_JNI_EXCEPTIONCLEAR_ENTRY(env);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   703
489c9b5090e2 Initial load
duke
parents:
diff changeset
   704
  // The jni code might be using this API to clear java thrown exception.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   705
  // So just mark jvmti thread exception state as exception caught.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   706
  JvmtiThreadState *state = JavaThread::current()->jvmti_thread_state();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   707
  if (state != NULL && state->is_exception_detected()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   708
    state->set_exception_caught();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   709
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   710
  thread->clear_pending_exception();
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   711
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   712
  HOTSPOT_JNI_EXCEPTIONCLEAR_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   713
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   714
489c9b5090e2 Initial load
duke
parents:
diff changeset
   715
489c9b5090e2 Initial load
duke
parents:
diff changeset
   716
JNI_ENTRY(void, jni_FatalError(JNIEnv *env, const char *msg))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   717
  JNIWrapper("FatalError");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   718
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   719
  HOTSPOT_JNI_FATALERROR_ENTRY(env, (char *) msg);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   720
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   721
  tty->print_cr("FATAL ERROR in native method: %s", msg);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   722
  thread->print_stack();
773
01daf7c809b1 6694099: Hotspot vm_exit_out_of_memory should dump core
poonam
parents: 360
diff changeset
   723
  os::abort(); // Dump core and abort
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   724
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   725
489c9b5090e2 Initial load
duke
parents:
diff changeset
   726
489c9b5090e2 Initial load
duke
parents:
diff changeset
   727
JNI_ENTRY(jint, jni_PushLocalFrame(JNIEnv *env, jint capacity))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   728
  JNIWrapper("PushLocalFrame");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   729
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   730
  HOTSPOT_JNI_PUSHLOCALFRAME_ENTRY(env, capacity);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   731
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   732
  //%note jni_11
25630
ff281ea14d41 8046919: jni_PushLocalFrame OOM - increase MAX_REASONABLE_LOCAL_CAPACITY
dsimms
parents: 25477
diff changeset
   733
  if (capacity < 0 ||
ff281ea14d41 8046919: jni_PushLocalFrame OOM - increase MAX_REASONABLE_LOCAL_CAPACITY
dsimms
parents: 25477
diff changeset
   734
      ((MaxJNILocalCapacity > 0) && (capacity > MaxJNILocalCapacity))) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   735
    HOTSPOT_JNI_PUSHLOCALFRAME_RETURN((uint32_t)JNI_ERR);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   736
    return JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   737
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   738
  JNIHandleBlock* old_handles = thread->active_handles();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   739
  JNIHandleBlock* new_handles = JNIHandleBlock::allocate_block(thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   740
  assert(new_handles != NULL, "should not be NULL");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   741
  new_handles->set_pop_frame_link(old_handles);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   742
  thread->set_active_handles(new_handles);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   743
  jint ret = JNI_OK;
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   744
  HOTSPOT_JNI_PUSHLOCALFRAME_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   745
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   746
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   747
489c9b5090e2 Initial load
duke
parents:
diff changeset
   748
489c9b5090e2 Initial load
duke
parents:
diff changeset
   749
JNI_ENTRY(jobject, jni_PopLocalFrame(JNIEnv *env, jobject result))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   750
  JNIWrapper("PopLocalFrame");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   751
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   752
  HOTSPOT_JNI_POPLOCALFRAME_ENTRY(env, result);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   753
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   754
  //%note jni_11
489c9b5090e2 Initial load
duke
parents:
diff changeset
   755
  Handle result_handle(thread, JNIHandles::resolve(result));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   756
  JNIHandleBlock* old_handles = thread->active_handles();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   757
  JNIHandleBlock* new_handles = old_handles->pop_frame_link();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   758
  if (new_handles != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   759
    // As a sanity check we only release the handle blocks if the pop_frame_link is not NULL.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   760
    // This way code will still work if PopLocalFrame is called without a corresponding
489c9b5090e2 Initial load
duke
parents:
diff changeset
   761
    // PushLocalFrame call. Note that we set the pop_frame_link to NULL explicitly, otherwise
489c9b5090e2 Initial load
duke
parents:
diff changeset
   762
    // the release_block call will release the blocks.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   763
    thread->set_active_handles(new_handles);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   764
    old_handles->set_pop_frame_link(NULL);              // clear link we won't release new_handles below
489c9b5090e2 Initial load
duke
parents:
diff changeset
   765
    JNIHandleBlock::release_block(old_handles, thread); // may block
489c9b5090e2 Initial load
duke
parents:
diff changeset
   766
    result = JNIHandles::make_local(thread, result_handle());
489c9b5090e2 Initial load
duke
parents:
diff changeset
   767
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   768
  HOTSPOT_JNI_POPLOCALFRAME_RETURN(result);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   769
  return result;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   770
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   771
489c9b5090e2 Initial load
duke
parents:
diff changeset
   772
489c9b5090e2 Initial load
duke
parents:
diff changeset
   773
JNI_ENTRY(jobject, jni_NewGlobalRef(JNIEnv *env, jobject ref))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   774
  JNIWrapper("NewGlobalRef");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   775
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   776
  HOTSPOT_JNI_NEWGLOBALREF_ENTRY(env, ref);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   777
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   778
  Handle ref_handle(thread, JNIHandles::resolve(ref));
489c9b5090e2 Initial load
duke
parents:
diff changeset
   779
  jobject ret = JNIHandles::make_global(ref_handle);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   780
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   781
  HOTSPOT_JNI_NEWGLOBALREF_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   782
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   783
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   784
489c9b5090e2 Initial load
duke
parents:
diff changeset
   785
// Must be JNI_ENTRY (with HandleMark)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   786
JNI_ENTRY_NO_PRESERVE(void, jni_DeleteGlobalRef(JNIEnv *env, jobject ref))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   787
  JNIWrapper("DeleteGlobalRef");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   788
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   789
  HOTSPOT_JNI_DELETEGLOBALREF_ENTRY(env, ref);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   790
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   791
  JNIHandles::destroy_global(ref);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   792
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   793
  HOTSPOT_JNI_DELETEGLOBALREF_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   794
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   795
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
   796
JNI_ENTRY_NO_PRESERVE(void, jni_DeleteLocalRef(JNIEnv *env, jobject obj))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   797
  JNIWrapper("DeleteLocalRef");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   798
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   799
  HOTSPOT_JNI_DELETELOCALREF_ENTRY(env, obj);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   800
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   801
  JNIHandles::destroy_local(obj);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   802
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   803
  HOTSPOT_JNI_DELETELOCALREF_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   804
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   805
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
   806
JNI_ENTRY_NO_PRESERVE(jboolean, jni_IsSameObject(JNIEnv *env, jobject r1, jobject r2))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   807
  JNIWrapper("IsSameObject");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   808
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   809
  HOTSPOT_JNI_ISSAMEOBJECT_ENTRY(env, r1, r2);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   810
53060
7aa1a37b04a2 8215451: JNI IsSameObject should not keep objects alive
pliden
parents: 52934
diff changeset
   811
  jboolean ret = JNIHandles::is_same_object(r1, r2) ? JNI_TRUE : JNI_FALSE;
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   812
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   813
  HOTSPOT_JNI_ISSAMEOBJECT_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   814
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   815
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   816
489c9b5090e2 Initial load
duke
parents:
diff changeset
   817
489c9b5090e2 Initial load
duke
parents:
diff changeset
   818
JNI_ENTRY(jobject, jni_NewLocalRef(JNIEnv *env, jobject ref))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   819
  JNIWrapper("NewLocalRef");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   820
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   821
  HOTSPOT_JNI_NEWLOCALREF_ENTRY(env, ref);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   822
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   823
  jobject ret = JNIHandles::make_local(env, JNIHandles::resolve(ref));
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   824
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   825
  HOTSPOT_JNI_NEWLOCALREF_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   826
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   827
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   828
489c9b5090e2 Initial load
duke
parents:
diff changeset
   829
JNI_LEAF(jint, jni_EnsureLocalCapacity(JNIEnv *env, jint capacity))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   830
  JNIWrapper("EnsureLocalCapacity");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   831
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   832
  HOTSPOT_JNI_ENSURELOCALCAPACITY_ENTRY(env, capacity);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   833
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   834
  jint ret;
25630
ff281ea14d41 8046919: jni_PushLocalFrame OOM - increase MAX_REASONABLE_LOCAL_CAPACITY
dsimms
parents: 25477
diff changeset
   835
  if (capacity >= 0 &&
ff281ea14d41 8046919: jni_PushLocalFrame OOM - increase MAX_REASONABLE_LOCAL_CAPACITY
dsimms
parents: 25477
diff changeset
   836
      ((MaxJNILocalCapacity <= 0) || (capacity <= MaxJNILocalCapacity))) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   837
    ret = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   838
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   839
    ret = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   840
  }
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   841
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   842
  HOTSPOT_JNI_ENSURELOCALCAPACITY_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   843
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   844
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   845
489c9b5090e2 Initial load
duke
parents:
diff changeset
   846
// Return the Handle Type
489c9b5090e2 Initial load
duke
parents:
diff changeset
   847
JNI_LEAF(jobjectRefType, jni_GetObjectRefType(JNIEnv *env, jobject obj))
489c9b5090e2 Initial load
duke
parents:
diff changeset
   848
  JNIWrapper("GetObjectRefType");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   849
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   850
  HOTSPOT_JNI_GETOBJECTREFTYPE_ENTRY(env, obj);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   851
48808
2b0b7f222800 8195690: JNI GetObjectRefType doesn't handle NULL
kbarrett
parents: 48787
diff changeset
   852
  jobjectRefType ret = JNIInvalidRefType;
2b0b7f222800 8195690: JNI GetObjectRefType doesn't handle NULL
kbarrett
parents: 48787
diff changeset
   853
  if (obj != NULL) {
2b0b7f222800 8195690: JNI GetObjectRefType doesn't handle NULL
kbarrett
parents: 48787
diff changeset
   854
    ret = JNIHandles::handle_type(thread, obj);
2b0b7f222800 8195690: JNI GetObjectRefType doesn't handle NULL
kbarrett
parents: 48787
diff changeset
   855
  }
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
   856
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
   857
  HOTSPOT_JNI_GETOBJECTREFTYPE_RETURN((void *) ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   858
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   859
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
   860
489c9b5090e2 Initial load
duke
parents:
diff changeset
   861
489c9b5090e2 Initial load
duke
parents:
diff changeset
   862
class JNI_ArgumentPusher : public SignatureIterator {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   863
 protected:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   864
  JavaCallArguments*  _arguments;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   865
489c9b5090e2 Initial load
duke
parents:
diff changeset
   866
  virtual void get_bool   () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   867
  virtual void get_char   () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   868
  virtual void get_short  () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   869
  virtual void get_byte   () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   870
  virtual void get_int    () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   871
  virtual void get_long   () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   872
  virtual void get_float  () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   873
  virtual void get_double () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   874
  virtual void get_object () = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   875
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   876
  JNI_ArgumentPusher(Symbol* signature) : SignatureIterator(signature) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   877
    this->_return_type = T_ILLEGAL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   878
    _arguments = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   879
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   880
489c9b5090e2 Initial load
duke
parents:
diff changeset
   881
 public:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   882
  virtual void iterate( uint64_t fingerprint ) = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   883
489c9b5090e2 Initial load
duke
parents:
diff changeset
   884
  void set_java_argument_object(JavaCallArguments *arguments) { _arguments = arguments; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   885
489c9b5090e2 Initial load
duke
parents:
diff changeset
   886
  inline void do_bool()                     { if (!is_return_type()) get_bool();   }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   887
  inline void do_char()                     { if (!is_return_type()) get_char();   }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   888
  inline void do_short()                    { if (!is_return_type()) get_short();  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   889
  inline void do_byte()                     { if (!is_return_type()) get_byte();   }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   890
  inline void do_int()                      { if (!is_return_type()) get_int();    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   891
  inline void do_long()                     { if (!is_return_type()) get_long();   }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   892
  inline void do_float()                    { if (!is_return_type()) get_float();  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   893
  inline void do_double()                   { if (!is_return_type()) get_double(); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   894
  inline void do_object(int begin, int end) { if (!is_return_type()) get_object(); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   895
  inline void do_array(int begin, int end)  { if (!is_return_type()) get_object(); } // do_array uses get_object -- there is no get_array
489c9b5090e2 Initial load
duke
parents:
diff changeset
   896
  inline void do_void()                     { }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   897
489c9b5090e2 Initial load
duke
parents:
diff changeset
   898
  JavaCallArguments* arguments()     { return _arguments; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   899
  void push_receiver(Handle h)       { _arguments->push_oop(h); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   900
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   901
489c9b5090e2 Initial load
duke
parents:
diff changeset
   902
489c9b5090e2 Initial load
duke
parents:
diff changeset
   903
class JNI_ArgumentPusherVaArg : public JNI_ArgumentPusher {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   904
 protected:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   905
  va_list _ap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   906
37483
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   907
  inline void get_bool()   {
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   908
    // Normalize boolean arguments from native code by converting 1-255 to JNI_TRUE and
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   909
    // 0 to JNI_FALSE.  Boolean return values from native are normalized the same in
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   910
    // TemplateInterpreterGenerator::generate_result_handler_for and
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   911
    // SharedRuntime::generate_native_wrapper.
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   912
    jboolean b = va_arg(_ap, jint);
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   913
    _arguments->push_int((jint)(b == 0 ? JNI_FALSE : JNI_TRUE));
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   914
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   915
  inline void get_char()   { _arguments->push_int(va_arg(_ap, jint)); } // char is coerced to int when using va_arg
489c9b5090e2 Initial load
duke
parents:
diff changeset
   916
  inline void get_short()  { _arguments->push_int(va_arg(_ap, jint)); } // short is coerced to int when using va_arg
489c9b5090e2 Initial load
duke
parents:
diff changeset
   917
  inline void get_byte()   { _arguments->push_int(va_arg(_ap, jint)); } // byte is coerced to int when using va_arg
489c9b5090e2 Initial load
duke
parents:
diff changeset
   918
  inline void get_int()    { _arguments->push_int(va_arg(_ap, jint)); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   919
489c9b5090e2 Initial load
duke
parents:
diff changeset
   920
  // each of these paths is exercized by the various jck Call[Static,Nonvirtual,][Void,Int,..]Method[A,V,] tests
489c9b5090e2 Initial load
duke
parents:
diff changeset
   921
489c9b5090e2 Initial load
duke
parents:
diff changeset
   922
  inline void get_long()   { _arguments->push_long(va_arg(_ap, jlong)); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   923
  inline void get_float()  { _arguments->push_float((jfloat)va_arg(_ap, jdouble)); } // float is coerced to double w/ va_arg
489c9b5090e2 Initial load
duke
parents:
diff changeset
   924
  inline void get_double() { _arguments->push_double(va_arg(_ap, jdouble)); }
44406
a46a6c4d1dd9 8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents: 44093
diff changeset
   925
  inline void get_object() { _arguments->push_jobject(va_arg(_ap, jobject)); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   926
489c9b5090e2 Initial load
duke
parents:
diff changeset
   927
  inline void set_ap(va_list rap) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   928
    va_copy(_ap, rap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   929
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   930
489c9b5090e2 Initial load
duke
parents:
diff changeset
   931
 public:
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   932
  JNI_ArgumentPusherVaArg(Symbol* signature, va_list rap)
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   933
       : JNI_ArgumentPusher(signature) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   934
    set_ap(rap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   935
  }
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
   936
  JNI_ArgumentPusherVaArg(jmethodID method_id, va_list rap)
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
   937
      : JNI_ArgumentPusher(Method::resolve_jmethod_id(method_id)->signature()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   938
    set_ap(rap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   939
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   940
489c9b5090e2 Initial load
duke
parents:
diff changeset
   941
  // Optimized path if we have the bitvector form of signature
489c9b5090e2 Initial load
duke
parents:
diff changeset
   942
  void iterate( uint64_t fingerprint ) {
27471
6e56277909f1 8062370: Various minor code improvements
goetz
parents: 27247
diff changeset
   943
    if (fingerprint == (uint64_t)CONST64(-1)) {
6e56277909f1 8062370: Various minor code improvements
goetz
parents: 27247
diff changeset
   944
      SignatureIterator::iterate(); // Must be too many arguments
6e56277909f1 8062370: Various minor code improvements
goetz
parents: 27247
diff changeset
   945
    } else {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   946
      _return_type = (BasicType)((fingerprint >> static_feature_size) &
489c9b5090e2 Initial load
duke
parents:
diff changeset
   947
                                  result_feature_mask);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   948
489c9b5090e2 Initial load
duke
parents:
diff changeset
   949
      assert(fingerprint, "Fingerprint should not be 0");
489c9b5090e2 Initial load
duke
parents:
diff changeset
   950
      fingerprint = fingerprint >> (static_feature_size + result_feature_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
   951
      while ( 1 ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   952
        switch ( fingerprint & parameter_feature_mask ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   953
          case bool_parm:
37483
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   954
            get_bool();
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   955
            break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   956
          case char_parm:
37483
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   957
            get_char();
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   958
            break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   959
          case short_parm:
37483
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   960
            get_short();
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   961
            break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   962
          case byte_parm:
37483
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   963
            get_byte();
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   964
            break;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   965
          case int_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   966
            get_int();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   967
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   968
          case obj_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   969
            get_object();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   970
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   971
          case long_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   972
            get_long();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   973
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   974
          case float_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   975
            get_float();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   976
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   977
          case double_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   978
            get_double();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   979
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   980
          case done_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   981
            return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   982
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   983
          default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   984
            ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
   985
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   986
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   987
        fingerprint >>= parameter_feature_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   988
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   989
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   990
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
   991
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
   992
489c9b5090e2 Initial load
duke
parents:
diff changeset
   993
489c9b5090e2 Initial load
duke
parents:
diff changeset
   994
class JNI_ArgumentPusherArray : public JNI_ArgumentPusher {
489c9b5090e2 Initial load
duke
parents:
diff changeset
   995
 protected:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   996
  const jvalue *_ap;
489c9b5090e2 Initial load
duke
parents:
diff changeset
   997
37483
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   998
  inline void get_bool()   {
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
   999
    // Normalize boolean arguments from native code by converting 1-255 to JNI_TRUE and
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
  1000
    // 0 to JNI_FALSE.  Boolean return values from native are normalized the same in
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
  1001
    // TemplateInterpreterGenerator::generate_result_handler_for and
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
  1002
    // SharedRuntime::generate_native_wrapper.
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
  1003
    jboolean b = (_ap++)->z;
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
  1004
    _arguments->push_int((jint)(b == 0 ? JNI_FALSE : JNI_TRUE));
8447cff6323d 8149170: Better byte behavior should normalize JNI arguments
coleenp
parents: 37480
diff changeset
  1005
  }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1006
  inline void get_char()   { _arguments->push_int((jint)(_ap++)->c); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1007
  inline void get_short()  { _arguments->push_int((jint)(_ap++)->s); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1008
  inline void get_byte()   { _arguments->push_int((jint)(_ap++)->b); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1009
  inline void get_int()    { _arguments->push_int((jint)(_ap++)->i); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1010
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1011
  inline void get_long()   { _arguments->push_long((_ap++)->j);  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1012
  inline void get_float()  { _arguments->push_float((_ap++)->f); }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1013
  inline void get_double() { _arguments->push_double((_ap++)->d);}
44406
a46a6c4d1dd9 8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents: 44093
diff changeset
  1014
  inline void get_object() { _arguments->push_jobject((_ap++)->l); }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1015
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1016
  inline void set_ap(const jvalue *rap) { _ap = rap; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1017
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1018
 public:
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1019
  JNI_ArgumentPusherArray(Symbol* signature, const jvalue *rap)
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1020
       : JNI_ArgumentPusher(signature) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1021
    set_ap(rap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1022
  }
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1023
  JNI_ArgumentPusherArray(jmethodID method_id, const jvalue *rap)
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1024
      : JNI_ArgumentPusher(Method::resolve_jmethod_id(method_id)->signature()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1025
    set_ap(rap);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1026
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1027
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1028
  // Optimized path if we have the bitvector form of signature
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1029
  void iterate( uint64_t fingerprint ) {
27471
6e56277909f1 8062370: Various minor code improvements
goetz
parents: 27247
diff changeset
  1030
    if (fingerprint == (uint64_t)CONST64(-1)) {
6e56277909f1 8062370: Various minor code improvements
goetz
parents: 27247
diff changeset
  1031
      SignatureIterator::iterate(); // Must be too many arguments
6e56277909f1 8062370: Various minor code improvements
goetz
parents: 27247
diff changeset
  1032
    } else {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1033
      _return_type = (BasicType)((fingerprint >> static_feature_size) &
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1034
                                  result_feature_mask);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1035
      assert(fingerprint, "Fingerprint should not be 0");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1036
      fingerprint = fingerprint >> (static_feature_size + result_feature_size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1037
      while ( 1 ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1038
        switch ( fingerprint & parameter_feature_mask ) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1039
          case bool_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1040
            get_bool();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1041
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1042
          case char_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1043
            get_char();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1044
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1045
          case short_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1046
            get_short();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1047
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1048
          case byte_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1049
            get_byte();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1050
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1051
          case int_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1052
            get_int();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1053
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1054
          case obj_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1055
            get_object();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1056
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1057
          case long_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1058
            get_long();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1059
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1060
          case float_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1061
            get_float();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1062
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1063
          case double_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1064
            get_double();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1065
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1066
          case done_parm:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1067
            return;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1068
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1069
          default:
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1070
            ShouldNotReachHere();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1071
            break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1072
        }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1073
        fingerprint >>= parameter_feature_size;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1074
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1075
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1076
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1077
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1078
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1079
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1080
enum JNICallType {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1081
  JNI_STATIC,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1082
  JNI_VIRTUAL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1083
  JNI_NONVIRTUAL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1084
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1085
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1086
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1087
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1088
static void jni_invoke_static(JNIEnv *env, JavaValue* result, jobject receiver, JNICallType call_type, jmethodID method_id, JNI_ArgumentPusher *args, TRAPS) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1089
  methodHandle method(THREAD, Method::resolve_jmethod_id(method_id));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1090
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1091
  // Create object to hold arguments for the JavaCall, and associate it with
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1092
  // the jni parser
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1093
  ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1094
  int number_of_parameters = method->size_of_parameters();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1095
  JavaCallArguments java_args(number_of_parameters);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1096
  args->set_java_argument_object(&java_args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1097
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1098
  assert(method->is_static(), "method should be static");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1099
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1100
  // Fill out JavaCallArguments object
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1101
  args->iterate( Fingerprinter(method).fingerprint() );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1102
  // Initialize result type
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1103
  result->set_type(args->get_ret_type());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1104
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1105
  // Invoke the method. Result is returned as oop.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1106
  JavaCalls::call(result, method, &java_args, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1107
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1108
  // Convert result
58273
08a5148e7c4e 8230505: Replace JVM type comparisons to T_OBJECT and T_ARRAY with call to is_reference_type
lfoltan
parents: 58177
diff changeset
  1109
  if (is_reference_type(result->get_type())) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1110
    result->set_jobject(JNIHandles::make_local(env, (oop) result->get_jobject()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1111
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1112
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1113
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1114
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1115
static void jni_invoke_nonstatic(JNIEnv *env, JavaValue* result, jobject receiver, JNICallType call_type, jmethodID method_id, JNI_ArgumentPusher *args, TRAPS) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1116
  oop recv = JNIHandles::resolve(receiver);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1117
  if (recv == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1118
    THROW(vmSymbols::java_lang_NullPointerException());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1119
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1120
  Handle h_recv(THREAD, recv);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1121
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1122
  int number_of_parameters;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1123
  Method* selected_method;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1124
  {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1125
    Method* m = Method::resolve_jmethod_id(method_id);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1126
    number_of_parameters = m->size_of_parameters();
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1127
    Klass* holder = m->method_holder();
31027
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1128
    if (call_type != JNI_VIRTUAL) {
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1129
        selected_method = m;
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1130
    } else if (!m->has_itable_index()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1131
      // non-interface call -- for that little speed boost, don't handlize
35492
c8c0273e6b91 8146690: Make all classes in GC follow the naming convention.
david
parents: 35219
diff changeset
  1132
      debug_only(NoSafepointVerifier nosafepoint;)
31027
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1133
      // jni_GetMethodID makes sure class is linked and initialized
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1134
      // so m should have a valid vtable index.
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1135
      assert(m->valid_vtable_index(), "no valid vtable index");
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1136
      int vtbl_index = m->vtable_index();
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1137
      if (vtbl_index != Method::nonvirtual_vtable_index) {
35900
d64cf9290fc4 8148481: Devirtualize Klass::vtable
mgerdin
parents: 35519
diff changeset
  1138
        selected_method = h_recv->klass()->method_at_vtable(vtbl_index);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1139
      } else {
31027
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1140
        // final method
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1141
        selected_method = m;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1142
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1143
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1144
      // interface call
31027
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1145
      int itbl_index = m->itable_index();
6df6a1332f23 8072588: JVM crashes in JNI if toString is declared as an interface method
aeriksso
parents: 30764
diff changeset
  1146
      Klass* k = h_recv->klass();
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1147
      selected_method = InstanceKlass::cast(k)->method_at_itable(holder, itbl_index, CHECK);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1148
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1149
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1150
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1151
  methodHandle method(THREAD, selected_method);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1152
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1153
  // Create object to hold arguments for the JavaCall, and associate it with
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1154
  // the jni parser
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1155
  ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1156
  JavaCallArguments java_args(number_of_parameters);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1157
  args->set_java_argument_object(&java_args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1158
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1159
  // handle arguments
41669
2091069b6851 8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents: 40655
diff changeset
  1160
  assert(!method->is_static(), "method %s should not be static", method->name_and_sig_as_C_string());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1161
  args->push_receiver(h_recv); // Push jobject handle
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1162
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1163
  // Fill out JavaCallArguments object
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1164
  args->iterate( Fingerprinter(method).fingerprint() );
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1165
  // Initialize result type
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1166
  result->set_type(args->get_ret_type());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1167
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1168
  // Invoke the method. Result is returned as oop.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1169
  JavaCalls::call(result, method, &java_args, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1170
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1171
  // Convert result
58273
08a5148e7c4e 8230505: Replace JVM type comparisons to T_OBJECT and T_ARRAY with call to is_reference_type
lfoltan
parents: 58177
diff changeset
  1172
  if (is_reference_type(result->get_type())) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1173
    result->set_jobject(JNIHandles::make_local(env, (oop) result->get_jobject()));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1174
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1175
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1176
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1177
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1178
static instanceOop alloc_object(jclass clazz, TRAPS) {
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1179
  Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(clazz));
22532
1fc87ea15795 8031427: AllocObject and Unsafe.allocateInstance segfault for primitive types
gdub
parents: 22520
diff changeset
  1180
  if (k == NULL) {
1fc87ea15795 8031427: AllocObject and Unsafe.allocateInstance segfault for primitive types
gdub
parents: 22520
diff changeset
  1181
    ResourceMark rm(THREAD);
1fc87ea15795 8031427: AllocObject and Unsafe.allocateInstance segfault for primitive types
gdub
parents: 22520
diff changeset
  1182
    THROW_(vmSymbols::java_lang_InstantiationException(), NULL);
1fc87ea15795 8031427: AllocObject and Unsafe.allocateInstance segfault for primitive types
gdub
parents: 22520
diff changeset
  1183
  }
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1184
  k->check_valid_for_instantiation(false, CHECK_NULL);
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1185
  k->initialize(CHECK_NULL);
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1186
  instanceOop ih = InstanceKlass::cast(k)->allocate_instance(THREAD);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1187
  return ih;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1188
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1189
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1190
DT_RETURN_MARK_DECL(AllocObject, jobject
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1191
                    , HOTSPOT_JNI_ALLOCOBJECT_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1192
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1193
JNI_ENTRY(jobject, jni_AllocObject(JNIEnv *env, jclass clazz))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1194
  JNIWrapper("AllocObject");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1195
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1196
  HOTSPOT_JNI_ALLOCOBJECT_ENTRY(env, clazz);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1197
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1198
  jobject ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1199
  DT_RETURN_MARK(AllocObject, jobject, (const jobject&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1200
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1201
  instanceOop i = alloc_object(clazz, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1202
  ret = JNIHandles::make_local(env, i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1203
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1204
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1205
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1206
DT_RETURN_MARK_DECL(NewObjectA, jobject
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1207
                    , HOTSPOT_JNI_NEWOBJECTA_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1208
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1209
JNI_ENTRY(jobject, jni_NewObjectA(JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1210
  JNIWrapper("NewObjectA");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1211
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1212
  HOTSPOT_JNI_NEWOBJECTA_ENTRY(env, clazz, (uintptr_t) methodID);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1213
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1214
  jobject obj = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1215
  DT_RETURN_MARK(NewObjectA, jobject, (const jobject)obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1216
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1217
  instanceOop i = alloc_object(clazz, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1218
  obj = JNIHandles::make_local(env, i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1219
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1220
  JNI_ArgumentPusherArray ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1221
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1222
  return obj;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1223
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1224
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1225
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1226
DT_RETURN_MARK_DECL(NewObjectV, jobject
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1227
                    , HOTSPOT_JNI_NEWOBJECTV_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1228
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1229
JNI_ENTRY(jobject, jni_NewObjectV(JNIEnv *env, jclass clazz, jmethodID methodID, va_list args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1230
  JNIWrapper("NewObjectV");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1231
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1232
  HOTSPOT_JNI_NEWOBJECTV_ENTRY(env, clazz, (uintptr_t) methodID);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1233
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1234
  jobject obj = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1235
  DT_RETURN_MARK(NewObjectV, jobject, (const jobject&)obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1236
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1237
  instanceOop i = alloc_object(clazz, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1238
  obj = JNIHandles::make_local(env, i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1239
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1240
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1241
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1242
  return obj;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1243
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1244
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1245
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1246
DT_RETURN_MARK_DECL(NewObject, jobject
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1247
                    , HOTSPOT_JNI_NEWOBJECT_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1248
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1249
JNI_ENTRY(jobject, jni_NewObject(JNIEnv *env, jclass clazz, jmethodID methodID, ...))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1250
  JNIWrapper("NewObject");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1251
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1252
  HOTSPOT_JNI_NEWOBJECT_ENTRY(env, clazz, (uintptr_t) methodID);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1253
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1254
  jobject obj = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1255
  DT_RETURN_MARK(NewObject, jobject, (const jobject&)obj);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1256
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1257
  instanceOop i = alloc_object(clazz, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1258
  obj = JNIHandles::make_local(env, i);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1259
  va_list args;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1260
  va_start(args, methodID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1261
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1262
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1263
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1264
  va_end(args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1265
  return obj;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1266
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1267
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1268
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1269
JNI_ENTRY(jclass, jni_GetObjectClass(JNIEnv *env, jobject obj))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1270
  JNIWrapper("GetObjectClass");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1271
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1272
  HOTSPOT_JNI_GETOBJECTCLASS_ENTRY(env, obj);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1273
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1274
  Klass* k = JNIHandles::resolve_non_null(obj)->klass();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1275
  jclass ret =
14488
ab48109f7d1b 8001471: Klass::cast() does nothing
hseigel
parents: 14391
diff changeset
  1276
    (jclass) JNIHandles::make_local(env, k->java_mirror());
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1277
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1278
  HOTSPOT_JNI_GETOBJECTCLASS_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1279
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1280
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1281
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  1282
JNI_ENTRY_NO_PRESERVE(jboolean, jni_IsInstanceOf(JNIEnv *env, jobject obj, jclass clazz))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1283
  JNIWrapper("IsInstanceOf");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1284
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1285
  HOTSPOT_JNI_ISINSTANCEOF_ENTRY(env, obj, clazz);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1286
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1287
  jboolean ret = JNI_TRUE;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1288
  if (obj != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1289
    ret = JNI_FALSE;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1290
    Klass* k = java_lang_Class::as_Klass(
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1291
      JNIHandles::resolve_non_null(clazz));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1292
    if (k != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1293
      ret = JNIHandles::resolve_non_null(obj)->is_a(k) ? JNI_TRUE : JNI_FALSE;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1294
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1295
  }
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  1296
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1297
  HOTSPOT_JNI_ISINSTANCEOF_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1298
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1299
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1300
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1302
static jmethodID get_method_id(JNIEnv *env, jclass clazz, const char *name_str,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1303
                               const char *sig, bool is_static, TRAPS) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1304
  // %%%% This code should probably just call into a method in the LinkResolver
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1305
  //
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1306
  // The class should have been loaded (we have an instance of the class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1307
  // passed in) so the method and signature should already be in the symbol
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1308
  // table.  If they're not there, the method doesn't exist.
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1309
  const char *name_to_probe = (name_str == NULL)
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1310
                        ? vmSymbols::object_initializer_name()->as_C_string()
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1311
                        : name_str;
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1312
  TempNewSymbol name = SymbolTable::probe(name_to_probe, (int)strlen(name_to_probe));
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1313
  TempNewSymbol signature = SymbolTable::probe(sig, (int)strlen(sig));
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1314
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1315
  if (name == NULL || signature == NULL) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1316
    THROW_MSG_0(vmSymbols::java_lang_NoSuchMethodError(), name_str);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1317
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1318
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  1319
  Klass* klass = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(clazz));
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  1320
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1321
  // Throw a NoSuchMethodError exception if we have an instance of a
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1322
  // primitive java.lang.Class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1323
  if (java_lang_Class::is_primitive(JNIHandles::resolve_non_null(clazz))) {
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  1324
    ResourceMark rm;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  1325
    THROW_MSG_0(vmSymbols::java_lang_NoSuchMethodError(), err_msg("%s%s.%s%s", is_static ? "static " : "", klass->signature_name(), name_str, sig));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1326
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1327
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1328
  // Make sure class is linked and initialized before handing id's out to
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1329
  // Method*s.
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1330
  klass->initialize(CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1331
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  1332
  Method* m;
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1333
  if (name == vmSymbols::object_initializer_name() ||
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1334
      name == vmSymbols::class_initializer_name()) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1335
    // Never search superclasses for constructors
33611
9abd65805e19 8139203: Consistent naming for klass type predicates
coleenp
parents: 33576
diff changeset
  1336
    if (klass->is_instance_klass()) {
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1337
      m = InstanceKlass::cast(klass)->find_method(name, signature);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1338
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1339
      m = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1340
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1341
  } else {
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1342
    m = klass->lookup_method(name, signature);
33611
9abd65805e19 8139203: Consistent naming for klass type predicates
coleenp
parents: 33576
diff changeset
  1343
    if (m == NULL &&  klass->is_instance_klass()) {
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1344
      m = InstanceKlass::cast(klass)->lookup_method_in_ordered_interfaces(name, signature);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1345
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1346
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1347
  if (m == NULL || (m->is_static() != is_static)) {
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  1348
    ResourceMark rm;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  1349
    THROW_MSG_0(vmSymbols::java_lang_NoSuchMethodError(), err_msg("%s%s.%s%s", is_static ? "static " : "", klass->signature_name(), name_str, sig));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1350
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1351
  return m->jmethod_id();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1352
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1353
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1354
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1355
JNI_ENTRY(jmethodID, jni_GetMethodID(JNIEnv *env, jclass clazz,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1356
          const char *name, const char *sig))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1357
  JNIWrapper("GetMethodID");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1358
  HOTSPOT_JNI_GETMETHODID_ENTRY(env, clazz, (char *) name, (char *) sig);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1359
  jmethodID ret = get_method_id(env, clazz, name, sig, false, thread);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1360
  HOTSPOT_JNI_GETMETHODID_RETURN((uintptr_t) ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1361
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1362
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1363
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1364
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1365
JNI_ENTRY(jmethodID, jni_GetStaticMethodID(JNIEnv *env, jclass clazz,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1366
          const char *name, const char *sig))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1367
  JNIWrapper("GetStaticMethodID");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1368
  HOTSPOT_JNI_GETSTATICMETHODID_ENTRY(env, (char *) clazz, (char *) name, (char *)sig);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1369
  jmethodID ret = get_method_id(env, clazz, name, sig, true, thread);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1370
  HOTSPOT_JNI_GETSTATICMETHODID_RETURN((uintptr_t) ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1371
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1372
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1373
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1374
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1375
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1376
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1377
// Calling Methods
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1378
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1379
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1380
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1381
#define DEFINE_CALLMETHOD(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1382
                          , EntryProbe, ReturnProbe)    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1383
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1384
  DT_RETURN_MARK_DECL_FOR(Result, Call##Result##Method, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1385
                          , ReturnProbe);                          \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1386
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1387
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1388
          jni_Call##Result##Method(JNIEnv *env, jobject obj, jmethodID methodID, ...)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1389
  JNIWrapper("Call" XSTR(Result) "Method"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1390
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1391
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1392
  ResultType ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1393
  DT_RETURN_MARK_FOR(Result, Call##Result##Method, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1394
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1395
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1396
  va_list args; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1397
  va_start(args, methodID); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1398
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1399
  JNI_ArgumentPusherVaArg ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1400
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_VIRTUAL, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1401
  va_end(args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1402
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1403
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1404
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1405
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1406
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1407
DEFINE_CALLMETHOD(jboolean, Boolean, T_BOOLEAN
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1408
                  , HOTSPOT_JNI_CALLBOOLEANMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1409
                  HOTSPOT_JNI_CALLBOOLEANMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1410
DEFINE_CALLMETHOD(jbyte,    Byte,    T_BYTE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1411
                  , HOTSPOT_JNI_CALLBYTEMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1412
                  HOTSPOT_JNI_CALLBYTEMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1413
DEFINE_CALLMETHOD(jchar,    Char,    T_CHAR
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1414
                  , HOTSPOT_JNI_CALLCHARMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1415
                  HOTSPOT_JNI_CALLCHARMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1416
DEFINE_CALLMETHOD(jshort,   Short,   T_SHORT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1417
                  , HOTSPOT_JNI_CALLSHORTMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1418
                  HOTSPOT_JNI_CALLSHORTMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1419
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1420
DEFINE_CALLMETHOD(jobject,  Object,  T_OBJECT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1421
                  , HOTSPOT_JNI_CALLOBJECTMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1422
                  HOTSPOT_JNI_CALLOBJECTMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1423
DEFINE_CALLMETHOD(jint,     Int,     T_INT,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1424
                  HOTSPOT_JNI_CALLINTMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1425
                  HOTSPOT_JNI_CALLINTMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1426
DEFINE_CALLMETHOD(jlong,    Long,    T_LONG
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1427
                  , HOTSPOT_JNI_CALLLONGMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1428
                  HOTSPOT_JNI_CALLLONGMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1429
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1430
DEFINE_CALLMETHOD(jfloat,   Float,   T_FLOAT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1431
                  , HOTSPOT_JNI_CALLFLOATMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1432
                  HOTSPOT_JNI_CALLFLOATMETHOD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1433
DEFINE_CALLMETHOD(jdouble,  Double,  T_DOUBLE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1434
                  , HOTSPOT_JNI_CALLDOUBLEMETHOD_ENTRY(env, obj, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1435
                  HOTSPOT_JNI_CALLDOUBLEMETHOD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1436
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1437
#define DEFINE_CALLMETHODV(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1438
                          , EntryProbe, ReturnProbe)    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1439
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1440
  DT_RETURN_MARK_DECL_FOR(Result, Call##Result##MethodV, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1441
                          , ReturnProbe);                          \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1442
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1443
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1444
          jni_Call##Result##MethodV(JNIEnv *env, jobject obj, jmethodID methodID, va_list args)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1445
  JNIWrapper("Call" XSTR(Result) "MethodV"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1446
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1447
  EntryProbe;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1448
  ResultType ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1449
  DT_RETURN_MARK_FOR(Result, Call##Result##MethodV, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1450
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1451
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1452
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1453
  JNI_ArgumentPusherVaArg ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1454
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_VIRTUAL, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1455
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1456
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1457
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1458
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1459
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1460
DEFINE_CALLMETHODV(jboolean, Boolean, T_BOOLEAN
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1461
                  , HOTSPOT_JNI_CALLBOOLEANMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1462
                  HOTSPOT_JNI_CALLBOOLEANMETHODV_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1463
DEFINE_CALLMETHODV(jbyte,    Byte,    T_BYTE
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1464
                  , HOTSPOT_JNI_CALLBYTEMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1465
                  HOTSPOT_JNI_CALLBYTEMETHODV_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1466
DEFINE_CALLMETHODV(jchar,    Char,    T_CHAR
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1467
                  , HOTSPOT_JNI_CALLCHARMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1468
                  HOTSPOT_JNI_CALLCHARMETHODV_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1469
DEFINE_CALLMETHODV(jshort,   Short,   T_SHORT
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1470
                  , HOTSPOT_JNI_CALLSHORTMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1471
                  HOTSPOT_JNI_CALLSHORTMETHODV_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1472
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1473
DEFINE_CALLMETHODV(jobject,  Object,  T_OBJECT
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1474
                  , HOTSPOT_JNI_CALLOBJECTMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1475
                  HOTSPOT_JNI_CALLOBJECTMETHODV_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1476
DEFINE_CALLMETHODV(jint,     Int,     T_INT,
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1477
                  HOTSPOT_JNI_CALLINTMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1478
                  HOTSPOT_JNI_CALLINTMETHODV_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1479
DEFINE_CALLMETHODV(jlong,    Long,    T_LONG
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1480
                  , HOTSPOT_JNI_CALLLONGMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1481
                  HOTSPOT_JNI_CALLLONGMETHODV_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1482
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1483
DEFINE_CALLMETHODV(jfloat,   Float,   T_FLOAT
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1484
                  , HOTSPOT_JNI_CALLFLOATMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1485
                  HOTSPOT_JNI_CALLFLOATMETHODV_RETURN())
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1486
DEFINE_CALLMETHODV(jdouble,  Double,  T_DOUBLE
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1487
                  , HOTSPOT_JNI_CALLDOUBLEMETHODV_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1488
                  HOTSPOT_JNI_CALLDOUBLEMETHODV_RETURN())
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1489
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1490
#define DEFINE_CALLMETHODA(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1491
                          , EntryProbe, ReturnProbe)    \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1492
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1493
  DT_RETURN_MARK_DECL_FOR(Result, Call##Result##MethodA, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1494
                          , ReturnProbe);                          \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1495
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1496
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1497
          jni_Call##Result##MethodA(JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1498
  JNIWrapper("Call" XSTR(Result) "MethodA"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1499
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1500
  ResultType ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1501
  DT_RETURN_MARK_FOR(Result, Call##Result##MethodA, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1502
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1503
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1504
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1505
  JNI_ArgumentPusherArray ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1506
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_VIRTUAL, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1507
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1508
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1509
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1510
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1511
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1512
DEFINE_CALLMETHODA(jboolean, Boolean, T_BOOLEAN
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1513
                  , HOTSPOT_JNI_CALLBOOLEANMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1514
                  HOTSPOT_JNI_CALLBOOLEANMETHODA_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1515
DEFINE_CALLMETHODA(jbyte,    Byte,    T_BYTE
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1516
                  , HOTSPOT_JNI_CALLBYTEMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1517
                  HOTSPOT_JNI_CALLBYTEMETHODA_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1518
DEFINE_CALLMETHODA(jchar,    Char,    T_CHAR
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1519
                  , HOTSPOT_JNI_CALLCHARMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1520
                  HOTSPOT_JNI_CALLCHARMETHODA_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1521
DEFINE_CALLMETHODA(jshort,   Short,   T_SHORT
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1522
                  , HOTSPOT_JNI_CALLSHORTMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1523
                  HOTSPOT_JNI_CALLSHORTMETHODA_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1524
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1525
DEFINE_CALLMETHODA(jobject,  Object,  T_OBJECT
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1526
                  , HOTSPOT_JNI_CALLOBJECTMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1527
                  HOTSPOT_JNI_CALLOBJECTMETHODA_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1528
DEFINE_CALLMETHODA(jint,     Int,     T_INT,
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1529
                  HOTSPOT_JNI_CALLINTMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1530
                  HOTSPOT_JNI_CALLINTMETHODA_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1531
DEFINE_CALLMETHODA(jlong,    Long,    T_LONG
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1532
                  , HOTSPOT_JNI_CALLLONGMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1533
                  HOTSPOT_JNI_CALLLONGMETHODA_RETURN(_ret_ref))
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1534
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1535
DEFINE_CALLMETHODA(jfloat,   Float,   T_FLOAT
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1536
                  , HOTSPOT_JNI_CALLFLOATMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1537
                  HOTSPOT_JNI_CALLFLOATMETHODA_RETURN())
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1538
DEFINE_CALLMETHODA(jdouble,  Double,  T_DOUBLE
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1539
                  , HOTSPOT_JNI_CALLDOUBLEMETHODA_ENTRY(env, obj, (uintptr_t)methodID),
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  1540
                  HOTSPOT_JNI_CALLDOUBLEMETHODA_RETURN())
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1541
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1542
DT_VOID_RETURN_MARK_DECL(CallVoidMethod, HOTSPOT_JNI_CALLVOIDMETHOD_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1543
DT_VOID_RETURN_MARK_DECL(CallVoidMethodV, HOTSPOT_JNI_CALLVOIDMETHODV_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1544
DT_VOID_RETURN_MARK_DECL(CallVoidMethodA, HOTSPOT_JNI_CALLVOIDMETHODA_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1545
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1546
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1547
JNI_ENTRY(void, jni_CallVoidMethod(JNIEnv *env, jobject obj, jmethodID methodID, ...))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1548
  JNIWrapper("CallVoidMethod");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1549
  HOTSPOT_JNI_CALLVOIDMETHOD_ENTRY(env, obj, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1550
  DT_VOID_RETURN_MARK(CallVoidMethod);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1551
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1552
  va_list args;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1553
  va_start(args, methodID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1554
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1555
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1556
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_VIRTUAL, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1557
  va_end(args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1558
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1559
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1560
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1561
JNI_ENTRY(void, jni_CallVoidMethodV(JNIEnv *env, jobject obj, jmethodID methodID, va_list args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1562
  JNIWrapper("CallVoidMethodV");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1563
  HOTSPOT_JNI_CALLVOIDMETHODV_ENTRY(env, obj, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1564
  DT_VOID_RETURN_MARK(CallVoidMethodV);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1565
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1566
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1567
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1568
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_VIRTUAL, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1569
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1570
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1571
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1572
JNI_ENTRY(void, jni_CallVoidMethodA(JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1573
  JNIWrapper("CallVoidMethodA");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1574
  HOTSPOT_JNI_CALLVOIDMETHODA_ENTRY(env, obj, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1575
  DT_VOID_RETURN_MARK(CallVoidMethodA);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1576
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1577
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1578
  JNI_ArgumentPusherArray ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1579
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_VIRTUAL, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1580
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1581
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1582
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1583
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1584
#define DEFINE_CALLNONVIRTUALMETHOD(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1585
                                    , EntryProbe, ReturnProbe)      \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1586
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1587
  DT_RETURN_MARK_DECL_FOR(Result, CallNonvirtual##Result##Method, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1588
                          , ReturnProbe);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1589
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1590
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1591
          jni_CallNonvirtual##Result##Method(JNIEnv *env, jobject obj, jclass cls, jmethodID methodID, ...)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1592
  JNIWrapper("CallNonvitual" XSTR(Result) "Method"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1593
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1594
  EntryProbe;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1595
  ResultType ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1596
  DT_RETURN_MARK_FOR(Result, CallNonvirtual##Result##Method, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1597
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1598
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1599
  va_list args; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1600
  va_start(args, methodID); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1601
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1602
  JNI_ArgumentPusherVaArg ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1603
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1604
  va_end(args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1605
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1606
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1607
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1608
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1609
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1610
DEFINE_CALLNONVIRTUALMETHOD(jboolean, Boolean, T_BOOLEAN
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1611
                            , HOTSPOT_JNI_CALLNONVIRTUALBOOLEANMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1612
                            HOTSPOT_JNI_CALLNONVIRTUALBOOLEANMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1613
DEFINE_CALLNONVIRTUALMETHOD(jbyte,    Byte,    T_BYTE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1614
                            , HOTSPOT_JNI_CALLNONVIRTUALBYTEMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1615
                            HOTSPOT_JNI_CALLNONVIRTUALBYTEMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1616
DEFINE_CALLNONVIRTUALMETHOD(jchar,    Char,    T_CHAR
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1617
                            , HOTSPOT_JNI_CALLNONVIRTUALCHARMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1618
                            HOTSPOT_JNI_CALLNONVIRTUALCHARMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1619
DEFINE_CALLNONVIRTUALMETHOD(jshort,   Short,   T_SHORT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1620
                            , HOTSPOT_JNI_CALLNONVIRTUALSHORTMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1621
                            HOTSPOT_JNI_CALLNONVIRTUALSHORTMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1622
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1623
DEFINE_CALLNONVIRTUALMETHOD(jobject,  Object,  T_OBJECT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1624
                            , HOTSPOT_JNI_CALLNONVIRTUALOBJECTMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1625
                            HOTSPOT_JNI_CALLNONVIRTUALOBJECTMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1626
DEFINE_CALLNONVIRTUALMETHOD(jint,     Int,     T_INT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1627
                            , HOTSPOT_JNI_CALLNONVIRTUALINTMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1628
                            HOTSPOT_JNI_CALLNONVIRTUALINTMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1629
DEFINE_CALLNONVIRTUALMETHOD(jlong,    Long,    T_LONG
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1630
                            , HOTSPOT_JNI_CALLNONVIRTUALLONGMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1631
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1632
                            HOTSPOT_JNI_CALLNONVIRTUALLONGMETHOD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1633
DEFINE_CALLNONVIRTUALMETHOD(jfloat,   Float,   T_FLOAT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1634
                            , HOTSPOT_JNI_CALLNONVIRTUALFLOATMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1635
                            HOTSPOT_JNI_CALLNONVIRTUALFLOATMETHOD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1636
DEFINE_CALLNONVIRTUALMETHOD(jdouble,  Double,  T_DOUBLE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1637
                            , HOTSPOT_JNI_CALLNONVIRTUALDOUBLEMETHOD_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1638
                            HOTSPOT_JNI_CALLNONVIRTUALDOUBLEMETHOD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1639
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1640
#define DEFINE_CALLNONVIRTUALMETHODV(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1641
                                    , EntryProbe, ReturnProbe)      \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1642
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1643
  DT_RETURN_MARK_DECL_FOR(Result, CallNonvirtual##Result##MethodV, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1644
                          , ReturnProbe);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1645
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1646
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1647
          jni_CallNonvirtual##Result##MethodV(JNIEnv *env, jobject obj, jclass cls, jmethodID methodID, va_list args)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1648
  JNIWrapper("CallNonvitual" XSTR(Result) "MethodV"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1649
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1650
  EntryProbe;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1651
  ResultType ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1652
  DT_RETURN_MARK_FOR(Result, CallNonvirtual##Result##MethodV, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1653
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1654
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1655
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1656
  JNI_ArgumentPusherVaArg ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1657
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1658
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1659
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1660
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1661
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1662
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1663
DEFINE_CALLNONVIRTUALMETHODV(jboolean, Boolean, T_BOOLEAN
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1664
                            , HOTSPOT_JNI_CALLNONVIRTUALBOOLEANMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1665
                            HOTSPOT_JNI_CALLNONVIRTUALBOOLEANMETHODV_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1666
DEFINE_CALLNONVIRTUALMETHODV(jbyte,    Byte,    T_BYTE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1667
                            , HOTSPOT_JNI_CALLNONVIRTUALBYTEMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1668
                            HOTSPOT_JNI_CALLNONVIRTUALBYTEMETHODV_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1669
DEFINE_CALLNONVIRTUALMETHODV(jchar,    Char,    T_CHAR
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1670
                            , HOTSPOT_JNI_CALLNONVIRTUALCHARMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1671
                            HOTSPOT_JNI_CALLNONVIRTUALCHARMETHODV_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1672
DEFINE_CALLNONVIRTUALMETHODV(jshort,   Short,   T_SHORT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1673
                            , HOTSPOT_JNI_CALLNONVIRTUALSHORTMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1674
                            HOTSPOT_JNI_CALLNONVIRTUALSHORTMETHODV_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1675
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1676
DEFINE_CALLNONVIRTUALMETHODV(jobject,  Object,  T_OBJECT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1677
                            , HOTSPOT_JNI_CALLNONVIRTUALOBJECTMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1678
                            HOTSPOT_JNI_CALLNONVIRTUALOBJECTMETHODV_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1679
DEFINE_CALLNONVIRTUALMETHODV(jint,     Int,     T_INT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1680
                            , HOTSPOT_JNI_CALLNONVIRTUALINTMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1681
                            HOTSPOT_JNI_CALLNONVIRTUALINTMETHODV_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1682
DEFINE_CALLNONVIRTUALMETHODV(jlong,    Long,    T_LONG
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1683
                            , HOTSPOT_JNI_CALLNONVIRTUALLONGMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1684
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1685
                            HOTSPOT_JNI_CALLNONVIRTUALLONGMETHODV_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1686
DEFINE_CALLNONVIRTUALMETHODV(jfloat,   Float,   T_FLOAT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1687
                            , HOTSPOT_JNI_CALLNONVIRTUALFLOATMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1688
                            HOTSPOT_JNI_CALLNONVIRTUALFLOATMETHODV_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1689
DEFINE_CALLNONVIRTUALMETHODV(jdouble,  Double,  T_DOUBLE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1690
                            , HOTSPOT_JNI_CALLNONVIRTUALDOUBLEMETHODV_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1691
                            HOTSPOT_JNI_CALLNONVIRTUALDOUBLEMETHODV_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1692
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1693
#define DEFINE_CALLNONVIRTUALMETHODA(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1694
                                    , EntryProbe, ReturnProbe)      \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1695
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1696
  DT_RETURN_MARK_DECL_FOR(Result, CallNonvirtual##Result##MethodA, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1697
                          , ReturnProbe);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1698
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1699
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1700
          jni_CallNonvirtual##Result##MethodA(JNIEnv *env, jobject obj, jclass cls, jmethodID methodID, const jvalue *args)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1701
  JNIWrapper("CallNonvitual" XSTR(Result) "MethodA"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1702
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1703
  EntryProbe;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1704
  ResultType ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1705
  DT_RETURN_MARK_FOR(Result, CallNonvirtual##Result##MethodA, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1706
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1707
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1708
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1709
  JNI_ArgumentPusherArray ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1710
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1711
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1712
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1713
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1714
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1715
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1716
DEFINE_CALLNONVIRTUALMETHODA(jboolean, Boolean, T_BOOLEAN
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1717
                            , HOTSPOT_JNI_CALLNONVIRTUALBOOLEANMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1718
                            HOTSPOT_JNI_CALLNONVIRTUALBOOLEANMETHODA_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1719
DEFINE_CALLNONVIRTUALMETHODA(jbyte,    Byte,    T_BYTE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1720
                            , HOTSPOT_JNI_CALLNONVIRTUALBYTEMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1721
                            HOTSPOT_JNI_CALLNONVIRTUALBYTEMETHODA_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1722
DEFINE_CALLNONVIRTUALMETHODA(jchar,    Char,    T_CHAR
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1723
                            , HOTSPOT_JNI_CALLNONVIRTUALCHARMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1724
                            HOTSPOT_JNI_CALLNONVIRTUALCHARMETHODA_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1725
DEFINE_CALLNONVIRTUALMETHODA(jshort,   Short,   T_SHORT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1726
                            , HOTSPOT_JNI_CALLNONVIRTUALSHORTMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1727
                            HOTSPOT_JNI_CALLNONVIRTUALSHORTMETHODA_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1728
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1729
DEFINE_CALLNONVIRTUALMETHODA(jobject,  Object,  T_OBJECT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1730
                            , HOTSPOT_JNI_CALLNONVIRTUALOBJECTMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1731
                            HOTSPOT_JNI_CALLNONVIRTUALOBJECTMETHODA_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1732
DEFINE_CALLNONVIRTUALMETHODA(jint,     Int,     T_INT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1733
                            , HOTSPOT_JNI_CALLNONVIRTUALINTMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1734
                            HOTSPOT_JNI_CALLNONVIRTUALINTMETHODA_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1735
DEFINE_CALLNONVIRTUALMETHODA(jlong,    Long,    T_LONG
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1736
                            , HOTSPOT_JNI_CALLNONVIRTUALLONGMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1737
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1738
                            HOTSPOT_JNI_CALLNONVIRTUALLONGMETHODA_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1739
DEFINE_CALLNONVIRTUALMETHODA(jfloat,   Float,   T_FLOAT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1740
                            , HOTSPOT_JNI_CALLNONVIRTUALFLOATMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1741
                            HOTSPOT_JNI_CALLNONVIRTUALFLOATMETHODA_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1742
DEFINE_CALLNONVIRTUALMETHODA(jdouble,  Double,  T_DOUBLE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1743
                            , HOTSPOT_JNI_CALLNONVIRTUALDOUBLEMETHODA_ENTRY(env, obj, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1744
                            HOTSPOT_JNI_CALLNONVIRTUALDOUBLEMETHODA_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1745
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1746
DT_VOID_RETURN_MARK_DECL(CallNonvirtualVoidMethod
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1747
                         , HOTSPOT_JNI_CALLNONVIRTUALVOIDMETHOD_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1748
DT_VOID_RETURN_MARK_DECL(CallNonvirtualVoidMethodV
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1749
                         , HOTSPOT_JNI_CALLNONVIRTUALVOIDMETHODV_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1750
DT_VOID_RETURN_MARK_DECL(CallNonvirtualVoidMethodA
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1751
                         , HOTSPOT_JNI_CALLNONVIRTUALVOIDMETHODA_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1752
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1753
JNI_ENTRY(void, jni_CallNonvirtualVoidMethod(JNIEnv *env, jobject obj, jclass cls, jmethodID methodID, ...))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1754
  JNIWrapper("CallNonvirtualVoidMethod");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1755
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1756
  HOTSPOT_JNI_CALLNONVIRTUALVOIDMETHOD_ENTRY(env, obj, cls, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1757
  DT_VOID_RETURN_MARK(CallNonvirtualVoidMethod);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1758
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1759
  va_list args;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1760
  va_start(args, methodID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1761
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1762
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1763
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1764
  va_end(args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1765
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1766
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1767
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1768
JNI_ENTRY(void, jni_CallNonvirtualVoidMethodV(JNIEnv *env, jobject obj, jclass cls, jmethodID methodID, va_list args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1769
  JNIWrapper("CallNonvirtualVoidMethodV");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1770
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1771
  HOTSPOT_JNI_CALLNONVIRTUALVOIDMETHODV_ENTRY(
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1772
               env, obj, cls, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1773
  DT_VOID_RETURN_MARK(CallNonvirtualVoidMethodV);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1774
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1775
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1776
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1777
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1778
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1779
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1780
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1781
JNI_ENTRY(void, jni_CallNonvirtualVoidMethodA(JNIEnv *env, jobject obj, jclass cls, jmethodID methodID, const jvalue *args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1782
  JNIWrapper("CallNonvirtualVoidMethodA");
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1783
  HOTSPOT_JNI_CALLNONVIRTUALVOIDMETHODA_ENTRY(
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1784
                env, obj, cls, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1785
  DT_VOID_RETURN_MARK(CallNonvirtualVoidMethodA);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1786
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1787
  JNI_ArgumentPusherArray ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1788
  jni_invoke_nonstatic(env, &jvalue, obj, JNI_NONVIRTUAL, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1789
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1790
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1791
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1792
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1793
#define DEFINE_CALLSTATICMETHOD(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1794
                                , EntryProbe, ResultProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1795
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1796
  DT_RETURN_MARK_DECL_FOR(Result, CallStatic##Result##Method, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1797
                          , ResultProbe);                               \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1798
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1799
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1800
          jni_CallStatic##Result##Method(JNIEnv *env, jclass cls, jmethodID methodID, ...)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1801
  JNIWrapper("CallStatic" XSTR(Result) "Method"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1802
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1803
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1804
  ResultType ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1805
  DT_RETURN_MARK_FOR(Result, CallStatic##Result##Method, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1806
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1807
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1808
  va_list args; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1809
  va_start(args, methodID); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1810
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1811
  JNI_ArgumentPusherVaArg ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1812
  jni_invoke_static(env, &jvalue, NULL, JNI_STATIC, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1813
  va_end(args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1814
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1815
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1816
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1817
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1818
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1819
DEFINE_CALLSTATICMETHOD(jboolean, Boolean, T_BOOLEAN
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1820
                        , HOTSPOT_JNI_CALLSTATICBOOLEANMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1821
                        HOTSPOT_JNI_CALLSTATICBOOLEANMETHOD_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1822
DEFINE_CALLSTATICMETHOD(jbyte,    Byte,    T_BYTE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1823
                        , HOTSPOT_JNI_CALLSTATICBYTEMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1824
                        HOTSPOT_JNI_CALLSTATICBYTEMETHOD_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1825
DEFINE_CALLSTATICMETHOD(jchar,    Char,    T_CHAR
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1826
                        , HOTSPOT_JNI_CALLSTATICCHARMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1827
                        HOTSPOT_JNI_CALLSTATICCHARMETHOD_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1828
DEFINE_CALLSTATICMETHOD(jshort,   Short,   T_SHORT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1829
                        , HOTSPOT_JNI_CALLSTATICSHORTMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1830
                        HOTSPOT_JNI_CALLSTATICSHORTMETHOD_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1831
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1832
DEFINE_CALLSTATICMETHOD(jobject,  Object,  T_OBJECT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1833
                        , HOTSPOT_JNI_CALLSTATICOBJECTMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1834
                        HOTSPOT_JNI_CALLSTATICOBJECTMETHOD_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1835
DEFINE_CALLSTATICMETHOD(jint,     Int,     T_INT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1836
                        , HOTSPOT_JNI_CALLSTATICINTMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1837
                        HOTSPOT_JNI_CALLSTATICINTMETHOD_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1838
DEFINE_CALLSTATICMETHOD(jlong,    Long,    T_LONG
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1839
                        , HOTSPOT_JNI_CALLSTATICLONGMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1840
                        HOTSPOT_JNI_CALLSTATICLONGMETHOD_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1841
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1842
DEFINE_CALLSTATICMETHOD(jfloat,   Float,   T_FLOAT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1843
                        , HOTSPOT_JNI_CALLSTATICFLOATMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1844
                        HOTSPOT_JNI_CALLSTATICFLOATMETHOD_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1845
DEFINE_CALLSTATICMETHOD(jdouble,  Double,  T_DOUBLE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1846
                        , HOTSPOT_JNI_CALLSTATICDOUBLEMETHOD_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1847
                        HOTSPOT_JNI_CALLSTATICDOUBLEMETHOD_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1848
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1849
#define DEFINE_CALLSTATICMETHODV(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1850
                                , EntryProbe, ResultProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1851
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1852
  DT_RETURN_MARK_DECL_FOR(Result, CallStatic##Result##MethodV, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1853
                          , ResultProbe);                               \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1854
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1855
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1856
          jni_CallStatic##Result##MethodV(JNIEnv *env, jclass cls, jmethodID methodID, va_list args)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1857
  JNIWrapper("CallStatic" XSTR(Result) "MethodV"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1858
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1859
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1860
  ResultType ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1861
  DT_RETURN_MARK_FOR(Result, CallStatic##Result##MethodV, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1862
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1863
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1864
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1865
  JNI_ArgumentPusherVaArg ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1866
  /* Make sure class is initialized before trying to invoke its method */ \
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1867
  Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(cls)); \
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  1868
  k->initialize(CHECK_0); \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1869
  jni_invoke_static(env, &jvalue, NULL, JNI_STATIC, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1870
  va_end(args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1871
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1872
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1873
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1874
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1875
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1876
DEFINE_CALLSTATICMETHODV(jboolean, Boolean, T_BOOLEAN
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1877
                        , HOTSPOT_JNI_CALLSTATICBOOLEANMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1878
                        HOTSPOT_JNI_CALLSTATICBOOLEANMETHODV_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1879
DEFINE_CALLSTATICMETHODV(jbyte,    Byte,    T_BYTE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1880
                        , HOTSPOT_JNI_CALLSTATICBYTEMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1881
                        HOTSPOT_JNI_CALLSTATICBYTEMETHODV_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1882
DEFINE_CALLSTATICMETHODV(jchar,    Char,    T_CHAR
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1883
                        , HOTSPOT_JNI_CALLSTATICCHARMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1884
                        HOTSPOT_JNI_CALLSTATICCHARMETHODV_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1885
DEFINE_CALLSTATICMETHODV(jshort,   Short,   T_SHORT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1886
                        , HOTSPOT_JNI_CALLSTATICSHORTMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1887
                        HOTSPOT_JNI_CALLSTATICSHORTMETHODV_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1888
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1889
DEFINE_CALLSTATICMETHODV(jobject,  Object,  T_OBJECT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1890
                        , HOTSPOT_JNI_CALLSTATICOBJECTMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1891
                        HOTSPOT_JNI_CALLSTATICOBJECTMETHODV_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1892
DEFINE_CALLSTATICMETHODV(jint,     Int,     T_INT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1893
                        , HOTSPOT_JNI_CALLSTATICINTMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1894
                        HOTSPOT_JNI_CALLSTATICINTMETHODV_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1895
DEFINE_CALLSTATICMETHODV(jlong,    Long,    T_LONG
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1896
                        , HOTSPOT_JNI_CALLSTATICLONGMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1897
                        HOTSPOT_JNI_CALLSTATICLONGMETHODV_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1898
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1899
DEFINE_CALLSTATICMETHODV(jfloat,   Float,   T_FLOAT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1900
                        , HOTSPOT_JNI_CALLSTATICFLOATMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1901
                        HOTSPOT_JNI_CALLSTATICFLOATMETHODV_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1902
DEFINE_CALLSTATICMETHODV(jdouble,  Double,  T_DOUBLE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1903
                        , HOTSPOT_JNI_CALLSTATICDOUBLEMETHODV_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1904
                        HOTSPOT_JNI_CALLSTATICDOUBLEMETHODV_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1905
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1906
#define DEFINE_CALLSTATICMETHODA(ResultType, Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1907
                                , EntryProbe, ResultProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1908
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1909
  DT_RETURN_MARK_DECL_FOR(Result, CallStatic##Result##MethodA, ResultType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1910
                          , ResultProbe);                               \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1911
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1912
JNI_ENTRY(ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1913
          jni_CallStatic##Result##MethodA(JNIEnv *env, jclass cls, jmethodID methodID, const jvalue *args)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1914
  JNIWrapper("CallStatic" XSTR(Result) "MethodA"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1915
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1916
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1917
  ResultType ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1918
  DT_RETURN_MARK_FOR(Result, CallStatic##Result##MethodA, ResultType, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1919
                     (const ResultType&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1920
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1921
  JavaValue jvalue(Tag); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1922
  JNI_ArgumentPusherArray ap(methodID, args); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1923
  jni_invoke_static(env, &jvalue, NULL, JNI_STATIC, methodID, &ap, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1924
  ret = jvalue.get_##ResultType(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1925
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1926
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1927
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1928
// the runtime type of subword integral basic types is integer
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1929
DEFINE_CALLSTATICMETHODA(jboolean, Boolean, T_BOOLEAN
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1930
                        , HOTSPOT_JNI_CALLSTATICBOOLEANMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1931
                        HOTSPOT_JNI_CALLSTATICBOOLEANMETHODA_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1932
DEFINE_CALLSTATICMETHODA(jbyte,    Byte,    T_BYTE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1933
                        , HOTSPOT_JNI_CALLSTATICBYTEMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1934
                        HOTSPOT_JNI_CALLSTATICBYTEMETHODA_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1935
DEFINE_CALLSTATICMETHODA(jchar,    Char,    T_CHAR
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1936
                        , HOTSPOT_JNI_CALLSTATICCHARMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1937
                        HOTSPOT_JNI_CALLSTATICCHARMETHODA_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1938
DEFINE_CALLSTATICMETHODA(jshort,   Short,   T_SHORT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1939
                        , HOTSPOT_JNI_CALLSTATICSHORTMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1940
                        HOTSPOT_JNI_CALLSTATICSHORTMETHODA_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1941
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1942
DEFINE_CALLSTATICMETHODA(jobject,  Object,  T_OBJECT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1943
                        , HOTSPOT_JNI_CALLSTATICOBJECTMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1944
                        HOTSPOT_JNI_CALLSTATICOBJECTMETHODA_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1945
DEFINE_CALLSTATICMETHODA(jint,     Int,     T_INT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1946
                        , HOTSPOT_JNI_CALLSTATICINTMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1947
                        HOTSPOT_JNI_CALLSTATICINTMETHODA_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1948
DEFINE_CALLSTATICMETHODA(jlong,    Long,    T_LONG
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1949
                        , HOTSPOT_JNI_CALLSTATICLONGMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1950
                        HOTSPOT_JNI_CALLSTATICLONGMETHODA_RETURN(_ret_ref));
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1951
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1952
DEFINE_CALLSTATICMETHODA(jfloat,   Float,   T_FLOAT
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1953
                        , HOTSPOT_JNI_CALLSTATICFLOATMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1954
                        HOTSPOT_JNI_CALLSTATICFLOATMETHODA_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1955
DEFINE_CALLSTATICMETHODA(jdouble,  Double,  T_DOUBLE
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1956
                        , HOTSPOT_JNI_CALLSTATICDOUBLEMETHODA_ENTRY(env, cls, (uintptr_t)methodID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1957
                        HOTSPOT_JNI_CALLSTATICDOUBLEMETHODA_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1958
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1959
DT_VOID_RETURN_MARK_DECL(CallStaticVoidMethod
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1960
                         , HOTSPOT_JNI_CALLSTATICVOIDMETHOD_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1961
DT_VOID_RETURN_MARK_DECL(CallStaticVoidMethodV
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1962
                         , HOTSPOT_JNI_CALLSTATICVOIDMETHODV_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1963
DT_VOID_RETURN_MARK_DECL(CallStaticVoidMethodA
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1964
                         , HOTSPOT_JNI_CALLSTATICVOIDMETHODA_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  1965
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1966
JNI_ENTRY(void, jni_CallStaticVoidMethod(JNIEnv *env, jclass cls, jmethodID methodID, ...))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1967
  JNIWrapper("CallStaticVoidMethod");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1968
  HOTSPOT_JNI_CALLSTATICVOIDMETHOD_ENTRY(env, cls, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1969
  DT_VOID_RETURN_MARK(CallStaticVoidMethod);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1970
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1971
  va_list args;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1972
  va_start(args, methodID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1973
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1974
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1975
  jni_invoke_static(env, &jvalue, NULL, JNI_STATIC, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1976
  va_end(args);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1977
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1978
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1979
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1980
JNI_ENTRY(void, jni_CallStaticVoidMethodV(JNIEnv *env, jclass cls, jmethodID methodID, va_list args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1981
  JNIWrapper("CallStaticVoidMethodV");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1982
  HOTSPOT_JNI_CALLSTATICVOIDMETHODV_ENTRY(env, cls, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1983
  DT_VOID_RETURN_MARK(CallStaticVoidMethodV);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1984
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1985
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1986
  JNI_ArgumentPusherVaArg ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1987
  jni_invoke_static(env, &jvalue, NULL, JNI_STATIC, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1988
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1989
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1990
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1991
JNI_ENTRY(void, jni_CallStaticVoidMethodA(JNIEnv *env, jclass cls, jmethodID methodID, const jvalue *args))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1992
  JNIWrapper("CallStaticVoidMethodA");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  1993
  HOTSPOT_JNI_CALLSTATICVOIDMETHODA_ENTRY(env, cls, (uintptr_t) methodID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1994
  DT_VOID_RETURN_MARK(CallStaticVoidMethodA);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1995
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1996
  JavaValue jvalue(T_VOID);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  1997
  JNI_ArgumentPusherArray ap(methodID, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1998
  jni_invoke_static(env, &jvalue, NULL, JNI_STATIC, methodID, &ap, CHECK);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  1999
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2000
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2001
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2002
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2003
// Accessing Fields
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2004
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2005
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2006
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2007
DT_RETURN_MARK_DECL(GetFieldID, jfieldID
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2008
                    , HOTSPOT_JNI_GETFIELDID_RETURN((uintptr_t)_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2009
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2010
JNI_ENTRY(jfieldID, jni_GetFieldID(JNIEnv *env, jclass clazz,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2011
          const char *name, const char *sig))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2012
  JNIWrapper("GetFieldID");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2013
  HOTSPOT_JNI_GETFIELDID_ENTRY(env, clazz, (char *) name, (char *) sig);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2014
  jfieldID ret = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2015
  DT_RETURN_MARK(GetFieldID, jfieldID, (const jfieldID&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2016
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  2017
  Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(clazz));
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  2018
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2019
  // The class should have been loaded (we have an instance of the class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2020
  // passed in) so the field and signature should already be in the symbol
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2021
  // table.  If they're not there, the field doesn't exist.
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2022
  TempNewSymbol fieldname = SymbolTable::probe(name, (int)strlen(name));
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2023
  TempNewSymbol signame = SymbolTable::probe(sig, (int)strlen(sig));
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2024
  if (fieldname == NULL || signame == NULL) {
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  2025
    ResourceMark rm;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  2026
    THROW_MSG_0(vmSymbols::java_lang_NoSuchFieldError(), err_msg("%s.%s %s", k->external_name(), name, sig));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2027
  }
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  2028
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2029
  // Make sure class is initialized before handing id's out to fields
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2030
  k->initialize(CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2031
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2032
  fieldDescriptor fd;
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2033
  if (!k->is_instance_klass() ||
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2034
      !InstanceKlass::cast(k)->find_field(fieldname, signame, false, &fd)) {
54669
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  2035
    ResourceMark rm;
ad45b3802d4e 8220623: [JVMCI] Update JVMCI to support JVMCI based Compiler compiled into shared library
kvn
parents: 54495
diff changeset
  2036
    THROW_MSG_0(vmSymbols::java_lang_NoSuchFieldError(), err_msg("%s.%s %s", k->external_name(), name, sig));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2037
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2038
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2039
  // A jfieldID for a non-static field is simply the offset of the field within the instanceOop
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2040
  // It may also have hash bits for k, if VerifyJNIFields is turned on.
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2041
  ret = jfieldIDWorkaround::to_instance_jfieldID(k, fd.offset());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2042
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2043
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2044
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2045
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2046
JNI_ENTRY(jobject, jni_GetObjectField(JNIEnv *env, jobject obj, jfieldID fieldID))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2047
  JNIWrapper("GetObjectField");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2048
  HOTSPOT_JNI_GETOBJECTFIELD_ENTRY(env, obj, (uintptr_t) fieldID);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2049
  oop o = JNIHandles::resolve_non_null(obj);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2050
  Klass* k = o->klass();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2051
  int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2052
  // Keep JVMTI addition small and only check enabled flag here.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2053
  // jni_GetField_probe() assumes that is okay to create handles.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2054
  if (JvmtiExport::should_post_field_access()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2055
    o = JvmtiExport::jni_GetField_probe(thread, obj, o, k, fieldID, false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2056
  }
47998
fb0275c320a0 8189871: Refactor GC barriers to use declarative semantics
eosterlund
parents: 47796
diff changeset
  2057
  oop loaded_obj = HeapAccess<ON_UNKNOWN_OOP_REF>::oop_load_at(o, offset);
fb0275c320a0 8189871: Refactor GC barriers to use declarative semantics
eosterlund
parents: 47796
diff changeset
  2058
  jobject ret = JNIHandles::make_local(env, loaded_obj);
fb0275c320a0 8189871: Refactor GC barriers to use declarative semantics
eosterlund
parents: 47796
diff changeset
  2059
  HOTSPOT_JNI_GETOBJECTFIELD_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2060
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2061
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2062
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2063
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2064
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2065
#define DEFINE_GETFIELD(Return,Fieldname,Result \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2066
  , EntryProbe, ReturnProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2067
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2068
  DT_RETURN_MARK_DECL_FOR(Result, Get##Result##Field, Return \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2069
  , ReturnProbe); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2070
\
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2071
JNI_ENTRY_NO_PRESERVE(Return, jni_Get##Result##Field(JNIEnv *env, jobject obj, jfieldID fieldID)) \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2072
  JNIWrapper("Get" XSTR(Result) "Field"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2073
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2074
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2075
  Return ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2076
  DT_RETURN_MARK_FOR(Result, Get##Result##Field, Return, (const Return&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2077
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2078
  oop o = JNIHandles::resolve_non_null(obj); \
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2079
  Klass* k = o->klass(); \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2080
  int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID);  \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2081
  /* Keep JVMTI addition small and only check enabled flag here.       */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2082
  /* jni_GetField_probe_nh() assumes that is not okay to create handles */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2083
  /* and creates a ResetNoHandleMark.                                   */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2084
  if (JvmtiExport::should_post_field_access()) { \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2085
    o = JvmtiExport::jni_GetField_probe_nh(thread, obj, o, k, fieldID, false); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2086
  } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2087
  ret = o->Fieldname##_field(offset); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2088
  return ret; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2089
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2090
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2091
DEFINE_GETFIELD(jboolean, bool,   Boolean
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2092
                , HOTSPOT_JNI_GETBOOLEANFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2093
                HOTSPOT_JNI_GETBOOLEANFIELD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2094
DEFINE_GETFIELD(jbyte,    byte,   Byte
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2095
                , HOTSPOT_JNI_GETBYTEFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2096
                HOTSPOT_JNI_GETBYTEFIELD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2097
DEFINE_GETFIELD(jchar,    char,   Char
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2098
                , HOTSPOT_JNI_GETCHARFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2099
                HOTSPOT_JNI_GETCHARFIELD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2100
DEFINE_GETFIELD(jshort,   short,  Short
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2101
                , HOTSPOT_JNI_GETSHORTFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2102
                HOTSPOT_JNI_GETSHORTFIELD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2103
DEFINE_GETFIELD(jint,     int,    Int
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2104
                , HOTSPOT_JNI_GETINTFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2105
                HOTSPOT_JNI_GETINTFIELD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2106
DEFINE_GETFIELD(jlong,    long,   Long
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2107
                , HOTSPOT_JNI_GETLONGFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2108
                HOTSPOT_JNI_GETLONGFIELD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2109
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2110
DEFINE_GETFIELD(jfloat,   float,  Float
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2111
                , HOTSPOT_JNI_GETFLOATFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2112
                HOTSPOT_JNI_GETFLOATFIELD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2113
DEFINE_GETFIELD(jdouble,  double, Double
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2114
                , HOTSPOT_JNI_GETDOUBLEFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2115
                HOTSPOT_JNI_GETDOUBLEFIELD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2116
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2117
address jni_GetBooleanField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2118
  return (address)jni_GetBooleanField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2119
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2120
address jni_GetByteField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2121
  return (address)jni_GetByteField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2122
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2123
address jni_GetCharField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2124
  return (address)jni_GetCharField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2125
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2126
address jni_GetShortField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2127
  return (address)jni_GetShortField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2128
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2129
address jni_GetIntField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2130
  return (address)jni_GetIntField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2131
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2132
address jni_GetLongField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2133
  return (address)jni_GetLongField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2134
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2135
address jni_GetFloatField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2136
  return (address)jni_GetFloatField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2137
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2138
address jni_GetDoubleField_addr() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2139
  return (address)jni_GetDoubleField;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2140
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2141
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2142
JNI_ENTRY_NO_PRESERVE(void, jni_SetObjectField(JNIEnv *env, jobject obj, jfieldID fieldID, jobject value))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2143
  JNIWrapper("SetObjectField");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2144
  HOTSPOT_JNI_SETOBJECTFIELD_ENTRY(env, obj, (uintptr_t) fieldID, value);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2145
  oop o = JNIHandles::resolve_non_null(obj);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2146
  Klass* k = o->klass();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2147
  int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2148
  // Keep JVMTI addition small and only check enabled flag here.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2149
  // jni_SetField_probe_nh() assumes that is not okay to create handles
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2150
  // and creates a ResetNoHandleMark.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2151
  if (JvmtiExport::should_post_field_modification()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2152
    jvalue field_value;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2153
    field_value.l = value;
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2154
    o = JvmtiExport::jni_SetField_probe_nh(thread, obj, o, k, fieldID, false, JVM_SIGNATURE_CLASS, (jvalue *)&field_value);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2155
  }
47998
fb0275c320a0 8189871: Refactor GC barriers to use declarative semantics
eosterlund
parents: 47796
diff changeset
  2156
  HeapAccess<ON_UNKNOWN_OOP_REF>::oop_store_at(o, offset, JNIHandles::resolve(value));
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2157
  HOTSPOT_JNI_SETOBJECTFIELD_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2158
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2159
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2160
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2161
#define DEFINE_SETFIELD(Argument,Fieldname,Result,SigType,unionType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2162
                        , EntryProbe, ReturnProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2163
\
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2164
JNI_ENTRY_NO_PRESERVE(void, jni_Set##Result##Field(JNIEnv *env, jobject obj, jfieldID fieldID, Argument value)) \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2165
  JNIWrapper("Set" XSTR(Result) "Field"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2166
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2167
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2168
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2169
  oop o = JNIHandles::resolve_non_null(obj); \
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2170
  Klass* k = o->klass(); \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2171
  int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID);  \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2172
  /* Keep JVMTI addition small and only check enabled flag here.       */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2173
  /* jni_SetField_probe_nh() assumes that is not okay to create handles */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2174
  /* and creates a ResetNoHandleMark.                                   */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2175
  if (JvmtiExport::should_post_field_modification()) { \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2176
    jvalue field_value; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2177
    field_value.unionType = value; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2178
    o = JvmtiExport::jni_SetField_probe_nh(thread, obj, o, k, fieldID, false, SigType, (jvalue *)&field_value); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2179
  } \
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2180
  if (SigType == JVM_SIGNATURE_BOOLEAN) { value = ((jboolean)value) & 1; } \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2181
  o->Fieldname##_field_put(offset, value); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2182
  ReturnProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2183
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2184
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2185
DEFINE_SETFIELD(jboolean, bool,   Boolean, JVM_SIGNATURE_BOOLEAN, z
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2186
                , HOTSPOT_JNI_SETBOOLEANFIELD_ENTRY(env, obj, (uintptr_t)fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2187
                HOTSPOT_JNI_SETBOOLEANFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2188
DEFINE_SETFIELD(jbyte,    byte,   Byte,    JVM_SIGNATURE_BYTE, b
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2189
                , HOTSPOT_JNI_SETBYTEFIELD_ENTRY(env, obj, (uintptr_t)fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2190
                HOTSPOT_JNI_SETBYTEFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2191
DEFINE_SETFIELD(jchar,    char,   Char,    JVM_SIGNATURE_CHAR, c
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2192
                , HOTSPOT_JNI_SETCHARFIELD_ENTRY(env, obj, (uintptr_t)fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2193
                HOTSPOT_JNI_SETCHARFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2194
DEFINE_SETFIELD(jshort,   short,  Short,   JVM_SIGNATURE_SHORT, s
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2195
                , HOTSPOT_JNI_SETSHORTFIELD_ENTRY(env, obj, (uintptr_t)fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2196
                HOTSPOT_JNI_SETSHORTFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2197
DEFINE_SETFIELD(jint,     int,    Int,     JVM_SIGNATURE_INT, i
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2198
                , HOTSPOT_JNI_SETINTFIELD_ENTRY(env, obj, (uintptr_t)fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2199
                HOTSPOT_JNI_SETINTFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2200
DEFINE_SETFIELD(jlong,    long,   Long,    JVM_SIGNATURE_LONG, j
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2201
                , HOTSPOT_JNI_SETLONGFIELD_ENTRY(env, obj, (uintptr_t)fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2202
                HOTSPOT_JNI_SETLONGFIELD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2203
// Float and double probes don't return value because dtrace doesn't currently support it
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2204
DEFINE_SETFIELD(jfloat,   float,  Float,   JVM_SIGNATURE_FLOAT, f
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2205
                , HOTSPOT_JNI_SETFLOATFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2206
                HOTSPOT_JNI_SETFLOATFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2207
DEFINE_SETFIELD(jdouble,  double, Double,  JVM_SIGNATURE_DOUBLE, d
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2208
                , HOTSPOT_JNI_SETDOUBLEFIELD_ENTRY(env, obj, (uintptr_t)fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2209
                HOTSPOT_JNI_SETDOUBLEFIELD_RETURN())
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  2210
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2211
DT_RETURN_MARK_DECL(ToReflectedField, jobject
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2212
                    , HOTSPOT_JNI_TOREFLECTEDFIELD_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2213
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2214
JNI_ENTRY(jobject, jni_ToReflectedField(JNIEnv *env, jclass cls, jfieldID fieldID, jboolean isStatic))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2215
  JNIWrapper("ToReflectedField");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2216
  HOTSPOT_JNI_TOREFLECTEDFIELD_ENTRY(env, cls, (uintptr_t) fieldID, isStatic);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2217
  jobject ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2218
  DT_RETURN_MARK(ToReflectedField, jobject, (const jobject&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2219
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2220
  fieldDescriptor fd;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2221
  bool found = false;
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2222
  Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(cls));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2223
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2224
  assert(jfieldIDWorkaround::is_static_jfieldID(fieldID) == (isStatic != 0), "invalid fieldID");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2225
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2226
  if (isStatic) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2227
    // Static field. The fieldID a JNIid specifying the field holder and the offset within the Klass*.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2228
    JNIid* id = jfieldIDWorkaround::from_static_jfieldID(fieldID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2229
    assert(id->is_static_field_id(), "invalid static field id");
8725
8c1e3dd5fe1b 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 8076
diff changeset
  2230
    found = id->find_local_field(&fd);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2231
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2232
    // Non-static field. The fieldID is really the offset of the field within the instanceOop.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2233
    int offset = jfieldIDWorkaround::from_instance_jfieldID(k, fieldID);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2234
    found = InstanceKlass::cast(k)->find_field_from_offset(offset, false, &fd);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2235
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2236
  assert(found, "bad fieldID passed into jni_ToReflectedField");
24456
8c7933fa5a1f 8025580: Temporary flags: UseNewReflection and ReflectionWrapResolutionErrors
coleenp
parents: 24424
diff changeset
  2237
  oop reflected = Reflection::new_field(&fd, CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2238
  ret = JNIHandles::make_local(env, reflected);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2239
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2240
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2241
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2242
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2243
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2244
// Accessing Static Fields
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2245
//
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2246
DT_RETURN_MARK_DECL(GetStaticFieldID, jfieldID
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2247
                    , HOTSPOT_JNI_GETSTATICFIELDID_RETURN((uintptr_t)_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2248
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2249
JNI_ENTRY(jfieldID, jni_GetStaticFieldID(JNIEnv *env, jclass clazz,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2250
          const char *name, const char *sig))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2251
  JNIWrapper("GetStaticFieldID");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2252
  HOTSPOT_JNI_GETSTATICFIELDID_ENTRY(env, clazz, (char *) name, (char *) sig);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2253
  jfieldID ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2254
  DT_RETURN_MARK(GetStaticFieldID, jfieldID, (const jfieldID&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2255
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2256
  // The class should have been loaded (we have an instance of the class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2257
  // passed in) so the field and signature should already be in the symbol
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2258
  // table.  If they're not there, the field doesn't exist.
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2259
  TempNewSymbol fieldname = SymbolTable::probe(name, (int)strlen(name));
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2260
  TempNewSymbol signame = SymbolTable::probe(sig, (int)strlen(sig));
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2261
  if (fieldname == NULL || signame == NULL) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2262
    THROW_MSG_0(vmSymbols::java_lang_NoSuchFieldError(), (char*) name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2263
  }
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2264
  Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(clazz));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2265
  // Make sure class is initialized before handing id's out to static fields
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2266
  k->initialize(CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2267
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2268
  fieldDescriptor fd;
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2269
  if (!k->is_instance_klass() ||
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2270
      !InstanceKlass::cast(k)->find_field(fieldname, signame, true, &fd)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2271
    THROW_MSG_0(vmSymbols::java_lang_NoSuchFieldError(), (char*) name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2272
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2273
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2274
  // A jfieldID for a static field is a JNIid specifying the field holder and the offset within the Klass*
14391
df0a1573d5bd 8000725: NPG: method_holder() and pool_holder() and pool_holder field should be InstanceKlass
coleenp
parents: 13977
diff changeset
  2275
  JNIid* id = fd.field_holder()->jni_id_for(fd.offset());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2276
  debug_only(id->set_is_static_field_id();)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2277
8725
8c1e3dd5fe1b 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 8076
diff changeset
  2278
  debug_only(id->verify(fd.field_holder()));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2279
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2280
  ret = jfieldIDWorkaround::to_static_jfieldID(id);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2281
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2282
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2283
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2284
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2285
JNI_ENTRY(jobject, jni_GetStaticObjectField(JNIEnv *env, jclass clazz, jfieldID fieldID))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2286
  JNIWrapper("GetStaticObjectField");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2287
  HOTSPOT_JNI_GETSTATICOBJECTFIELD_ENTRY(env, clazz, (uintptr_t) fieldID);
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
  2288
#if INCLUDE_JNI_CHECK
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2289
  DEBUG_ONLY(Klass* param_k = jniCheck::validate_class(thread, clazz);)
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
  2290
#endif // INCLUDE_JNI_CHECK
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2291
  JNIid* id = jfieldIDWorkaround::from_static_jfieldID(fieldID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2292
  assert(id->is_static_field_id(), "invalid static field id");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2293
  // Keep JVMTI addition small and only check enabled flag here.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2294
  // jni_GetField_probe() assumes that is okay to create handles.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2295
  if (JvmtiExport::should_post_field_access()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2296
    JvmtiExport::jni_GetField_probe(thread, NULL, NULL, id->holder(), fieldID, true);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2297
  }
8725
8c1e3dd5fe1b 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 8076
diff changeset
  2298
  jobject ret = JNIHandles::make_local(id->holder()->java_mirror()->obj_field(id->offset()));
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2299
  HOTSPOT_JNI_GETSTATICOBJECTFIELD_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2300
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2301
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2302
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2303
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2304
#define DEFINE_GETSTATICFIELD(Return,Fieldname,Result \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2305
                              , EntryProbe, ReturnProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2306
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2307
  DT_RETURN_MARK_DECL_FOR(Result, GetStatic##Result##Field, Return \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2308
                          , ReturnProbe);                                          \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2309
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2310
JNI_ENTRY(Return, jni_GetStatic##Result##Field(JNIEnv *env, jclass clazz, jfieldID fieldID)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2311
  JNIWrapper("GetStatic" XSTR(Result) "Field"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2312
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2313
  Return ret = 0;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2314
  DT_RETURN_MARK_FOR(Result, GetStatic##Result##Field, Return, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2315
                     (const Return&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2316
  JNIid* id = jfieldIDWorkaround::from_static_jfieldID(fieldID); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2317
  assert(id->is_static_field_id(), "invalid static field id"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2318
  /* Keep JVMTI addition small and only check enabled flag here. */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2319
  /* jni_GetField_probe() assumes that is okay to create handles. */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2320
  if (JvmtiExport::should_post_field_access()) { \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2321
    JvmtiExport::jni_GetField_probe(thread, NULL, NULL, id->holder(), fieldID, true); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2322
  } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2323
  ret = id->holder()->java_mirror()-> Fieldname##_field (id->offset()); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2324
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2325
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2326
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2327
DEFINE_GETSTATICFIELD(jboolean, bool,   Boolean
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2328
                      , HOTSPOT_JNI_GETSTATICBOOLEANFIELD_ENTRY(env, clazz, (uintptr_t) fieldID), HOTSPOT_JNI_GETSTATICBOOLEANFIELD_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2329
DEFINE_GETSTATICFIELD(jbyte,    byte,   Byte
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2330
                      , HOTSPOT_JNI_GETSTATICBYTEFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),    HOTSPOT_JNI_GETSTATICBYTEFIELD_RETURN(_ret_ref)   )
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2331
DEFINE_GETSTATICFIELD(jchar,    char,   Char
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2332
                      , HOTSPOT_JNI_GETSTATICCHARFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),    HOTSPOT_JNI_GETSTATICCHARFIELD_RETURN(_ret_ref)   )
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2333
DEFINE_GETSTATICFIELD(jshort,   short,  Short
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2334
                      , HOTSPOT_JNI_GETSTATICSHORTFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),   HOTSPOT_JNI_GETSTATICSHORTFIELD_RETURN(_ret_ref)  )
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2335
DEFINE_GETSTATICFIELD(jint,     int,    Int
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2336
                      , HOTSPOT_JNI_GETSTATICINTFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),     HOTSPOT_JNI_GETSTATICINTFIELD_RETURN(_ret_ref)    )
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2337
DEFINE_GETSTATICFIELD(jlong,    long,   Long
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2338
                      , HOTSPOT_JNI_GETSTATICLONGFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),    HOTSPOT_JNI_GETSTATICLONGFIELD_RETURN(_ret_ref)   )
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2339
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2340
DEFINE_GETSTATICFIELD(jfloat,   float,  Float
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2341
                      , HOTSPOT_JNI_GETSTATICFLOATFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),   HOTSPOT_JNI_GETSTATICFLOATFIELD_RETURN()          )
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2342
DEFINE_GETSTATICFIELD(jdouble,  double, Double
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2343
                      , HOTSPOT_JNI_GETSTATICDOUBLEFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),  HOTSPOT_JNI_GETSTATICDOUBLEFIELD_RETURN()         )
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2344
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2345
JNI_ENTRY(void, jni_SetStaticObjectField(JNIEnv *env, jclass clazz, jfieldID fieldID, jobject value))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2346
  JNIWrapper("SetStaticObjectField");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2347
 HOTSPOT_JNI_SETSTATICOBJECTFIELD_ENTRY(env, clazz, (uintptr_t) fieldID, value);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2348
  JNIid* id = jfieldIDWorkaround::from_static_jfieldID(fieldID);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2349
  assert(id->is_static_field_id(), "invalid static field id");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2350
  // Keep JVMTI addition small and only check enabled flag here.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2351
  // jni_SetField_probe() assumes that is okay to create handles.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2352
  if (JvmtiExport::should_post_field_modification()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2353
    jvalue field_value;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2354
    field_value.l = value;
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2355
    JvmtiExport::jni_SetField_probe(thread, NULL, NULL, id->holder(), fieldID, true, JVM_SIGNATURE_CLASS, (jvalue *)&field_value);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2356
  }
8725
8c1e3dd5fe1b 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 8076
diff changeset
  2357
  id->holder()->java_mirror()->obj_field_put(id->offset(), JNIHandles::resolve(value));
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2358
  HOTSPOT_JNI_SETSTATICOBJECTFIELD_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2359
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2360
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2361
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2362
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2363
#define DEFINE_SETSTATICFIELD(Argument,Fieldname,Result,SigType,unionType \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2364
                              , EntryProbe, ReturnProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2365
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2366
JNI_ENTRY(void, jni_SetStatic##Result##Field(JNIEnv *env, jclass clazz, jfieldID fieldID, Argument value)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2367
  JNIWrapper("SetStatic" XSTR(Result) "Field"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2368
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2369
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2370
  JNIid* id = jfieldIDWorkaround::from_static_jfieldID(fieldID); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2371
  assert(id->is_static_field_id(), "invalid static field id"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2372
  /* Keep JVMTI addition small and only check enabled flag here. */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2373
  /* jni_SetField_probe() assumes that is okay to create handles. */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2374
  if (JvmtiExport::should_post_field_modification()) { \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2375
    jvalue field_value; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2376
    field_value.unionType = value; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2377
    JvmtiExport::jni_SetField_probe(thread, NULL, NULL, id->holder(), fieldID, true, SigType, (jvalue *)&field_value); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2378
  } \
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2379
  if (SigType == JVM_SIGNATURE_BOOLEAN) { value = ((jboolean)value) & 1; } \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2380
  id->holder()->java_mirror()-> Fieldname##_field_put (id->offset(), value); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2381
  ReturnProbe;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2382
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2383
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2384
DEFINE_SETSTATICFIELD(jboolean, bool,   Boolean, JVM_SIGNATURE_BOOLEAN, z
22190
d306a75a70d3 8029726: On OS X some dtrace probe names are mismatched with Solaris
sla
parents: 21112
diff changeset
  2385
                      , HOTSPOT_JNI_SETSTATICBOOLEANFIELD_ENTRY(env, clazz, (uintptr_t)fieldID, value),
23997
73485c7e8122 8039947: Dtrace return probe name for jni_SetStaticBooleanField named incorrectly
dsimms
parents: 23859
diff changeset
  2386
                      HOTSPOT_JNI_SETSTATICBOOLEANFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2387
DEFINE_SETSTATICFIELD(jbyte,    byte,   Byte,    JVM_SIGNATURE_BYTE, b
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2388
                      , HOTSPOT_JNI_SETSTATICBYTEFIELD_ENTRY(env, clazz, (uintptr_t) fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2389
                      HOTSPOT_JNI_SETSTATICBYTEFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2390
DEFINE_SETSTATICFIELD(jchar,    char,   Char,    JVM_SIGNATURE_CHAR, c
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2391
                      , HOTSPOT_JNI_SETSTATICCHARFIELD_ENTRY(env, clazz, (uintptr_t) fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2392
                      HOTSPOT_JNI_SETSTATICCHARFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2393
DEFINE_SETSTATICFIELD(jshort,   short,  Short,   JVM_SIGNATURE_SHORT, s
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2394
                      , HOTSPOT_JNI_SETSTATICSHORTFIELD_ENTRY(env, clazz, (uintptr_t) fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2395
                      HOTSPOT_JNI_SETSTATICSHORTFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2396
DEFINE_SETSTATICFIELD(jint,     int,    Int,     JVM_SIGNATURE_INT, i
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2397
                      , HOTSPOT_JNI_SETSTATICINTFIELD_ENTRY(env, clazz, (uintptr_t) fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2398
                      HOTSPOT_JNI_SETSTATICINTFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2399
DEFINE_SETSTATICFIELD(jlong,    long,   Long,    JVM_SIGNATURE_LONG, j
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2400
                      , HOTSPOT_JNI_SETSTATICLONGFIELD_ENTRY(env, clazz, (uintptr_t) fieldID, value),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2401
                      HOTSPOT_JNI_SETSTATICLONGFIELD_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2402
// Float and double probes don't return value because dtrace doesn't currently support it
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2403
DEFINE_SETSTATICFIELD(jfloat,   float,  Float,   JVM_SIGNATURE_FLOAT, f
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2404
                      , HOTSPOT_JNI_SETSTATICFLOATFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2405
                      HOTSPOT_JNI_SETSTATICFLOATFIELD_RETURN())
58722
cba8afa5cfed 8231844: Enhance type signature characters in classfile_constants.h and improve the JVM to use type signature characters more consistently
lfoltan
parents: 58545
diff changeset
  2406
DEFINE_SETSTATICFIELD(jdouble,  double, Double,  JVM_SIGNATURE_DOUBLE, d
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2407
                      , HOTSPOT_JNI_SETSTATICDOUBLEFIELD_ENTRY(env, clazz, (uintptr_t) fieldID),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2408
                      HOTSPOT_JNI_SETSTATICDOUBLEFIELD_RETURN())
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2409
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2410
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2411
// String Operations
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2412
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2413
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2414
// Unicode Interface
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2415
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2416
DT_RETURN_MARK_DECL(NewString, jstring
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2417
                    , HOTSPOT_JNI_NEWSTRING_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2418
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2419
JNI_ENTRY(jstring, jni_NewString(JNIEnv *env, const jchar *unicodeChars, jsize len))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2420
  JNIWrapper("NewString");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2421
 HOTSPOT_JNI_NEWSTRING_ENTRY(env, (uint16_t *) unicodeChars, len);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2422
  jstring ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2423
  DT_RETURN_MARK(NewString, jstring, (const jstring&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2424
  oop string=java_lang_String::create_oop_from_unicode((jchar*) unicodeChars, len, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2425
  ret = (jstring) JNIHandles::make_local(env, string);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2426
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2427
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2428
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2429
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2430
JNI_ENTRY_NO_PRESERVE(jsize, jni_GetStringLength(JNIEnv *env, jstring string))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2431
  JNIWrapper("GetStringLength");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2432
  HOTSPOT_JNI_GETSTRINGLENGTH_ENTRY(env, string);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2433
  jsize ret = 0;
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2434
  oop s = JNIHandles::resolve_non_null(string);
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  2435
  ret = java_lang_String::length(s);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2436
 HOTSPOT_JNI_GETSTRINGLENGTH_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2437
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2438
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2439
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2440
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2441
JNI_ENTRY_NO_PRESERVE(const jchar*, jni_GetStringChars(
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2442
  JNIEnv *env, jstring string, jboolean *isCopy))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2443
  JNIWrapper("GetStringChars");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2444
 HOTSPOT_JNI_GETSTRINGCHARS_ENTRY(env, string, (uintptr_t *) isCopy);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2445
  jchar* buf = NULL;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2446
  oop s = JNIHandles::resolve_non_null(string);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2447
  typeArrayOop s_value = java_lang_String::value(s);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2448
  if (s_value != NULL) {
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  2449
    int s_len = java_lang_String::length(s, s_value);
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  2450
    bool is_latin1 = java_lang_String::is_latin1(s);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2451
    buf = NEW_C_HEAP_ARRAY_RETURN_NULL(jchar, s_len + 1, mtInternal);  // add one for zero termination
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2452
    /* JNI Specification states return NULL on OOM */
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2453
    if (buf != NULL) {
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2454
      if (s_len > 0) {
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  2455
        if (!is_latin1) {
50389
7e8c0409a747 8198285: More consistent Access API for arraycopy
rkennke
parents: 50113
diff changeset
  2456
          ArrayAccess<>::arraycopy_to_native(s_value, (size_t) typeArrayOopDesc::element_offset<jchar>(0),
7e8c0409a747 8198285: More consistent Access API for arraycopy
rkennke
parents: 50113
diff changeset
  2457
                                             buf, s_len);
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  2458
        } else {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  2459
          for (int i = 0; i < s_len; i++) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  2460
            buf[i] = ((jchar) s_value->byte_at(i)) & 0xff;
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  2461
          }
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  2462
        }
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2463
      }
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2464
      buf[s_len] = 0;
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2465
      //%note jni_5
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2466
      if (isCopy != NULL) {
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2467
        *isCopy = JNI_TRUE;
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2468
      }
19545
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2469
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2470
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2471
  HOTSPOT_JNI_GETSTRINGCHARS_RETURN(buf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2472
  return buf;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2473
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2474
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2475
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2476
JNI_ENTRY_NO_PRESERVE(void, jni_ReleaseStringChars(JNIEnv *env, jstring str, const jchar *chars))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2477
  JNIWrapper("ReleaseStringChars");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2478
  HOTSPOT_JNI_RELEASESTRINGCHARS_ENTRY(env, str, (uint16_t *) chars);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2479
  //%note jni_6
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2480
  if (chars != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2481
    // Since String objects are supposed to be immutable, don't copy any
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2482
    // new data back.  A bad user will have to go after the char array.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2483
    FreeHeap((void*) chars);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2484
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2485
  HOTSPOT_JNI_RELEASESTRINGCHARS_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2486
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2487
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2488
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2489
// UTF Interface
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2490
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2491
DT_RETURN_MARK_DECL(NewStringUTF, jstring
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2492
                    , HOTSPOT_JNI_NEWSTRINGUTF_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2493
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2494
JNI_ENTRY(jstring, jni_NewStringUTF(JNIEnv *env, const char *bytes))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2495
  JNIWrapper("NewStringUTF");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2496
  HOTSPOT_JNI_NEWSTRINGUTF_ENTRY(env, (char *) bytes);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2497
  jstring ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2498
  DT_RETURN_MARK(NewStringUTF, jstring, (const jstring&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2499
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2500
  oop result = java_lang_String::create_oop_from_str((char*) bytes, CHECK_NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2501
  ret = (jstring) JNIHandles::make_local(env, result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2502
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2503
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2504
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2505
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2506
JNI_ENTRY(jsize, jni_GetStringUTFLength(JNIEnv *env, jstring string))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2507
  JNIWrapper("GetStringUTFLength");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2508
 HOTSPOT_JNI_GETSTRINGUTFLENGTH_ENTRY(env, string);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2509
  oop java_string = JNIHandles::resolve_non_null(string);
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  2510
  jsize ret = java_lang_String::utf8_length(java_string);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2511
  HOTSPOT_JNI_GETSTRINGUTFLENGTH_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2512
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2513
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2514
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2515
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2516
JNI_ENTRY(const char*, jni_GetStringUTFChars(JNIEnv *env, jstring string, jboolean *isCopy))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2517
  JNIWrapper("GetStringUTFChars");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2518
 HOTSPOT_JNI_GETSTRINGUTFCHARS_ENTRY(env, string, (uintptr_t *) isCopy);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2519
  char* result = NULL;
7414
940d84ca7fca 6539281: -Xcheck:jni should validate char* argument to ReleaseStringUTFChars
sla
parents: 7405
diff changeset
  2520
  oop java_string = JNIHandles::resolve_non_null(string);
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  2521
  typeArrayOop s_value = java_lang_String::value(java_string);
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  2522
  if (s_value != NULL) {
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  2523
    size_t length = java_lang_String::utf8_length(java_string, s_value);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2524
    /* JNI Specification states return NULL on OOM */
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2525
    result = AllocateHeap(length + 1, mtInternal, 0, AllocFailStrategy::RETURN_NULL);
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2526
    if (result != NULL) {
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  2527
      java_lang_String::as_utf8_string(java_string, s_value, result, (int) length + 1);
20387
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2528
      if (isCopy != NULL) {
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2529
        *isCopy = JNI_TRUE;
df9f9f220120 8025922: JNI access to Strings need to check if the value field is non-null
sla
parents: 20084
diff changeset
  2530
      }
19545
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2531
    }
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2532
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2533
 HOTSPOT_JNI_GETSTRINGUTFCHARS_RETURN(result);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2534
  return result;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2535
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2536
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2537
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2538
JNI_LEAF(void, jni_ReleaseStringUTFChars(JNIEnv *env, jstring str, const char *chars))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2539
  JNIWrapper("ReleaseStringUTFChars");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2540
 HOTSPOT_JNI_RELEASESTRINGUTFCHARS_ENTRY(env, str, (char *) chars);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2541
  if (chars != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2542
    FreeHeap((char*) chars);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2543
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2544
HOTSPOT_JNI_RELEASESTRINGUTFCHARS_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2545
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2546
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2547
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2548
JNI_ENTRY_NO_PRESERVE(jsize, jni_GetArrayLength(JNIEnv *env, jarray array))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2549
  JNIWrapper("GetArrayLength");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2550
 HOTSPOT_JNI_GETARRAYLENGTH_ENTRY(env, array);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2551
  arrayOop a = arrayOop(JNIHandles::resolve_non_null(array));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2552
  assert(a->is_array(), "must be array");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2553
  jsize ret = a->length();
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2554
 HOTSPOT_JNI_GETARRAYLENGTH_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2555
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2556
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2557
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2558
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2559
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2560
// Object Array Operations
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2561
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2562
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2563
DT_RETURN_MARK_DECL(NewObjectArray, jobjectArray
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2564
                    , HOTSPOT_JNI_NEWOBJECTARRAY_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2565
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2566
JNI_ENTRY(jobjectArray, jni_NewObjectArray(JNIEnv *env, jsize length, jclass elementClass, jobject initialElement))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2567
  JNIWrapper("NewObjectArray");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2568
 HOTSPOT_JNI_NEWOBJECTARRAY_ENTRY(env, length, elementClass, initialElement);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2569
  jobjectArray ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2570
  DT_RETURN_MARK(NewObjectArray, jobjectArray, (const jobjectArray&)ret);
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2571
  Klass* ek = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(elementClass));
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2572
  Klass* ak = ek->array_klass(CHECK_NULL);
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2573
  ObjArrayKlass::cast(ak)->initialize(CHECK_NULL);
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2574
  objArrayOop result = ObjArrayKlass::cast(ak)->allocate(length, CHECK_NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2575
  oop initial_value = JNIHandles::resolve(initialElement);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2576
  if (initial_value != NULL) {  // array already initialized with NULL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2577
    for (int index = 0; index < length; index++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2578
      result->obj_at_put(index, initial_value);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2579
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2580
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2581
  ret = (jobjectArray) JNIHandles::make_local(env, result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2582
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2583
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2584
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2585
DT_RETURN_MARK_DECL(GetObjectArrayElement, jobject
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2586
                    , HOTSPOT_JNI_GETOBJECTARRAYELEMENT_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2587
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2588
JNI_ENTRY(jobject, jni_GetObjectArrayElement(JNIEnv *env, jobjectArray array, jsize index))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2589
  JNIWrapper("GetObjectArrayElement");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2590
 HOTSPOT_JNI_GETOBJECTARRAYELEMENT_ENTRY(env, array, index);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2591
  jobject ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2592
  DT_RETURN_MARK(GetObjectArrayElement, jobject, (const jobject&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2593
  objArrayOop a = objArrayOop(JNIHandles::resolve_non_null(array));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2594
  if (a->is_within_bounds(index)) {
4089
14bd2cd13a2c 6893483: DTrace probe return values for a couple JNI methods are wrong
kamg
parents: 3820
diff changeset
  2595
    ret = JNIHandles::make_local(env, a->obj_at(index));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2596
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2597
  } else {
53533
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2598
    ResourceMark rm(THREAD);
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2599
    stringStream ss;
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2600
    ss.print("Index %d out of bounds for length %d", index, a->length());
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2601
    THROW_MSG_0(vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), ss.as_string());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2602
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2603
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2604
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2605
DT_VOID_RETURN_MARK_DECL(SetObjectArrayElement
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2606
                         , HOTSPOT_JNI_SETOBJECTARRAYELEMENT_RETURN());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2607
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2608
JNI_ENTRY(void, jni_SetObjectArrayElement(JNIEnv *env, jobjectArray array, jsize index, jobject value))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2609
  JNIWrapper("SetObjectArrayElement");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  2610
 HOTSPOT_JNI_SETOBJECTARRAYELEMENT_ENTRY(env, array, index, value);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2611
  DT_VOID_RETURN_MARK(SetObjectArrayElement);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2612
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2613
  objArrayOop a = objArrayOop(JNIHandles::resolve_non_null(array));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2614
  oop v = JNIHandles::resolve(value);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2615
  if (a->is_within_bounds(index)) {
13952
e3cf184080bc 8000213: NPG: Should have renamed arrayKlass and typeArrayKlass
coleenp
parents: 13728
diff changeset
  2616
    if (v == NULL || v->is_a(ObjArrayKlass::cast(a->klass())->element_klass())) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2617
      a->obj_at_put(index, v);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2618
    } else {
50601
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2619
      ResourceMark rm(THREAD);
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2620
      stringStream ss;
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2621
      Klass *bottom_kl = ObjArrayKlass::cast(a->klass())->bottom_klass();
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2622
      ss.print("type mismatch: can not store %s to %s[%d]",
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2623
               v->klass()->external_name(),
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2624
               bottom_kl->is_typeArray_klass() ? type2name_tab[ArrayKlass::cast(bottom_kl)->element_type()] : bottom_kl->external_name(),
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2625
               index);
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2626
      for (int dims = ArrayKlass::cast(a->klass())->dimension(); dims > 1; --dims) {
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2627
        ss.print("[]");
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2628
      }
3fbae7b9ddb5 8204943: Improve message of ArrayStoreException.
goetz
parents: 50429
diff changeset
  2629
      THROW_MSG(vmSymbols::java_lang_ArrayStoreException(), ss.as_string());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2630
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2631
  } else {
53533
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2632
    ResourceMark rm(THREAD);
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2633
    stringStream ss;
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2634
    ss.print("Index %d out of bounds for length %d", index, a->length());
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2635
    THROW_MSG(vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), ss.as_string());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2636
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2637
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2638
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2639
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2640
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2641
#define DEFINE_NEWSCALARARRAY(Return,Allocator,Result \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2642
                              ,EntryProbe,ReturnProbe)  \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2643
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2644
  DT_RETURN_MARK_DECL(New##Result##Array, Return \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2645
                      , ReturnProbe); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2646
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2647
JNI_ENTRY(Return, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2648
          jni_New##Result##Array(JNIEnv *env, jsize len)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2649
  JNIWrapper("New" XSTR(Result) "Array"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2650
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2651
  Return ret = NULL;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2652
  DT_RETURN_MARK(New##Result##Array, Return, (const Return&)ret);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2653
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2654
  oop obj= oopFactory::Allocator(len, CHECK_0); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2655
  ret = (Return) JNIHandles::make_local(env, obj); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2656
  return ret;\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2657
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2658
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2659
DEFINE_NEWSCALARARRAY(jbooleanArray, new_boolArray,   Boolean,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2660
                      HOTSPOT_JNI_NEWBOOLEANARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2661
                      HOTSPOT_JNI_NEWBOOLEANARRAY_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2662
DEFINE_NEWSCALARARRAY(jbyteArray,    new_byteArray,   Byte,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2663
                      HOTSPOT_JNI_NEWBYTEARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2664
                      HOTSPOT_JNI_NEWBYTEARRAY_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2665
DEFINE_NEWSCALARARRAY(jshortArray,   new_shortArray,  Short,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2666
                      HOTSPOT_JNI_NEWSHORTARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2667
                      HOTSPOT_JNI_NEWSHORTARRAY_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2668
DEFINE_NEWSCALARARRAY(jcharArray,    new_charArray,   Char,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2669
                      HOTSPOT_JNI_NEWCHARARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2670
                      HOTSPOT_JNI_NEWCHARARRAY_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2671
DEFINE_NEWSCALARARRAY(jintArray,     new_intArray,    Int,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2672
                      HOTSPOT_JNI_NEWINTARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2673
                      HOTSPOT_JNI_NEWINTARRAY_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2674
DEFINE_NEWSCALARARRAY(jlongArray,    new_longArray,   Long,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2675
                      HOTSPOT_JNI_NEWLONGARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2676
                      HOTSPOT_JNI_NEWLONGARRAY_RETURN(_ret_ref))
51554
5b0d86499960 8209958: Clean up duplicate basic array type statics in Universe
coleenp
parents: 51467
diff changeset
  2677
DEFINE_NEWSCALARARRAY(jfloatArray,   new_floatArray,  Float,
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2678
                      HOTSPOT_JNI_NEWFLOATARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2679
                      HOTSPOT_JNI_NEWFLOATARRAY_RETURN(_ret_ref))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2680
DEFINE_NEWSCALARARRAY(jdoubleArray,  new_doubleArray, Double,
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2681
                      HOTSPOT_JNI_NEWDOUBLEARRAY_ENTRY(env, len),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2682
                      HOTSPOT_JNI_NEWDOUBLEARRAY_RETURN(_ret_ref))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2683
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2684
// Return an address which will fault if the caller writes to it.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2685
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2686
static char* get_bad_address() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2687
  static char* bad_address = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2688
  if (bad_address == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2689
    size_t size = os::vm_allocation_granularity();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2690
    bad_address = os::reserve_memory(size);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2691
    if (bad_address != NULL) {
1664
fc9ed50498fb 6727377: VM stack guard pages on Windows should PAGE_READWRITE not PAGE_EXECUTE_READWRITE
coleenp
parents: 823
diff changeset
  2692
      os::protect_memory(bad_address, size, os::MEM_PROT_READ,
fc9ed50498fb 6727377: VM stack guard pages on Windows should PAGE_READWRITE not PAGE_EXECUTE_READWRITE
coleenp
parents: 823
diff changeset
  2693
                         /*is_committed*/false);
25946
1572c9f03fb9 8046598: Scalable Native memory tracking development
zgu
parents: 25633
diff changeset
  2694
      MemTracker::record_virtual_memory_type((void*)bad_address, mtInternal);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2695
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2696
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2697
  return bad_address;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2698
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2699
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2700
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2701
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2702
#define DEFINE_GETSCALARARRAYELEMENTS(ElementTag,ElementType,Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2703
                                      , EntryProbe, ReturnProbe) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2704
\
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2705
JNI_ENTRY_NO_PRESERVE(ElementType*, \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2706
          jni_Get##Result##ArrayElements(JNIEnv *env, ElementType##Array array, jboolean *isCopy)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2707
  JNIWrapper("Get" XSTR(Result) "ArrayElements"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2708
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2709
  /* allocate an chunk of memory in c land */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2710
  typeArrayOop a = typeArrayOop(JNIHandles::resolve_non_null(array)); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2711
  ElementType* result; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2712
  int len = a->length(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2713
  if (len == 0) { \
53197
c92f4465fff1 8215495: Set isCopy to JNI_FALSE if len == 0
jcbeyler
parents: 53193
diff changeset
  2714
    if (isCopy != NULL) { \
c92f4465fff1 8215495: Set isCopy to JNI_FALSE if len == 0
jcbeyler
parents: 53193
diff changeset
  2715
      *isCopy = JNI_FALSE; \
c92f4465fff1 8215495: Set isCopy to JNI_FALSE if len == 0
jcbeyler
parents: 53193
diff changeset
  2716
    } \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2717
    /* Empty array: legal but useless, can't return NULL. \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2718
     * Return a pointer to something useless. \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2719
     * Avoid asserts in typeArrayOop. */ \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2720
    result = (ElementType*)get_bad_address(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2721
  } else { \
19545
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2722
    /* JNI Specification states return NULL on OOM */                    \
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2723
    result = NEW_C_HEAP_ARRAY_RETURN_NULL(ElementType, len, mtInternal); \
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2724
    if (result != NULL) {                                                \
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2725
      /* copy the array to the c chunk */                                \
50389
7e8c0409a747 8198285: More consistent Access API for arraycopy
rkennke
parents: 50113
diff changeset
  2726
      ArrayAccess<>::arraycopy_to_native(a, typeArrayOopDesc::element_offset<ElementType>(0), \
7e8c0409a747 8198285: More consistent Access API for arraycopy
rkennke
parents: 50113
diff changeset
  2727
                                         result, len);                   \
19545
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2728
      if (isCopy) {                                                      \
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2729
        *isCopy = JNI_TRUE;                                              \
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2730
      }                                                                  \
409c50cf1e5d 8022683: JNI GetStringUTFChars should return NULL on allocation failure not abort the VM
dsimms
parents: 18683
diff changeset
  2731
    }                                                                    \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2732
  } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2733
  ReturnProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2734
  return result; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2735
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2736
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2737
DEFINE_GETSCALARARRAYELEMENTS(T_BOOLEAN, jboolean, Boolean, bool
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2738
                              , HOTSPOT_JNI_GETBOOLEANARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2739
                              HOTSPOT_JNI_GETBOOLEANARRAYELEMENTS_RETURN((uintptr_t*)result))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2740
DEFINE_GETSCALARARRAYELEMENTS(T_BYTE,    jbyte,    Byte,    byte
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2741
                              , HOTSPOT_JNI_GETBYTEARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2742
                              HOTSPOT_JNI_GETBYTEARRAYELEMENTS_RETURN((char*)result))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2743
DEFINE_GETSCALARARRAYELEMENTS(T_SHORT,   jshort,   Short,   short
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2744
                              , HOTSPOT_JNI_GETSHORTARRAYELEMENTS_ENTRY(env, (uint16_t*) array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2745
                              HOTSPOT_JNI_GETSHORTARRAYELEMENTS_RETURN((uint16_t*)result))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2746
DEFINE_GETSCALARARRAYELEMENTS(T_CHAR,    jchar,    Char,    char
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2747
                              , HOTSPOT_JNI_GETCHARARRAYELEMENTS_ENTRY(env, (uint16_t*) array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2748
                              HOTSPOT_JNI_GETCHARARRAYELEMENTS_RETURN(result))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2749
DEFINE_GETSCALARARRAYELEMENTS(T_INT,     jint,     Int,     int
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2750
                              , HOTSPOT_JNI_GETINTARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2751
                              HOTSPOT_JNI_GETINTARRAYELEMENTS_RETURN((uint32_t*)result))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2752
DEFINE_GETSCALARARRAYELEMENTS(T_LONG,    jlong,    Long,    long
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2753
                              , HOTSPOT_JNI_GETLONGARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2754
                              HOTSPOT_JNI_GETLONGARRAYELEMENTS_RETURN(((uintptr_t*)result)))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2755
// Float and double probes don't return value because dtrace doesn't currently support it
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2756
DEFINE_GETSCALARARRAYELEMENTS(T_FLOAT,   jfloat,   Float,   float
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2757
                              , HOTSPOT_JNI_GETFLOATARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2758
                              HOTSPOT_JNI_GETFLOATARRAYELEMENTS_RETURN(result))
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2759
DEFINE_GETSCALARARRAYELEMENTS(T_DOUBLE,  jdouble,  Double,  double
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2760
                              , HOTSPOT_JNI_GETDOUBLEARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) isCopy),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2761
                              HOTSPOT_JNI_GETDOUBLEARRAYELEMENTS_RETURN(result))
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  2762
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2763
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2764
#define DEFINE_RELEASESCALARARRAYELEMENTS(ElementTag,ElementType,Result,Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2765
                                          , EntryProbe, ReturnProbe);\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2766
\
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  2767
JNI_ENTRY_NO_PRESERVE(void, \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2768
          jni_Release##Result##ArrayElements(JNIEnv *env, ElementType##Array array, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2769
                                             ElementType *buf, jint mode)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2770
  JNIWrapper("Release" XSTR(Result) "ArrayElements"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2771
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2772
  typeArrayOop a = typeArrayOop(JNIHandles::resolve_non_null(array)); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2773
  int len = a->length(); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2774
  if (len != 0) {   /* Empty array:  nothing to free or copy. */  \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2775
    if ((mode == 0) || (mode == JNI_COMMIT)) { \
50389
7e8c0409a747 8198285: More consistent Access API for arraycopy
rkennke
parents: 50113
diff changeset
  2776
      ArrayAccess<>::arraycopy_from_native(buf, a, typeArrayOopDesc::element_offset<ElementType>(0), len); \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2777
    } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2778
    if ((mode == 0) || (mode == JNI_ABORT)) { \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2779
      FreeHeap(buf); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2780
    } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2781
  } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2782
  ReturnProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2783
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2784
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2785
DEFINE_RELEASESCALARARRAYELEMENTS(T_BOOLEAN, jboolean, Boolean, bool
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2786
                                  , HOTSPOT_JNI_RELEASEBOOLEANARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2787
                                  HOTSPOT_JNI_RELEASEBOOLEANARRAYELEMENTS_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2788
DEFINE_RELEASESCALARARRAYELEMENTS(T_BYTE,    jbyte,    Byte,    byte
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2789
                                  , HOTSPOT_JNI_RELEASEBYTEARRAYELEMENTS_ENTRY(env, array, (char *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2790
                                  HOTSPOT_JNI_RELEASEBYTEARRAYELEMENTS_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2791
DEFINE_RELEASESCALARARRAYELEMENTS(T_SHORT,   jshort,   Short,   short
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2792
                                  ,  HOTSPOT_JNI_RELEASESHORTARRAYELEMENTS_ENTRY(env, array, (uint16_t *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2793
                                  HOTSPOT_JNI_RELEASESHORTARRAYELEMENTS_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2794
DEFINE_RELEASESCALARARRAYELEMENTS(T_CHAR,    jchar,    Char,    char
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2795
                                  ,  HOTSPOT_JNI_RELEASECHARARRAYELEMENTS_ENTRY(env, array, (uint16_t *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2796
                                  HOTSPOT_JNI_RELEASECHARARRAYELEMENTS_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2797
DEFINE_RELEASESCALARARRAYELEMENTS(T_INT,     jint,     Int,     int
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2798
                                  , HOTSPOT_JNI_RELEASEINTARRAYELEMENTS_ENTRY(env, array, (uint32_t *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2799
                                  HOTSPOT_JNI_RELEASEINTARRAYELEMENTS_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2800
DEFINE_RELEASESCALARARRAYELEMENTS(T_LONG,    jlong,    Long,    long
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2801
                                  , HOTSPOT_JNI_RELEASELONGARRAYELEMENTS_ENTRY(env, array, (uintptr_t *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2802
                                  HOTSPOT_JNI_RELEASELONGARRAYELEMENTS_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2803
DEFINE_RELEASESCALARARRAYELEMENTS(T_FLOAT,   jfloat,   Float,   float
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2804
                                  , HOTSPOT_JNI_RELEASEFLOATARRAYELEMENTS_ENTRY(env, array, (float *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2805
                                  HOTSPOT_JNI_RELEASEFLOATARRAYELEMENTS_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2806
DEFINE_RELEASESCALARARRAYELEMENTS(T_DOUBLE,  jdouble,  Double,  double
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2807
                                  , HOTSPOT_JNI_RELEASEDOUBLEARRAYELEMENTS_ENTRY(env, array, (double *) buf, mode),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2808
                                  HOTSPOT_JNI_RELEASEDOUBLEARRAYELEMENTS_RETURN())
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  2809
53533
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2810
static void check_bounds(jsize start, jsize copy_len, jsize array_len, TRAPS) {
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2811
  ResourceMark rm(THREAD);
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2812
  if (copy_len < 0) {
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2813
    stringStream ss;
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2814
    ss.print("Length %d is negative", copy_len);
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2815
    THROW_MSG(vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), ss.as_string());
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2816
  } else if (start < 0 || (start > array_len - copy_len)) {
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2817
    stringStream ss;
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2818
    ss.print("Array region %d.." INT64_FORMAT " out of bounds for length %d",
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2819
             start, (int64_t)start+(int64_t)copy_len, array_len);
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2820
    THROW_MSG(vmSymbols::java_lang_ArrayIndexOutOfBoundsException(), ss.as_string());
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2821
  }
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2822
}
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2823
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2824
#define DEFINE_GETSCALARARRAYREGION(ElementTag,ElementType,Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2825
                                    , EntryProbe, ReturnProbe); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2826
  DT_VOID_RETURN_MARK_DECL(Get##Result##ArrayRegion \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2827
                           , ReturnProbe); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2828
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2829
JNI_ENTRY(void, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2830
jni_Get##Result##ArrayRegion(JNIEnv *env, ElementType##Array array, jsize start, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2831
             jsize len, ElementType *buf)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2832
  JNIWrapper("Get" XSTR(Result) "ArrayRegion"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2833
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2834
  DT_VOID_RETURN_MARK(Get##Result##ArrayRegion); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2835
  typeArrayOop src = typeArrayOop(JNIHandles::resolve_non_null(array)); \
53533
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2836
  check_bounds(start, len, src->length(), CHECK); \
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2837
  if (len > 0) {    \
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2838
    ArrayAccess<>::arraycopy_to_native(src, typeArrayOopDesc::element_offset<ElementType>(start), buf, len); \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2839
  } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2840
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2841
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2842
DEFINE_GETSCALARARRAYREGION(T_BOOLEAN, jboolean,Boolean, bool
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2843
                            , HOTSPOT_JNI_GETBOOLEANARRAYREGION_ENTRY(env, array, start, len, (uintptr_t *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2844
                            HOTSPOT_JNI_GETBOOLEANARRAYREGION_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2845
DEFINE_GETSCALARARRAYREGION(T_BYTE,    jbyte,   Byte,    byte
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2846
                            ,  HOTSPOT_JNI_GETBYTEARRAYREGION_ENTRY(env, array, start, len, (char *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2847
                            HOTSPOT_JNI_GETBYTEARRAYREGION_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2848
DEFINE_GETSCALARARRAYREGION(T_SHORT,   jshort,  Short,   short
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2849
                            , HOTSPOT_JNI_GETSHORTARRAYREGION_ENTRY(env, array, start, len, (uint16_t *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2850
                            HOTSPOT_JNI_GETSHORTARRAYREGION_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2851
DEFINE_GETSCALARARRAYREGION(T_CHAR,    jchar,   Char,    char
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2852
                            ,  HOTSPOT_JNI_GETCHARARRAYREGION_ENTRY(env, array, start, len, (uint16_t*) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2853
                            HOTSPOT_JNI_GETCHARARRAYREGION_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2854
DEFINE_GETSCALARARRAYREGION(T_INT,     jint,    Int,     int
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2855
                            , HOTSPOT_JNI_GETINTARRAYREGION_ENTRY(env, array, start, len, (uint32_t*) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2856
                            HOTSPOT_JNI_GETINTARRAYREGION_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2857
DEFINE_GETSCALARARRAYREGION(T_LONG,    jlong,   Long,    long
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2858
                            ,  HOTSPOT_JNI_GETLONGARRAYREGION_ENTRY(env, array, start, len, (uintptr_t *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2859
                            HOTSPOT_JNI_GETLONGARRAYREGION_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2860
DEFINE_GETSCALARARRAYREGION(T_FLOAT,   jfloat,  Float,   float
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2861
                            , HOTSPOT_JNI_GETFLOATARRAYREGION_ENTRY(env, array, start, len, (float *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2862
                            HOTSPOT_JNI_GETFLOATARRAYREGION_RETURN());
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2863
DEFINE_GETSCALARARRAYREGION(T_DOUBLE,  jdouble, Double,  double
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2864
                            , HOTSPOT_JNI_GETDOUBLEARRAYREGION_ENTRY(env, array, start, len, (double *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2865
                            HOTSPOT_JNI_GETDOUBLEARRAYREGION_RETURN());
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  2866
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2867
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2868
#define DEFINE_SETSCALARARRAYREGION(ElementTag,ElementType,Result, Tag \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2869
                                    , EntryProbe, ReturnProbe); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2870
  DT_VOID_RETURN_MARK_DECL(Set##Result##ArrayRegion \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2871
                           ,ReturnProbe);           \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2872
\
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2873
JNI_ENTRY(void, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2874
jni_Set##Result##ArrayRegion(JNIEnv *env, ElementType##Array array, jsize start, \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2875
             jsize len, const ElementType *buf)) \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2876
  JNIWrapper("Set" XSTR(Result) "ArrayRegion"); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2877
  EntryProbe; \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2878
  DT_VOID_RETURN_MARK(Set##Result##ArrayRegion); \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2879
  typeArrayOop dst = typeArrayOop(JNIHandles::resolve_non_null(array)); \
53533
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2880
  check_bounds(start, len, dst->length(), CHECK); \
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2881
  if (len > 0) { \
bce458ffed11 8217628: Verbose ArrayIndexOutOfBoundsException message also in JNI calls.
goetz
parents: 53418
diff changeset
  2882
    ArrayAccess<>::arraycopy_from_native(buf, dst, typeArrayOopDesc::element_offset<ElementType>(start), len); \
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2883
  } \
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2884
JNI_END
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2885
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2886
DEFINE_SETSCALARARRAYREGION(T_BOOLEAN, jboolean, Boolean, bool
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2887
                            , HOTSPOT_JNI_SETBOOLEANARRAYREGION_ENTRY(env, array, start, len, (uintptr_t *)buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2888
                            HOTSPOT_JNI_SETBOOLEANARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2889
DEFINE_SETSCALARARRAYREGION(T_BYTE,    jbyte,    Byte,    byte
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2890
                            , HOTSPOT_JNI_SETBYTEARRAYREGION_ENTRY(env, array, start, len, (char *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2891
                            HOTSPOT_JNI_SETBYTEARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2892
DEFINE_SETSCALARARRAYREGION(T_SHORT,   jshort,   Short,   short
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2893
                            , HOTSPOT_JNI_SETSHORTARRAYREGION_ENTRY(env, array, start, len, (uint16_t *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2894
                            HOTSPOT_JNI_SETSHORTARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2895
DEFINE_SETSCALARARRAYREGION(T_CHAR,    jchar,    Char,    char
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2896
                            , HOTSPOT_JNI_SETCHARARRAYREGION_ENTRY(env, array, start, len, (uint16_t *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2897
                            HOTSPOT_JNI_SETCHARARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2898
DEFINE_SETSCALARARRAYREGION(T_INT,     jint,     Int,     int
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2899
                            , HOTSPOT_JNI_SETINTARRAYREGION_ENTRY(env, array, start, len, (uint32_t *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2900
                            HOTSPOT_JNI_SETINTARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2901
DEFINE_SETSCALARARRAYREGION(T_LONG,    jlong,    Long,    long
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2902
                            , HOTSPOT_JNI_SETLONGARRAYREGION_ENTRY(env, array, start, len, (uintptr_t *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2903
                            HOTSPOT_JNI_SETLONGARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2904
DEFINE_SETSCALARARRAYREGION(T_FLOAT,   jfloat,   Float,   float
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2905
                            , HOTSPOT_JNI_SETFLOATARRAYREGION_ENTRY(env, array, start, len, (float *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2906
                            HOTSPOT_JNI_SETFLOATARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2907
DEFINE_SETSCALARARRAYREGION(T_DOUBLE,  jdouble,  Double,  double
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2908
                            , HOTSPOT_JNI_SETDOUBLEARRAYREGION_ENTRY(env, array, start, len, (double *) buf),
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2909
                            HOTSPOT_JNI_SETDOUBLEARRAYREGION_RETURN())
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2910
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2911
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2912
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2913
// Interception of natives
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2914
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2915
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2916
// The RegisterNatives call being attempted tried to register with a method that
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2917
// is not native.  Ask JVM TI what prefixes have been specified.  Then check
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2918
// to see if the native method is now wrapped with the prefixes.  See the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2919
// SetNativeMethodPrefix(es) functions in the JVM TI Spec for details.
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2920
static Method* find_prefixed_native(Klass* k, Symbol* name, Symbol* signature, TRAPS) {
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
  2921
#if INCLUDE_JVMTI
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2922
  ResourceMark rm(THREAD);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2923
  Method* method;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2924
  int name_len = name->utf8_length();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2925
  char* name_str = name->as_utf8();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2926
  int prefix_count;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2927
  char** prefixes = JvmtiExport::get_all_native_method_prefixes(&prefix_count);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2928
  for (int i = 0; i < prefix_count; i++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2929
    char* prefix = prefixes[i];
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2930
    int prefix_len = (int)strlen(prefix);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2931
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2932
    // try adding this prefix to the method name and see if it matches another method name
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2933
    int trial_len = name_len + prefix_len;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2934
    char* trial_name_str = NEW_RESOURCE_ARRAY(char, trial_len + 1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2935
    strcpy(trial_name_str, prefix);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2936
    strcat(trial_name_str, name_str);
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2937
    TempNewSymbol trial_name = SymbolTable::probe(trial_name_str, trial_len);
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  2938
    if (trial_name == NULL) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2939
      continue; // no such symbol, so this prefix wasn't used, try the next prefix
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2940
    }
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2941
    method = k->lookup_method(trial_name, signature);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2942
    if (method == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2943
      continue; // signature doesn't match, try the next prefix
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2944
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2945
    if (method->is_native()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2946
      method->set_is_prefixed_native();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2947
      return method; // wahoo, we found a prefixed version of the method, return it
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2948
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2949
    // found as non-native, so prefix is good, add it, probably just need more prefixes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2950
    name_len = trial_len;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2951
    name_str = trial_name_str;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2952
  }
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
  2953
#endif // INCLUDE_JVMTI
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2954
  return NULL; // not found
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2955
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2956
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2957
static bool register_native(Klass* k, Symbol* name, Symbol* signature, address entry, TRAPS) {
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  2958
  Method* method = k->lookup_method(name, signature);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2959
  if (method == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2960
    ResourceMark rm;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2961
    stringStream st;
54432
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54416
diff changeset
  2962
    st.print("Method '");
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54416
diff changeset
  2963
    Method::print_external_name(&st, k, name, signature);
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54416
diff changeset
  2964
    st.print("' name or signature does not match");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2965
    THROW_MSG_(vmSymbols::java_lang_NoSuchMethodError(), st.as_string(), false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2966
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2967
  if (!method->is_native()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2968
    // trying to register to a non-native method, see if a JVM TI agent has added prefix(es)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2969
    method = find_prefixed_native(k, name, signature, THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2970
    if (method == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2971
      ResourceMark rm;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2972
      stringStream st;
54432
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54416
diff changeset
  2973
      st.print("Method '");
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54416
diff changeset
  2974
      Method::print_external_name(&st, k, name, signature);
532e88de77eb 8221470: Print methods in exception messages in java-like Syntax.
goetz
parents: 54416
diff changeset
  2975
      st.print("' is not declared as native");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2976
      THROW_MSG_(vmSymbols::java_lang_NoSuchMethodError(), st.as_string(), false);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2977
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2978
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2979
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2980
  if (entry != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2981
    method->set_native_function(entry,
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  2982
      Method::native_bind_event_is_interesting);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2983
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2984
    method->clear_native_function();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2985
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2986
  if (PrintJNIResolving) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2987
    ResourceMark rm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2988
    tty->print_cr("[Registering JNI native method %s.%s]",
14391
df0a1573d5bd 8000725: NPG: method_holder() and pool_holder() and pool_holder field should be InstanceKlass
coleenp
parents: 13977
diff changeset
  2989
      method->method_holder()->external_name(),
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2990
      method->name()->as_C_string());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2991
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2992
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2993
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2994
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2995
DT_RETURN_MARK_DECL(RegisterNatives, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  2996
                    , HOTSPOT_JNI_REGISTERNATIVES_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2997
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2998
JNI_ENTRY(jint, jni_RegisterNatives(JNIEnv *env, jclass clazz,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  2999
                                    const JNINativeMethod *methods,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3000
                                    jint nMethods))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3001
  JNIWrapper("RegisterNatives");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3002
  HOTSPOT_JNI_REGISTERNATIVES_ENTRY(env, clazz, (void *) methods, nMethods);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3003
  jint ret = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3004
  DT_RETURN_MARK(RegisterNatives, jint, (const jint&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3005
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  3006
  Klass* k = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(clazz));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3007
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3008
  for (int index = 0; index < nMethods; index++) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3009
    const char* meth_name = methods[index].name;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3010
    const char* meth_sig = methods[index].signature;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3011
    int meth_name_len = (int)strlen(meth_name);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3012
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3013
    // The class should have been loaded (we have an instance of the class
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3014
    // passed in) so the method and signature should already be in the symbol
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3015
    // table.  If they're not there, the method doesn't exist.
8076
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  3016
    TempNewSymbol  name = SymbolTable::probe(meth_name, meth_name_len);
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  3017
    TempNewSymbol  signature = SymbolTable::probe(meth_sig, (int)strlen(meth_sig));
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  3018
96d498ec7ae1 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 7414
diff changeset
  3019
    if (name == NULL || signature == NULL) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3020
      ResourceMark rm;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3021
      stringStream st;
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  3022
      st.print("Method %s.%s%s not found", k->external_name(), meth_name, meth_sig);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3023
      // Must return negative value on failure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3024
      THROW_MSG_(vmSymbols::java_lang_NoSuchMethodError(), st.as_string(), -1);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3025
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3026
46329
53ccc37bda19 8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents: 43969
diff changeset
  3027
    bool res = register_native(k, name, signature,
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3028
                               (address) methods[index].fnPtr, THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3029
    if (!res) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3030
      ret = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3031
      break;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3032
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3033
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3034
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3035
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3036
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3037
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3038
JNI_ENTRY(jint, jni_UnregisterNatives(JNIEnv *env, jclass clazz))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3039
  JNIWrapper("UnregisterNatives");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3040
 HOTSPOT_JNI_UNREGISTERNATIVES_ENTRY(env, clazz);
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  3041
  Klass* k   = java_lang_Class::as_Klass(JNIHandles::resolve_non_null(clazz));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3042
  //%note jni_2
33611
9abd65805e19 8139203: Consistent naming for klass type predicates
coleenp
parents: 33576
diff changeset
  3043
  if (k->is_instance_klass()) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  3044
    for (int index = 0; index < InstanceKlass::cast(k)->methods()->length(); index++) {
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  3045
      Method* m = InstanceKlass::cast(k)->methods()->at(index);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3046
      if (m->is_native()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3047
        m->clear_native_function();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3048
        m->set_signature_handler(NULL);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3049
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3050
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3051
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3052
 HOTSPOT_JNI_UNREGISTERNATIVES_RETURN(0);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3053
  return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3054
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3055
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3056
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3057
// Monitor functions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3058
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3059
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3060
DT_RETURN_MARK_DECL(MonitorEnter, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3061
                    , HOTSPOT_JNI_MONITORENTER_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3062
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3063
JNI_ENTRY(jint, jni_MonitorEnter(JNIEnv *env, jobject jobj))
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3064
 HOTSPOT_JNI_MONITORENTER_ENTRY(env, jobj);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3065
  jint ret = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3066
  DT_RETURN_MARK(MonitorEnter, jint, (const jint&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3067
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3068
  // If the object is null, we can't do anything with it
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3069
  if (jobj == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3070
    THROW_(vmSymbols::java_lang_NullPointerException(), JNI_ERR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3071
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3072
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3073
  Handle obj(thread, JNIHandles::resolve_non_null(jobj));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3074
  ObjectSynchronizer::jni_enter(obj, CHECK_(JNI_ERR));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3075
  ret = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3076
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3077
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3078
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3079
DT_RETURN_MARK_DECL(MonitorExit, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3080
                    , HOTSPOT_JNI_MONITOREXIT_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3081
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3082
JNI_ENTRY(jint, jni_MonitorExit(JNIEnv *env, jobject jobj))
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3083
 HOTSPOT_JNI_MONITOREXIT_ENTRY(env, jobj);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3084
  jint ret = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3085
  DT_RETURN_MARK(MonitorExit, jint, (const jint&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3086
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3087
  // Don't do anything with a null object
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3088
  if (jobj == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3089
    THROW_(vmSymbols::java_lang_NullPointerException(), JNI_ERR);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3090
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3091
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3092
  Handle obj(THREAD, JNIHandles::resolve_non_null(jobj));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3093
  ObjectSynchronizer::jni_exit(obj(), CHECK_(JNI_ERR));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3094
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3095
  ret = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3096
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3097
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3098
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3099
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3100
// Extensions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3101
//
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3102
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3103
DT_VOID_RETURN_MARK_DECL(GetStringRegion
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3104
                         , HOTSPOT_JNI_GETSTRINGREGION_RETURN());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3105
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3106
JNI_ENTRY(void, jni_GetStringRegion(JNIEnv *env, jstring string, jsize start, jsize len, jchar *buf))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3107
  JNIWrapper("GetStringRegion");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3108
 HOTSPOT_JNI_GETSTRINGREGION_ENTRY(env, string, start, len, buf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3109
  DT_VOID_RETURN_MARK(GetStringRegion);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3110
  oop s = JNIHandles::resolve_non_null(string);
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  3111
  typeArrayOop s_value = java_lang_String::value(s);
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  3112
  int s_len = java_lang_String::length(s, s_value);
48558
b2b67c8fc91a 8181664: Improve JVM UTF String handling
rprotacio
parents: 48105
diff changeset
  3113
  if (start < 0 || len < 0 || start > s_len - len) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3114
    THROW(vmSymbols::java_lang_StringIndexOutOfBoundsException());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3115
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3116
    if (len > 0) {
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3117
      bool is_latin1 = java_lang_String::is_latin1(s);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3118
      if (!is_latin1) {
50389
7e8c0409a747 8198285: More consistent Access API for arraycopy
rkennke
parents: 50113
diff changeset
  3119
        ArrayAccess<>::arraycopy_to_native(s_value, typeArrayOopDesc::element_offset<jchar>(start),
7e8c0409a747 8198285: More consistent Access API for arraycopy
rkennke
parents: 50113
diff changeset
  3120
                                           buf, len);
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3121
      } else {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3122
        for (int i = 0; i < len; i++) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3123
          buf[i] = ((jchar) s_value->byte_at(i + start)) & 0xff;
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3124
        }
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3125
      }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3126
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3127
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3128
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3129
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3130
DT_VOID_RETURN_MARK_DECL(GetStringUTFRegion
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3131
                         , HOTSPOT_JNI_GETSTRINGUTFREGION_RETURN());
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3132
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3133
JNI_ENTRY(void, jni_GetStringUTFRegion(JNIEnv *env, jstring string, jsize start, jsize len, char *buf))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3134
  JNIWrapper("GetStringUTFRegion");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3135
 HOTSPOT_JNI_GETSTRINGUTFREGION_ENTRY(env, string, start, len, buf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3136
  DT_VOID_RETURN_MARK(GetStringUTFRegion);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3137
  oop s = JNIHandles::resolve_non_null(string);
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  3138
  typeArrayOop s_value = java_lang_String::value(s);
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  3139
  int s_len = java_lang_String::length(s, s_value);
48558
b2b67c8fc91a 8181664: Improve JVM UTF String handling
rprotacio
parents: 48105
diff changeset
  3140
  if (start < 0 || len < 0 || start > s_len - len) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3141
    THROW(vmSymbols::java_lang_StringIndexOutOfBoundsException());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3142
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3143
    //%note jni_7
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3144
    if (len > 0) {
24237
7b210ef8c830 6664815: Eliminate redundant memcpy operation in jni_GetStringUTFRegion
mgerdin
parents: 23997
diff changeset
  3145
      // Assume the buffer is large enough as the JNI spec. does not require user error checking
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  3146
      java_lang_String::as_utf8_string(s, s_value, start, len, buf, INT_MAX);
24237
7b210ef8c830 6664815: Eliminate redundant memcpy operation in jni_GetStringUTFRegion
mgerdin
parents: 23997
diff changeset
  3147
      // as_utf8_string null-terminates the result string
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3148
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3149
      // JDK null-terminates the buffer even in len is zero
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3150
      if (buf != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3151
        buf[0] = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3152
      }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3153
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3154
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3155
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3156
49669
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3157
static oop lock_gc_or_pin_object(JavaThread* thread, jobject obj) {
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3158
  if (Universe::heap()->supports_object_pinning()) {
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3159
    const oop o = JNIHandles::resolve_non_null(obj);
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3160
    return Universe::heap()->pin_object(thread, o);
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3161
  } else {
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3162
    GCLocker::lock_critical(thread);
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3163
    return JNIHandles::resolve_non_null(obj);
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3164
  }
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3165
}
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3166
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3167
static void unlock_gc_or_unpin_object(JavaThread* thread, jobject obj) {
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3168
  if (Universe::heap()->supports_object_pinning()) {
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3169
    const oop o = JNIHandles::resolve_non_null(obj);
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3170
    return Universe::heap()->unpin_object(thread, o);
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3171
  } else {
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3172
    GCLocker::unlock_critical(thread);
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3173
  }
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3174
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3175
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3176
JNI_ENTRY(void*, jni_GetPrimitiveArrayCritical(JNIEnv *env, jarray array, jboolean *isCopy))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3177
  JNIWrapper("GetPrimitiveArrayCritical");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3178
 HOTSPOT_JNI_GETPRIMITIVEARRAYCRITICAL_ENTRY(env, array, (uintptr_t *) isCopy);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3179
  if (isCopy != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3180
    *isCopy = JNI_FALSE;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3181
  }
49669
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3182
  oop a = lock_gc_or_pin_object(thread, array);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3183
  assert(a->is_array(), "just checking");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3184
  BasicType type;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3185
  if (a->is_objArray()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3186
    type = T_OBJECT;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3187
  } else {
13952
e3cf184080bc 8000213: NPG: Should have renamed arrayKlass and typeArrayKlass
coleenp
parents: 13728
diff changeset
  3188
    type = TypeArrayKlass::cast(a->klass())->element_type();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3189
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3190
  void* ret = arrayOop(a)->base(type);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3191
 HOTSPOT_JNI_GETPRIMITIVEARRAYCRITICAL_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3192
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3193
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3194
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3195
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3196
JNI_ENTRY(void, jni_ReleasePrimitiveArrayCritical(JNIEnv *env, jarray array, void *carray, jint mode))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3197
  JNIWrapper("ReleasePrimitiveArrayCritical");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3198
  HOTSPOT_JNI_RELEASEPRIMITIVEARRAYCRITICAL_ENTRY(env, array, carray, mode);
49669
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3199
  unlock_gc_or_unpin_object(thread, array);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3200
HOTSPOT_JNI_RELEASEPRIMITIVEARRAYCRITICAL_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3201
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3202
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3203
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3204
JNI_ENTRY(const jchar*, jni_GetStringCritical(JNIEnv *env, jstring string, jboolean *isCopy))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3205
  JNIWrapper("GetStringCritical");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3206
  HOTSPOT_JNI_GETSTRINGCRITICAL_ENTRY(env, string, (uintptr_t *) isCopy);
49669
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3207
  oop s = lock_gc_or_pin_object(thread, string);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3208
  typeArrayOop s_value = java_lang_String::value(s);
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3209
  bool is_latin1 = java_lang_String::is_latin1(s);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3210
  if (isCopy != NULL) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3211
    *isCopy = is_latin1 ? JNI_TRUE : JNI_FALSE;
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3212
  }
35162
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3213
  jchar* ret;
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3214
  if (!is_latin1) {
35162
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3215
    ret = (jchar*) s_value->base(T_CHAR);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3216
  } else {
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3217
    // Inflate latin1 encoded string to UTF16
53418
bc2bb4eee477 8217442: Optimize native accesses to String.value
redestad
parents: 53197
diff changeset
  3218
    int s_len = java_lang_String::length(s, s_value);
35162
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3219
    ret = NEW_C_HEAP_ARRAY_RETURN_NULL(jchar, s_len + 1, mtInternal);  // add one for zero termination
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3220
    /* JNI Specification states return NULL on OOM */
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3221
    if (ret != NULL) {
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3222
      for (int i = 0; i < s_len; i++) {
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3223
        ret[i] = ((jchar) s_value->byte_at(i)) & 0xff;
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3224
      }
65d0237246b1 8145015: jni_GetStringCritical asserts for empty strings
simonis
parents: 35061
diff changeset
  3225
      ret[s_len] = 0;
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3226
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3227
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3228
 HOTSPOT_JNI_GETSTRINGCRITICAL_RETURN((uint16_t *) ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3229
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3230
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3231
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3232
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3233
JNI_ENTRY(void, jni_ReleaseStringCritical(JNIEnv *env, jstring str, const jchar *chars))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3234
  JNIWrapper("ReleaseStringCritical");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3235
  HOTSPOT_JNI_RELEASESTRINGCRITICAL_ENTRY(env, str, (uint16_t *) chars);
33628
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3236
  // The str and chars arguments are ignored for UTF16 strings
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3237
  oop s = JNIHandles::resolve_non_null(str);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3238
  bool is_latin1 = java_lang_String::is_latin1(s);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3239
  if (is_latin1) {
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3240
    // For latin1 string, free jchar array allocated by earlier call to GetStringCritical.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3241
    // This assumes that ReleaseStringCritical bookends GetStringCritical.
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3242
    FREE_C_HEAP_ARRAY(jchar, chars);
09241459a8b8 8141132: JEP 254: Compact Strings
thartmann
parents: 33470
diff changeset
  3243
  }
49669
3569b528972e 8200429: Adjust object pinning interface on CollectedHeap
pliden
parents: 49658
diff changeset
  3244
  unlock_gc_or_unpin_object(thread, str);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3245
HOTSPOT_JNI_RELEASESTRINGCRITICAL_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3246
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3247
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3248
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3249
JNI_ENTRY(jweak, jni_NewWeakGlobalRef(JNIEnv *env, jobject ref))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3250
  JNIWrapper("jni_NewWeakGlobalRef");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3251
 HOTSPOT_JNI_NEWWEAKGLOBALREF_ENTRY(env, ref);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3252
  Handle ref_handle(thread, JNIHandles::resolve(ref));
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3253
  jweak ret = JNIHandles::make_weak_global(ref_handle);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3254
 HOTSPOT_JNI_NEWWEAKGLOBALREF_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3255
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3256
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3257
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3258
// Must be JNI_ENTRY (with HandleMark)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3259
JNI_ENTRY(void, jni_DeleteWeakGlobalRef(JNIEnv *env, jweak ref))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3260
  JNIWrapper("jni_DeleteWeakGlobalRef");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3261
  HOTSPOT_JNI_DELETEWEAKGLOBALREF_ENTRY(env, ref);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3262
  JNIHandles::destroy_weak_global(ref);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3263
  HOTSPOT_JNI_DELETEWEAKGLOBALREF_RETURN();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3264
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3265
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3266
58043
647d623650d3 8228758: assert(_no_handle_mark_nesting == 0) failed: allocating handle inside NoHandleMark
rehn
parents: 57811
diff changeset
  3267
JNI_ENTRY_NO_PRESERVE(jboolean, jni_ExceptionCheck(JNIEnv *env))
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3268
  JNIWrapper("jni_ExceptionCheck");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3269
 HOTSPOT_JNI_EXCEPTIONCHECK_ENTRY(env);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3270
  jni_check_async_exceptions(thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3271
  jboolean ret = (thread->has_pending_exception()) ? JNI_TRUE : JNI_FALSE;
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3272
 HOTSPOT_JNI_EXCEPTIONCHECK_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3273
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3274
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3275
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3276
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3277
// Initialization state for three routines below relating to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3278
// java.nio.DirectBuffers
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  3279
static          int directBufferSupportInitializeStarted = 0;
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  3280
static volatile int directBufferSupportInitializeEnded   = 0;
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  3281
static volatile int directBufferSupportInitializeFailed  = 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3282
static jclass    bufferClass                 = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3283
static jclass    directBufferClass           = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3284
static jclass    directByteBufferClass       = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3285
static jmethodID directByteBufferConstructor = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3286
static jfieldID  directBufferAddressField    = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3287
static jfieldID  bufferCapacityField         = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3288
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3289
static jclass lookupOne(JNIEnv* env, const char* name, TRAPS) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3290
  Handle loader;            // null (bootstrap) loader
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3291
  Handle protection_domain; // null protection domain
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3292
54847
59ea39bb2809 8223657: Remove unused THREAD argument from SymbolTable functions
coleenp
parents: 54669
diff changeset
  3293
  TempNewSymbol sym = SymbolTable::new_symbol(name);
58056
db92a157dd70 8212117: Class.forName may return a reference to a loaded but not linked Class
bchristi
parents: 58043
diff changeset
  3294
  jclass result =  find_class_from_class_loader(env, sym, true, true, loader, protection_domain, true, CHECK_NULL);
2269
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
  3295
38151
fffedc5e5cf8 8154110: Update class* and safepoint* logging subsystems
mockner
parents: 37483
diff changeset
  3296
  if (log_is_enabled(Debug, class, resolve) && result != NULL) {
13728
882756847a04 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 13195
diff changeset
  3297
    trace_class_resolution(java_lang_Class::as_Klass(JNIHandles::resolve_non_null(result)));
2269
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
  3298
  }
ee9da33d43ab 6603316: Improve instrumentation for classes loaded at startup
acorn
parents: 2105
diff changeset
  3299
  return result;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3300
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3301
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3302
// These lookups are done with the NULL (bootstrap) ClassLoader to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3303
// circumvent any security checks that would be done by jni_FindClass.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3304
JNI_ENTRY(bool, lookupDirectBufferClasses(JNIEnv* env))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3305
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3306
  if ((bufferClass           = lookupOne(env, "java/nio/Buffer", thread))           == NULL) { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3307
  if ((directBufferClass     = lookupOne(env, "sun/nio/ch/DirectBuffer", thread))   == NULL) { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3308
  if ((directByteBufferClass = lookupOne(env, "java/nio/DirectByteBuffer", thread)) == NULL) { return false; }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3309
  return true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3310
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3311
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3312
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3313
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3314
static bool initializeDirectBufferSupport(JNIEnv* env, JavaThread* thread) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3315
  if (directBufferSupportInitializeFailed) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3316
    return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3317
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3318
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3319
  if (Atomic::cmpxchg(1, &directBufferSupportInitializeStarted, 0) == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3320
    if (!lookupDirectBufferClasses(env)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3321
      directBufferSupportInitializeFailed = 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3322
      return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3323
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3324
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3325
    // Make global references for these
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3326
    bufferClass           = (jclass) env->NewGlobalRef(bufferClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3327
    directBufferClass     = (jclass) env->NewGlobalRef(directBufferClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3328
    directByteBufferClass = (jclass) env->NewGlobalRef(directByteBufferClass);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3329
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3330
    // Get needed field and method IDs
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3331
    directByteBufferConstructor = env->GetMethodID(directByteBufferClass, "<init>", "(JI)V");
22786
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3332
    if (env->ExceptionCheck()) {
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3333
      env->ExceptionClear();
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3334
      directBufferSupportInitializeFailed = 1;
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3335
      return false;
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3336
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3337
    directBufferAddressField    = env->GetFieldID(bufferClass, "address", "J");
22786
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3338
    if (env->ExceptionCheck()) {
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3339
      env->ExceptionClear();
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3340
      directBufferSupportInitializeFailed = 1;
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3341
      return false;
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3342
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3343
    bufferCapacityField         = env->GetFieldID(bufferClass, "capacity", "I");
22786
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3344
    if (env->ExceptionCheck()) {
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3345
      env->ExceptionClear();
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3346
      directBufferSupportInitializeFailed = 1;
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3347
      return false;
86644d9539c2 8028785: [parfait] warnings from b116 for hotspot.src.share.vm.prims: JNI exception pending
ccheung
parents: 22737
diff changeset
  3348
    }
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3349
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3350
    if ((directByteBufferConstructor == NULL) ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3351
        (directBufferAddressField    == NULL) ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3352
        (bufferCapacityField         == NULL)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3353
      directBufferSupportInitializeFailed = 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3354
      return false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3355
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3356
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3357
    directBufferSupportInitializeEnded = 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3358
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3359
    while (!directBufferSupportInitializeEnded && !directBufferSupportInitializeFailed) {
25477
7dad9f95fd31 8047714: Fix for JDK-6546236 made Solaris os::yield() a no-op
fparain
parents: 25469
diff changeset
  3360
      os::naked_yield();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3361
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3362
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3363
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3364
  return !directBufferSupportInitializeFailed;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3365
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3366
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3367
extern "C" jobject JNICALL jni_NewDirectByteBuffer(JNIEnv *env, void* address, jlong capacity)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3368
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3369
  // thread_from_jni_environment() will block if VM is gone.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3370
  JavaThread* thread = JavaThread::thread_from_jni_environment(env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3371
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3372
  JNIWrapper("jni_NewDirectByteBuffer");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3373
 HOTSPOT_JNI_NEWDIRECTBYTEBUFFER_ENTRY(env, address, capacity);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3374
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3375
  if (!directBufferSupportInitializeEnded) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3376
    if (!initializeDirectBufferSupport(env, thread)) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3377
      HOTSPOT_JNI_NEWDIRECTBYTEBUFFER_RETURN(NULL);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3378
      return NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3379
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3380
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3381
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3382
  // Being paranoid about accidental sign extension on address
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3383
  jlong addr = (jlong) ((uintptr_t) address);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3384
  // NOTE that package-private DirectByteBuffer constructor currently
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3385
  // takes int capacity
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3386
  jint  cap  = (jint)  capacity;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3387
  jobject ret = env->NewObject(directByteBufferClass, directByteBufferConstructor, addr, cap);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3388
  HOTSPOT_JNI_NEWDIRECTBYTEBUFFER_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3389
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3390
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3391
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3392
DT_RETURN_MARK_DECL(GetDirectBufferAddress, void*
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3393
                    , HOTSPOT_JNI_GETDIRECTBUFFERADDRESS_RETURN((void*) _ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3394
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3395
extern "C" void* JNICALL jni_GetDirectBufferAddress(JNIEnv *env, jobject buf)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3396
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3397
  // thread_from_jni_environment() will block if VM is gone.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3398
  JavaThread* thread = JavaThread::thread_from_jni_environment(env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3399
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3400
  JNIWrapper("jni_GetDirectBufferAddress");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3401
  HOTSPOT_JNI_GETDIRECTBUFFERADDRESS_ENTRY(env, buf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3402
  void* ret = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3403
  DT_RETURN_MARK(GetDirectBufferAddress, void*, (const void*&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3404
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3405
  if (!directBufferSupportInitializeEnded) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3406
    if (!initializeDirectBufferSupport(env, thread)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3407
      return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3408
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3409
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3410
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3411
  if ((buf != NULL) && (!env->IsInstanceOf(buf, directBufferClass))) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3412
    return 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3413
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3414
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3415
  ret = (void*)(intptr_t)env->GetLongField(buf, directBufferAddressField);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3416
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3417
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3418
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3419
DT_RETURN_MARK_DECL(GetDirectBufferCapacity, jlong
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3420
                    , HOTSPOT_JNI_GETDIRECTBUFFERCAPACITY_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3421
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3422
extern "C" jlong JNICALL jni_GetDirectBufferCapacity(JNIEnv *env, jobject buf)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3423
{
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3424
  // thread_from_jni_environment() will block if VM is gone.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3425
  JavaThread* thread = JavaThread::thread_from_jni_environment(env);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3426
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3427
  JNIWrapper("jni_GetDirectBufferCapacity");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3428
  HOTSPOT_JNI_GETDIRECTBUFFERCAPACITY_ENTRY(env, buf);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3429
  jlong ret = -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3430
  DT_RETURN_MARK(GetDirectBufferCapacity, jlong, (const jlong&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3431
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3432
  if (!directBufferSupportInitializeEnded) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3433
    if (!initializeDirectBufferSupport(env, thread)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3434
      ret = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3435
      return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3436
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3437
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3438
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3439
  if (buf == NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3440
    return -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3441
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3442
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3443
  if (!env->IsInstanceOf(buf, directBufferClass)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3444
    return -1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3445
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3446
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3447
  // NOTE that capacity is currently an int in the implementation
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3448
  ret = env->GetIntField(buf, bufferCapacityField);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3449
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3450
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3451
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3452
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3453
JNI_LEAF(jint, jni_GetVersion(JNIEnv *env))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3454
  JNIWrapper("GetVersion");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3455
  HOTSPOT_JNI_GETVERSION_ENTRY(env);
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3456
  HOTSPOT_JNI_GETVERSION_RETURN(CurrentVersion);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3457
  return CurrentVersion;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3458
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3459
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3460
extern struct JavaVM_ main_vm;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3461
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3462
JNI_LEAF(jint, jni_GetJavaVM(JNIEnv *env, JavaVM **vm))
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3463
  JNIWrapper("jni_GetJavaVM");
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3464
  HOTSPOT_JNI_GETJAVAVM_ENTRY(env, (void **) vm);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3465
  *vm  = (JavaVM *)(&main_vm);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3466
  HOTSPOT_JNI_GETJAVAVM_RETURN(JNI_OK);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3467
  return JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3468
JNI_END
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3469
36508
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3470
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3471
JNI_ENTRY(jobject, jni_GetModule(JNIEnv* env, jclass clazz))
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3472
  JNIWrapper("GetModule");
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3473
  return Modules::get_module(clazz, THREAD);
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3474
JNI_END
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3475
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3476
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3477
// Structure containing all jni functions
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3478
struct JNINativeInterface_ jni_NativeInterface = {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3479
    NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3480
    NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3481
    NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3482
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3483
    NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3484
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3485
    jni_GetVersion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3486
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3487
    jni_DefineClass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3488
    jni_FindClass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3489
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3490
    jni_FromReflectedMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3491
    jni_FromReflectedField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3492
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3493
    jni_ToReflectedMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3494
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3495
    jni_GetSuperclass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3496
    jni_IsAssignableFrom,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3497
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3498
    jni_ToReflectedField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3499
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3500
    jni_Throw,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3501
    jni_ThrowNew,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3502
    jni_ExceptionOccurred,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3503
    jni_ExceptionDescribe,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3504
    jni_ExceptionClear,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3505
    jni_FatalError,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3506
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3507
    jni_PushLocalFrame,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3508
    jni_PopLocalFrame,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3509
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3510
    jni_NewGlobalRef,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3511
    jni_DeleteGlobalRef,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3512
    jni_DeleteLocalRef,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3513
    jni_IsSameObject,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3514
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3515
    jni_NewLocalRef,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3516
    jni_EnsureLocalCapacity,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3517
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3518
    jni_AllocObject,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3519
    jni_NewObject,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3520
    jni_NewObjectV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3521
    jni_NewObjectA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3522
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3523
    jni_GetObjectClass,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3524
    jni_IsInstanceOf,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3525
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3526
    jni_GetMethodID,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3527
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3528
    jni_CallObjectMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3529
    jni_CallObjectMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3530
    jni_CallObjectMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3531
    jni_CallBooleanMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3532
    jni_CallBooleanMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3533
    jni_CallBooleanMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3534
    jni_CallByteMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3535
    jni_CallByteMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3536
    jni_CallByteMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3537
    jni_CallCharMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3538
    jni_CallCharMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3539
    jni_CallCharMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3540
    jni_CallShortMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3541
    jni_CallShortMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3542
    jni_CallShortMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3543
    jni_CallIntMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3544
    jni_CallIntMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3545
    jni_CallIntMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3546
    jni_CallLongMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3547
    jni_CallLongMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3548
    jni_CallLongMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3549
    jni_CallFloatMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3550
    jni_CallFloatMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3551
    jni_CallFloatMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3552
    jni_CallDoubleMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3553
    jni_CallDoubleMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3554
    jni_CallDoubleMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3555
    jni_CallVoidMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3556
    jni_CallVoidMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3557
    jni_CallVoidMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3558
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3559
    jni_CallNonvirtualObjectMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3560
    jni_CallNonvirtualObjectMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3561
    jni_CallNonvirtualObjectMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3562
    jni_CallNonvirtualBooleanMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3563
    jni_CallNonvirtualBooleanMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3564
    jni_CallNonvirtualBooleanMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3565
    jni_CallNonvirtualByteMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3566
    jni_CallNonvirtualByteMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3567
    jni_CallNonvirtualByteMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3568
    jni_CallNonvirtualCharMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3569
    jni_CallNonvirtualCharMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3570
    jni_CallNonvirtualCharMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3571
    jni_CallNonvirtualShortMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3572
    jni_CallNonvirtualShortMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3573
    jni_CallNonvirtualShortMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3574
    jni_CallNonvirtualIntMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3575
    jni_CallNonvirtualIntMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3576
    jni_CallNonvirtualIntMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3577
    jni_CallNonvirtualLongMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3578
    jni_CallNonvirtualLongMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3579
    jni_CallNonvirtualLongMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3580
    jni_CallNonvirtualFloatMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3581
    jni_CallNonvirtualFloatMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3582
    jni_CallNonvirtualFloatMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3583
    jni_CallNonvirtualDoubleMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3584
    jni_CallNonvirtualDoubleMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3585
    jni_CallNonvirtualDoubleMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3586
    jni_CallNonvirtualVoidMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3587
    jni_CallNonvirtualVoidMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3588
    jni_CallNonvirtualVoidMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3589
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3590
    jni_GetFieldID,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3591
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3592
    jni_GetObjectField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3593
    jni_GetBooleanField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3594
    jni_GetByteField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3595
    jni_GetCharField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3596
    jni_GetShortField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3597
    jni_GetIntField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3598
    jni_GetLongField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3599
    jni_GetFloatField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3600
    jni_GetDoubleField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3601
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3602
    jni_SetObjectField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3603
    jni_SetBooleanField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3604
    jni_SetByteField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3605
    jni_SetCharField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3606
    jni_SetShortField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3607
    jni_SetIntField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3608
    jni_SetLongField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3609
    jni_SetFloatField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3610
    jni_SetDoubleField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3611
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3612
    jni_GetStaticMethodID,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3613
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3614
    jni_CallStaticObjectMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3615
    jni_CallStaticObjectMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3616
    jni_CallStaticObjectMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3617
    jni_CallStaticBooleanMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3618
    jni_CallStaticBooleanMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3619
    jni_CallStaticBooleanMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3620
    jni_CallStaticByteMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3621
    jni_CallStaticByteMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3622
    jni_CallStaticByteMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3623
    jni_CallStaticCharMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3624
    jni_CallStaticCharMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3625
    jni_CallStaticCharMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3626
    jni_CallStaticShortMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3627
    jni_CallStaticShortMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3628
    jni_CallStaticShortMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3629
    jni_CallStaticIntMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3630
    jni_CallStaticIntMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3631
    jni_CallStaticIntMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3632
    jni_CallStaticLongMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3633
    jni_CallStaticLongMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3634
    jni_CallStaticLongMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3635
    jni_CallStaticFloatMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3636
    jni_CallStaticFloatMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3637
    jni_CallStaticFloatMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3638
    jni_CallStaticDoubleMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3639
    jni_CallStaticDoubleMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3640
    jni_CallStaticDoubleMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3641
    jni_CallStaticVoidMethod,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3642
    jni_CallStaticVoidMethodV,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3643
    jni_CallStaticVoidMethodA,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3644
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3645
    jni_GetStaticFieldID,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3646
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3647
    jni_GetStaticObjectField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3648
    jni_GetStaticBooleanField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3649
    jni_GetStaticByteField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3650
    jni_GetStaticCharField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3651
    jni_GetStaticShortField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3652
    jni_GetStaticIntField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3653
    jni_GetStaticLongField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3654
    jni_GetStaticFloatField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3655
    jni_GetStaticDoubleField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3656
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3657
    jni_SetStaticObjectField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3658
    jni_SetStaticBooleanField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3659
    jni_SetStaticByteField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3660
    jni_SetStaticCharField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3661
    jni_SetStaticShortField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3662
    jni_SetStaticIntField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3663
    jni_SetStaticLongField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3664
    jni_SetStaticFloatField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3665
    jni_SetStaticDoubleField,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3666
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3667
    jni_NewString,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3668
    jni_GetStringLength,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3669
    jni_GetStringChars,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3670
    jni_ReleaseStringChars,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3671
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3672
    jni_NewStringUTF,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3673
    jni_GetStringUTFLength,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3674
    jni_GetStringUTFChars,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3675
    jni_ReleaseStringUTFChars,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3676
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3677
    jni_GetArrayLength,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3678
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3679
    jni_NewObjectArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3680
    jni_GetObjectArrayElement,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3681
    jni_SetObjectArrayElement,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3682
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3683
    jni_NewBooleanArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3684
    jni_NewByteArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3685
    jni_NewCharArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3686
    jni_NewShortArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3687
    jni_NewIntArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3688
    jni_NewLongArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3689
    jni_NewFloatArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3690
    jni_NewDoubleArray,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3691
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3692
    jni_GetBooleanArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3693
    jni_GetByteArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3694
    jni_GetCharArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3695
    jni_GetShortArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3696
    jni_GetIntArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3697
    jni_GetLongArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3698
    jni_GetFloatArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3699
    jni_GetDoubleArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3700
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3701
    jni_ReleaseBooleanArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3702
    jni_ReleaseByteArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3703
    jni_ReleaseCharArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3704
    jni_ReleaseShortArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3705
    jni_ReleaseIntArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3706
    jni_ReleaseLongArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3707
    jni_ReleaseFloatArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3708
    jni_ReleaseDoubleArrayElements,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3709
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3710
    jni_GetBooleanArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3711
    jni_GetByteArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3712
    jni_GetCharArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3713
    jni_GetShortArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3714
    jni_GetIntArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3715
    jni_GetLongArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3716
    jni_GetFloatArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3717
    jni_GetDoubleArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3718
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3719
    jni_SetBooleanArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3720
    jni_SetByteArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3721
    jni_SetCharArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3722
    jni_SetShortArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3723
    jni_SetIntArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3724
    jni_SetLongArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3725
    jni_SetFloatArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3726
    jni_SetDoubleArrayRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3727
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3728
    jni_RegisterNatives,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3729
    jni_UnregisterNatives,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3730
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3731
    jni_MonitorEnter,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3732
    jni_MonitorExit,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3733
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3734
    jni_GetJavaVM,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3735
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3736
    jni_GetStringRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3737
    jni_GetStringUTFRegion,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3738
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3739
    jni_GetPrimitiveArrayCritical,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3740
    jni_ReleasePrimitiveArrayCritical,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3741
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3742
    jni_GetStringCritical,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3743
    jni_ReleaseStringCritical,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3744
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3745
    jni_NewWeakGlobalRef,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3746
    jni_DeleteWeakGlobalRef,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3747
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3748
    jni_ExceptionCheck,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3749
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3750
    jni_NewDirectByteBuffer,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3751
    jni_GetDirectBufferAddress,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3752
    jni_GetDirectBufferCapacity,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3753
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3754
    // New 1_6 features
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3755
36508
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3756
    jni_GetObjectRefType,
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3757
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3758
    // Module features
5f9eee6b383b 8142968: Module System implementation
alanb
parents: 36396
diff changeset
  3759
42307
cefc81dc1d52 8169069: Module system implementation refresh (11/2016)
alanb
parents: 41669
diff changeset
  3760
    jni_GetModule
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3761
};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3762
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3763
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3764
// For jvmti use to modify jni function table.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3765
// Java threads in native contiues to run until it is transitioned
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3766
// to VM at safepoint. Before the transition or before it is blocked
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3767
// for safepoint it may access jni function table. VM could crash if
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3768
// any java thread access the jni function table in the middle of memcpy.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3769
// To avoid this each function pointers are copied automically.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3770
void copy_jni_function_table(const struct JNINativeInterface_ *new_jni_NativeInterface) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3771
  assert(SafepointSynchronize::is_at_safepoint(), "must be at safepoint");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3772
  intptr_t *a = (intptr_t *) jni_functions();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3773
  intptr_t *b = (intptr_t *) new_jni_NativeInterface;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3774
  for (uint i=0; i <  sizeof(struct JNINativeInterface_)/sizeof(void *); i++) {
47634
6a0c42c40cd1 8188220: Remove Atomic::*_ptr() uses and overloads from hotspot
coleenp
parents: 47627
diff changeset
  3775
    Atomic::store(*b++, a++);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3776
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3777
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3778
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3779
void quicken_jni_functions() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3780
  // Replace Get<Primitive>Field with fast versions
57570
d7304cf430f1 8227680: FastJNIAccessors: Check for JVMTI field access event requests at runtime
mdoerr
parents: 54847
diff changeset
  3781
  if (UseFastJNIAccessors && !VerifyJNIFields && !CountJNICalls && !CheckJNICalls) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3782
    address func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3783
    func = JNI_FastGetField::generate_fast_get_boolean_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3784
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3785
      jni_NativeInterface.GetBooleanField = (GetBooleanField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3786
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3787
    func = JNI_FastGetField::generate_fast_get_byte_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3788
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3789
      jni_NativeInterface.GetByteField = (GetByteField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3790
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3791
    func = JNI_FastGetField::generate_fast_get_char_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3792
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3793
      jni_NativeInterface.GetCharField = (GetCharField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3794
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3795
    func = JNI_FastGetField::generate_fast_get_short_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3796
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3797
      jni_NativeInterface.GetShortField = (GetShortField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3798
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3799
    func = JNI_FastGetField::generate_fast_get_int_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3800
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3801
      jni_NativeInterface.GetIntField = (GetIntField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3802
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3803
    func = JNI_FastGetField::generate_fast_get_long_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3804
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3805
      jni_NativeInterface.GetLongField = (GetLongField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3806
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3807
    func = JNI_FastGetField::generate_fast_get_float_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3808
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3809
      jni_NativeInterface.GetFloatField = (GetFloatField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3810
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3811
    func = JNI_FastGetField::generate_fast_get_double_field();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3812
    if (func != (address)-1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3813
      jni_NativeInterface.GetDoubleField = (GetDoubleField_t)func;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3814
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3815
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3816
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3817
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3818
// Returns the function structure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3819
struct JNINativeInterface_* jni_functions() {
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
  3820
#if INCLUDE_JNI_CHECK
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3821
  if (CheckJNICalls) return jni_functions_check();
13975
2f7431485cfa 7189254: Change makefiles for more flexibility to override defaults
jprovino
parents: 13728
diff changeset
  3822
#endif // INCLUDE_JNI_CHECK
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3823
  return &jni_NativeInterface;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3824
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3825
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3826
// Returns the function structure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3827
struct JNINativeInterface_* jni_functions_nocheck() {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3828
  return &jni_NativeInterface;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3829
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3830
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3831
static void post_thread_start_event(const JavaThread* jt) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3832
  assert(jt != NULL, "invariant");
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3833
  EventThreadStart event;
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3834
  if (event.should_commit()) {
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3835
    event.set_thread(JFR_THREAD_ID(jt));
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3836
    event.commit();
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3837
  }
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3838
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3839
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3840
// Invocation API
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3841
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3842
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3843
// Forward declaration
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3844
extern const struct JNIInvokeInterface_ jni_InvokeInterface;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3845
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3846
// Global invocation API vars
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  3847
volatile int vm_created = 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3848
// Indicate whether it is safe to recreate VM
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  3849
volatile int safe_to_recreate_vm = 1;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3850
struct JavaVM_ main_vm = {&jni_InvokeInterface};
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3851
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3852
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3853
#define JAVASTACKSIZE (400 * 1024)    /* Default size of a thread java stack */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3854
enum { VERIFY_NONE, VERIFY_REMOTE, VERIFY_ALL };
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3855
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3856
DT_RETURN_MARK_DECL(GetDefaultJavaVMInitArgs, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3857
                    , HOTSPOT_JNI_GETDEFAULTJAVAVMINITARGS_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3858
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3859
_JNI_IMPORT_OR_EXPORT_ jint JNICALL JNI_GetDefaultJavaVMInitArgs(void *args_) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3860
  HOTSPOT_JNI_GETDEFAULTJAVAVMINITARGS_ENTRY(args_);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3861
  JDK1_1InitArgs *args = (JDK1_1InitArgs *)args_;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3862
  jint ret = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3863
  DT_RETURN_MARK(GetDefaultJavaVMInitArgs, jint, (const jint&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3864
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3865
  if (Threads::is_supported_jni_version(args->version)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3866
    ret = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3867
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3868
  // 1.1 style no longer supported in hotspot.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3869
  // According the JNI spec, we should update args->version on return.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3870
  // We also use the structure to communicate with launcher about default
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3871
  // stack size.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3872
  if (args->version == JNI_VERSION_1_1) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3873
    args->version = JNI_VERSION_1_2;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3874
    // javaStackSize is int in arguments structure
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3875
    assert(jlong(ThreadStackSize) * K < INT_MAX, "integer overflow");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3876
    args->javaStackSize = (jint)(ThreadStackSize * K);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3877
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3878
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3879
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3880
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3881
DT_RETURN_MARK_DECL(CreateJavaVM, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  3882
                    , HOTSPOT_JNI_CREATEJAVAVM_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3883
30143
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  3884
static jint JNI_CreateJavaVM_inner(JavaVM **vm, void **penv, void *args) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  3885
  HOTSPOT_JNI_CREATEJAVAVM_ENTRY((void **) vm, penv, args);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3886
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3887
  jint result = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3888
  DT_RETURN_MARK(CreateJavaVM, jint, (const jint&)result);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3889
4448
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3890
  // We're about to use Atomic::xchg for synchronization.  Some Zero
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3891
  // platforms use the GCC builtin __sync_lock_test_and_set for this,
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3892
  // but __sync_lock_test_and_set is not guaranteed to do what we want
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3893
  // on all architectures.  So we check it works before relying on it.
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3894
#if defined(ZERO) && defined(ASSERT)
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3895
  {
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3896
    jint a = 0xcafebabe;
47627
6218d903d2f2 8189333: Fix Zero build after Atomic::xchg changes
rkennke
parents: 47613
diff changeset
  3897
    jint b = Atomic::xchg((jint) 0xdeadbeef, &a);
4448
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3898
    void *c = &a;
47634
6a0c42c40cd1 8188220: Remove Atomic::*_ptr() uses and overloads from hotspot
coleenp
parents: 47627
diff changeset
  3899
    void *d = Atomic::xchg(&b, &c);
4561
4dfa5956fbb9 6913869: Zero assert fix
twisti
parents: 4448
diff changeset
  3900
    assert(a == (jint) 0xdeadbeef && b == (jint) 0xcafebabe, "Atomic::xchg() works");
47634
6a0c42c40cd1 8188220: Remove Atomic::*_ptr() uses and overloads from hotspot
coleenp
parents: 47627
diff changeset
  3901
    assert(c == &b && d == &a, "Atomic::xchg() works");
4448
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3902
  }
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3903
#endif // ZERO && ASSERT
d6ec2737186c 6896043: first round of zero fixes
twisti
parents: 4089
diff changeset
  3904
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3905
  // At the moment it's only possible to have one Java VM,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3906
  // since some of the runtime state is in global variables.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3907
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3908
  // We cannot use our mutex locks here, since they only work on
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3909
  // Threads. We do an atomic compare and exchange to ensure only
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3910
  // one thread can call this method at a time
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3911
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3912
  // We use Atomic::xchg rather than Atomic::add/dec since on some platforms
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3913
  // the add/dec implementations are dependent on whether we are running
51996
84743156e780 8188764: Obsolete AssumeMP and then remove all support for non-MP builds
dholmes
parents: 51554
diff changeset
  3914
  // on a multiprocessor Atomic::xchg does not have this problem.
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3915
  if (Atomic::xchg(1, &vm_created) == 1) {
18680
6d5dc445baec 8019833: Wrong JNI error code for preexisting JVM
coleenp
parents: 18486
diff changeset
  3916
    return JNI_EEXIST;   // already created, or create attempt in progress
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3917
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3918
  if (Atomic::xchg(0, &safe_to_recreate_vm) == 0) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3919
    return JNI_ERR;  // someone tried and failed and retry not allowed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3920
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3921
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3922
  assert(vm_created == 1, "vm_created is true during the creation");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3923
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3924
  /**
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3925
   * Certain errors during initialization are recoverable and do not
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3926
   * prevent this method from being called again at a later time
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3927
   * (perhaps with different arguments).  However, at a certain
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3928
   * point during initialization if an error occurs we cannot allow
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3929
   * this function to be called again (or it will crash).  In those
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3930
   * situations, the 'canTryAgain' flag is set to false, which atomically
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3931
   * sets safe_to_recreate_vm to 1, such that any new call to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3932
   * JNI_CreateJavaVM will immediately fail using the above logic.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3933
   */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3934
  bool can_try_again = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3935
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3936
  result = Threads::create_vm((JavaVMInitArgs*) args, &can_try_again);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3937
  if (result == JNI_OK) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3938
    JavaThread *thread = JavaThread::current();
22539
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3939
    assert(!thread->has_pending_exception(), "should have returned not OK");
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3940
    /* thread is thread_in_vm here */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3941
    *vm = (JavaVM *)(&main_vm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3942
    *(JNIEnv**)penv = thread->jni_environment();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3943
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3944
#if INCLUDE_JVMCI
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3945
    if (EnableJVMCI) {
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3946
      if (UseJVMCICompiler) {
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3947
        // JVMCI is initialized on a CompilerThread
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3948
        if (BootstrapJVMCI) {
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3949
          JavaThread* THREAD = thread;
47796
47629b00daa9 8187315: [JVMCI] hosted use of JVMCI can crash VM under -Xint
dnsimon
parents: 47765
diff changeset
  3950
          JVMCICompiler* compiler = JVMCICompiler::instance(true, CATCH);
38674
eacc567feae8 8156034: [JVMCI] Notify the jvmci compiler on completion of a bootstrap
never
parents: 38151
diff changeset
  3951
          compiler->bootstrap(THREAD);
eacc567feae8 8156034: [JVMCI] Notify the jvmci compiler on completion of a bootstrap
never
parents: 38151
diff changeset
  3952
          if (HAS_PENDING_EXCEPTION) {
eacc567feae8 8156034: [JVMCI] Notify the jvmci compiler on completion of a bootstrap
never
parents: 38151
diff changeset
  3953
            HandleMark hm;
eacc567feae8 8156034: [JVMCI] Notify the jvmci compiler on completion of a bootstrap
never
parents: 38151
diff changeset
  3954
            vm_exit_during_initialization(Handle(THREAD, PENDING_EXCEPTION));
eacc567feae8 8156034: [JVMCI] Notify the jvmci compiler on completion of a bootstrap
never
parents: 38151
diff changeset
  3955
          }
33160
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3956
        }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3957
      }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3958
    }
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3959
#endif
c59f1676d27e 8136421: JEP 243: Java-Level JVM Compiler Interface
twisti
parents: 32598
diff changeset
  3960
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3961
    // Notify JVMTI
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3962
    if (JvmtiExport::should_post_thread_life()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3963
       JvmtiExport::post_thread_start(thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3964
    }
11480
1bf714e8adb4 7115199: Add event tracing hooks and Java Flight Recorder infrastructure
phh
parents: 11247
diff changeset
  3965
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  3966
    post_thread_start_event(thread);
11480
1bf714e8adb4 7115199: Add event tracing hooks and Java Flight Recorder infrastructure
phh
parents: 11247
diff changeset
  3967
18683
a6418e038255 8015884: runThese crashed with SIGSEGV, hs_err has an error instead of stacktrace
dcubed
parents: 18680
diff changeset
  3968
#ifndef PRODUCT
a6418e038255 8015884: runThese crashed with SIGSEGV, hs_err has an error instead of stacktrace
dcubed
parents: 18680
diff changeset
  3969
    if (ReplayCompiles) ciReplay::replay(thread);
a6418e038255 8015884: runThese crashed with SIGSEGV, hs_err has an error instead of stacktrace
dcubed
parents: 18680
diff changeset
  3970
a6418e038255 8015884: runThese crashed with SIGSEGV, hs_err has an error instead of stacktrace
dcubed
parents: 18680
diff changeset
  3971
    // Some platforms (like Win*) need a wrapper around these test
a6418e038255 8015884: runThese crashed with SIGSEGV, hs_err has an error instead of stacktrace
dcubed
parents: 18680
diff changeset
  3972
    // functions in order to properly handle error conditions.
46589
f1c04490ded1 8182848: Some functions misplaced in debug.hpp
coleenp
parents: 46431
diff changeset
  3973
    VMError::test_error_handler();
18683
a6418e038255 8015884: runThese crashed with SIGSEGV, hs_err has an error instead of stacktrace
dcubed
parents: 18680
diff changeset
  3974
#endif
a6418e038255 8015884: runThese crashed with SIGSEGV, hs_err has an error instead of stacktrace
dcubed
parents: 18680
diff changeset
  3975
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3976
    // Since this is not a JVM_ENTRY we have to set the thread state manually before leaving.
54495
941db9c0b5b5 8222231: Clean up interfaceSupport.inline.hpp duplicated code
coleenp
parents: 54432
diff changeset
  3977
    ThreadStateTransition::transition(thread, _thread_in_vm, _thread_in_native);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3978
  } else {
22539
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3979
    // If create_vm exits because of a pending exception, exit with that
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3980
    // exception.  In the future when we figure out how to reclaim memory,
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3981
    // we may be able to exit with JNI_ERR and allow the calling application
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3982
    // to continue.
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3983
    if (Universe::is_fully_initialized()) {
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3984
      // otherwise no pending exception possible - VM will already have aborted
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3985
      JavaThread* THREAD = JavaThread::current();
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3986
      if (HAS_PENDING_EXCEPTION) {
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3987
        HandleMark hm;
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3988
        vm_exit_during_initialization(Handle(THREAD, PENDING_EXCEPTION));
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3989
      }
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3990
    }
a27fa687eca8 8028275: Metaspace ShrinkGrowTest causes fatal error if run with JFR
coleenp
parents: 22532
diff changeset
  3991
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3992
    if (can_try_again) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3993
      // reset safe_to_recreate_vm to 1 so that retrial would be possible
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3994
      safe_to_recreate_vm = 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3995
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3996
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3997
    // Creation failed. We must reset vm_created
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3998
    *vm = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  3999
    *(JNIEnv**)penv = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4000
    // reset vm_created last to avoid race condition. Use OrderAccess to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4001
    // control both compiler and architectural-based reordering.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4002
    OrderAccess::release_store(&vm_created, 0);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4003
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4004
33600
922600753f71 8139801: Error message from validation check has wrong order on Windows
sangheki
parents: 33576
diff changeset
  4005
  // Flush stdout and stderr before exit.
922600753f71 8139801: Error message from validation check has wrong order on Windows
sangheki
parents: 33576
diff changeset
  4006
  fflush(stdout);
922600753f71 8139801: Error message from validation check has wrong order on Windows
sangheki
parents: 33576
diff changeset
  4007
  fflush(stderr);
922600753f71 8139801: Error message from validation check has wrong order on Windows
sangheki
parents: 33576
diff changeset
  4008
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4009
  return result;
30143
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4010
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4011
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4012
30143
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4013
_JNI_IMPORT_OR_EXPORT_ jint JNICALL JNI_CreateJavaVM(JavaVM **vm, void **penv, void *args) {
46955
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4014
  jint result = JNI_ERR;
30143
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4015
  // On Windows, let CreateJavaVM run with SEH protection
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4016
#ifdef _WIN32
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4017
  __try {
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4018
#endif
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4019
    result = JNI_CreateJavaVM_inner(vm, penv, args);
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4020
#ifdef _WIN32
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4021
  } __except(topLevelExceptionFilter((_EXCEPTION_POINTERS*)_exception_info())) {
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4022
    // Nothing to do.
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4023
  }
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4024
#endif
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4025
  return result;
7e99f2b4bae5 8074860: Structured Exception Catcher missing around CreateJavaVM on Windows
stuefe
parents: 29081
diff changeset
  4026
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4027
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4028
_JNI_IMPORT_OR_EXPORT_ jint JNICALL JNI_GetCreatedJavaVMs(JavaVM **vm_buf, jsize bufLen, jsize *numVMs) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4029
  // See bug 4367188, the wrapper can sometimes cause VM crashes
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4030
  // JNIWrapper("GetCreatedJavaVMs");
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  4031
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4032
  HOTSPOT_JNI_GETCREATEDJAVAVMS_ENTRY((void **) vm_buf, bufLen, (uintptr_t *) numVMs);
22796
bb0ea482a99e 8034080: Remove the USDT1 dtrace code from Hotspot
sla
parents: 22795
diff changeset
  4033
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  4034
  if (vm_created == 1) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4035
    if (numVMs != NULL) *numVMs = 1;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4036
    if (bufLen > 0)     *vm_buf = (JavaVM *)(&main_vm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4037
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4038
    if (numVMs != NULL) *numVMs = 0;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4039
  }
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4040
  HOTSPOT_JNI_GETCREATEDJAVAVMS_RETURN(JNI_OK);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4041
  return JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4042
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4043
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4044
extern "C" {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4045
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  4046
DT_RETURN_MARK_DECL(DestroyJavaVM, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  4047
                    , HOTSPOT_JNI_DESTROYJAVAVM_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4048
46955
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4049
static jint JNICALL jni_DestroyJavaVM_inner(JavaVM *vm) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4050
  HOTSPOT_JNI_DESTROYJAVAVM_ENTRY(vm);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4051
  jint res = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4052
  DT_RETURN_MARK(DestroyJavaVM, jint, (const jint&)res);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4053
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  4054
  if (vm_created == 0) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4055
    res = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4056
    return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4057
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4058
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4059
  JNIWrapper("DestroyJavaVM");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4060
  JNIEnv *env;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4061
  JavaVMAttachArgs destroyargs;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4062
  destroyargs.version = CurrentVersion;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4063
  destroyargs.name = (char *)"DestroyJavaVM";
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4064
  destroyargs.group = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4065
  res = vm->AttachCurrentThread((void **)&env, (void *)&destroyargs);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4066
  if (res != JNI_OK) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4067
    return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4068
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4069
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4070
  // Since this is not a JVM_ENTRY we have to set the thread state manually before entering.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4071
  JavaThread* thread = JavaThread::current();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4072
  ThreadStateTransition::transition_from_native(thread, _thread_in_vm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4073
  if (Threads::destroy_vm()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4074
    // Should not change thread state, VM is gone
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  4075
    vm_created = 0;
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4076
    res = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4077
    return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4078
  } else {
54495
941db9c0b5b5 8222231: Clean up interfaceSupport.inline.hpp duplicated code
coleenp
parents: 54432
diff changeset
  4079
    ThreadStateTransition::transition(thread, _thread_in_vm, _thread_in_native);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4080
    res = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4081
    return res;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4082
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4083
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4084
46955
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4085
jint JNICALL jni_DestroyJavaVM(JavaVM *vm) {
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4086
  jint result = JNI_ERR;
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4087
  // On Windows, we need SEH protection
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4088
#ifdef _WIN32
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4089
  __try {
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4090
#endif
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4091
    result = jni_DestroyJavaVM_inner(vm);
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4092
#ifdef _WIN32
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4093
  } __except(topLevelExceptionFilter((_EXCEPTION_POINTERS*)_exception_info())) {
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4094
    // Nothing to do.
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4095
  }
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4096
#endif
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4097
  return result;
c5a455ec08c0 8186199: [windows] JNI_DestroyJavaVM not covered by SEH
stuefe
parents: 46589
diff changeset
  4098
}
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4099
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4100
static jint attach_current_thread(JavaVM *vm, void **penv, void *_args, bool daemon) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4101
  JavaVMAttachArgs *args = (JavaVMAttachArgs *) _args;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4102
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4103
  // Check below commented out from JDK1.2fcs as well
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4104
  /*
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4105
  if (args && (args->version != JNI_VERSION_1_1 || args->version != JNI_VERSION_1_2)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4106
    return JNI_EVERSION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4107
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4108
  */
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4109
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 34317
diff changeset
  4110
  Thread* t = Thread::current_or_null();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4111
  if (t != NULL) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4112
    // If the thread has been attached this operation is a no-op
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4113
    *(JNIEnv**)penv = ((JavaThread*) t)->jni_environment();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4114
    return JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4115
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4116
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4117
  // Create a thread and mark it as attaching so it will be skipped by the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4118
  // ThreadsListEnumerator - see CR 6404306
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4119
  JavaThread* thread = new JavaThread(true);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4120
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4121
  // Set correct safepoint info. The thread is going to call into Java when
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4122
  // initializing the Java level thread object. Hence, the correct state must
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4123
  // be set in order for the Safepoint code to deal with it correctly.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4124
  thread->set_thread_state(_thread_in_vm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4125
  thread->record_stack_base_and_size();
52302
912b79d983d9 8212173: Thread._stack_base/_stack_size initialized too late for new threads
stuefe
parents: 51996
diff changeset
  4126
  thread->register_thread_stack_with_NMT();
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 34317
diff changeset
  4127
  thread->initialize_thread_current();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4128
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4129
  if (!os::create_attached_thread(thread)) {
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47998
diff changeset
  4130
    thread->smr_delete();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4131
    return JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4132
  }
5041
5bce37d77dde 6914050: jvm assertion "guard pages must be in use" in -Xcomp mode
coleenp
parents: 4571
diff changeset
  4133
  // Enable stack overflow checks
5bce37d77dde 6914050: jvm assertion "guard pages must be in use" in -Xcomp mode
coleenp
parents: 4571
diff changeset
  4134
  thread->create_stack_guard_pages();
5bce37d77dde 6914050: jvm assertion "guard pages must be in use" in -Xcomp mode
coleenp
parents: 4571
diff changeset
  4135
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4136
  thread->initialize_tlab();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4137
6176
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5547
diff changeset
  4138
  thread->cache_global_variables();
4d9030fe341f 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 5547
diff changeset
  4139
57699
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57570
diff changeset
  4140
  // This thread will not do a safepoint check, since it has
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4141
  // not been added to the Thread list yet.
57699
4aea554692aa 8226228: Make Threads_lock an always safepoint checked lock.
rehn
parents: 57570
diff changeset
  4142
  { MutexLocker ml(Threads_lock);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4143
    // This must be inside this lock in order to get FullGCALot to work properly, i.e., to
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4144
    // avoid this thread trying to do a GC before it is added to the thread-list
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4145
    thread->set_active_handles(JNIHandleBlock::allocate_block());
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4146
    Threads::add(thread, daemon);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4147
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4148
  // Create thread group and name info from attach arguments
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4149
  oop group = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4150
  char* thread_name = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4151
  if (args != NULL && Threads::is_supported_jni_version(args->version)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4152
    group = JNIHandles::resolve(args->group);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4153
    thread_name = args->name; // may be NULL
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4154
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4155
  if (group == NULL) group = Universe::main_thread_group();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4156
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4157
  // Create Java level thread object and attach it to this thread
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4158
  bool attach_failed = false;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4159
  {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4160
    EXCEPTION_MARK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4161
    HandleMark hm(THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4162
    Handle thread_group(THREAD, group);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4163
    thread->allocate_threadObj(thread_group, thread_name, daemon, THREAD);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4164
    if (HAS_PENDING_EXCEPTION) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4165
      CLEAR_PENDING_EXCEPTION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4166
      // cleanup outside the handle mark.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4167
      attach_failed = true;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4168
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4169
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4170
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4171
  if (attach_failed) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4172
    // Added missing cleanup
54416
b788c494aa46 8218483: Crash in "assert(_daemon_threads_count->get_value() > daemon_count) failed: thread count mismatch 5 : 5"
dholmes
parents: 53895
diff changeset
  4173
    thread->cleanup_failed_attach_current_thread(daemon);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4174
    return JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4175
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4176
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4177
  // mark the thread as no longer attaching
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4178
  // this uses a fence to push the change through so we don't have
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4179
  // to regrab the threads_lock
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  4180
  thread->set_done_attaching_via_jni();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4181
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4182
  // Set java thread status.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4183
  java_lang_Thread::set_thread_status(thread->threadObj(),
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4184
              java_lang_Thread::RUNNABLE);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4185
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4186
  // Notify the debugger
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4187
  if (JvmtiExport::should_post_thread_life()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4188
    JvmtiExport::post_thread_start(thread);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4189
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4190
50113
caf115bb98ad 8199712: Flight Recorder
egahlin
parents: 49982
diff changeset
  4191
  post_thread_start_event(thread);
11480
1bf714e8adb4 7115199: Add event tracing hooks and Java Flight Recorder infrastructure
phh
parents: 11247
diff changeset
  4192
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4193
  *(JNIEnv**)penv = thread->jni_environment();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4194
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4195
  // Now leaving the VM, so change thread_state. This is normally automatically taken care
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4196
  // of in the JVM_ENTRY. But in this situation we have to do it manually. Notice, that by
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4197
  // using ThreadStateTransition::transition, we do a callback to the safepoint code if
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4198
  // needed.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4199
54495
941db9c0b5b5 8222231: Clean up interfaceSupport.inline.hpp duplicated code
coleenp
parents: 54432
diff changeset
  4200
  ThreadStateTransition::transition(thread, _thread_in_vm, _thread_in_native);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4201
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4202
  // Perform any platform dependent FPU setup
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4203
  os::setup_fpu();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4204
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4205
  return JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4206
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4207
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4208
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4209
jint JNICALL jni_AttachCurrentThread(JavaVM *vm, void **penv, void *_args) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4210
  HOTSPOT_JNI_ATTACHCURRENTTHREAD_ENTRY(vm, penv, _args);
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  4211
  if (vm_created == 0) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4212
  HOTSPOT_JNI_ATTACHCURRENTTHREAD_RETURN((uint32_t) JNI_ERR);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4213
    return JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4214
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4215
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4216
  JNIWrapper("AttachCurrentThread");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4217
  jint ret = attach_current_thread(vm, penv, _args, false);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4218
  HOTSPOT_JNI_ATTACHCURRENTTHREAD_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4219
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4220
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4221
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4222
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4223
jint JNICALL jni_DetachCurrentThread(JavaVM *vm)  {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4224
  HOTSPOT_JNI_DETACHCURRENTTHREAD_ENTRY(vm);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4225
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4226
  JNIWrapper("DetachCurrentThread");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4227
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 34317
diff changeset
  4228
  // If the thread has already been detached the operation is a no-op
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 34317
diff changeset
  4229
  if (Thread::current_or_null() == NULL) {
49362
2085742233ed 8199012: SEGV in jni_DetachCurrentThread during VM shutdown
dholmes
parents: 49359
diff changeset
  4230
    HOTSPOT_JNI_DETACHCURRENTTHREAD_RETURN(JNI_OK);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4231
    return JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4232
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4233
49362
2085742233ed 8199012: SEGV in jni_DetachCurrentThread during VM shutdown
dholmes
parents: 49359
diff changeset
  4234
  VM_Exit::block_if_vm_exited();
2085742233ed 8199012: SEGV in jni_DetachCurrentThread during VM shutdown
dholmes
parents: 49359
diff changeset
  4235
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4236
  JavaThread* thread = JavaThread::current();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4237
  if (thread->has_last_Java_frame()) {
49362
2085742233ed 8199012: SEGV in jni_DetachCurrentThread during VM shutdown
dholmes
parents: 49359
diff changeset
  4238
    HOTSPOT_JNI_DETACHCURRENTTHREAD_RETURN((uint32_t) JNI_ERR);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4239
    // Can't detach a thread that's running java, that can't work.
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4240
    return JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4241
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4242
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4243
  // Safepoint support. Have to do call-back to safepoint code, if in the
49362
2085742233ed 8199012: SEGV in jni_DetachCurrentThread during VM shutdown
dholmes
parents: 49359
diff changeset
  4244
  // middle of a safepoint operation
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4245
  ThreadStateTransition::transition_from_native(thread, _thread_in_vm);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4246
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4247
  // XXX: Note that JavaThread::exit() call below removes the guards on the
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4248
  // stack pages set up via enable_stack_{red,yellow}_zone() calls
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4249
  // above in jni_AttachCurrentThread. Unfortunately, while the setting
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4250
  // of the guards is visible in jni_AttachCurrentThread above,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4251
  // the removal of the guards is buried below in JavaThread::exit()
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4252
  // here. The abstraction should be more symmetrically either exposed
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4253
  // or hidden (e.g. it could probably be hidden in the same
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4254
  // (platform-dependent) methods where we do alternate stack
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4255
  // maintenance work?)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4256
  thread->exit(false, JavaThread::jni_detach);
48105
8d15b1369c7a 8167108: inconsistent handling of SR_lock can lead to crashes
dcubed
parents: 47998
diff changeset
  4257
  thread->smr_delete();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4258
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4259
  HOTSPOT_JNI_DETACHCURRENTTHREAD_RETURN(JNI_OK);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4260
  return JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4261
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4262
10739
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  4263
DT_RETURN_MARK_DECL(GetEnv, jint
91935236600e 7098194: integrate macosx-port changes
dcubed
parents: 10565
diff changeset
  4264
                    , HOTSPOT_JNI_GETENV_RETURN(_ret_ref));
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4265
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4266
jint JNICALL jni_GetEnv(JavaVM *vm, void **penv, jint version) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4267
  HOTSPOT_JNI_GETENV_ENTRY(vm, penv, version);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4268
  jint ret = JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4269
  DT_RETURN_MARK(GetEnv, jint, (const jint&)ret);
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4270
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  4271
  if (vm_created == 0) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4272
    *penv = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4273
    ret = JNI_EDETACHED;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4274
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4275
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4276
11480
1bf714e8adb4 7115199: Add event tracing hooks and Java Flight Recorder infrastructure
phh
parents: 11247
diff changeset
  4277
  if (JniExportedInterface::GetExportedInterface(vm, penv, version, &ret)) {
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4278
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4279
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4280
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4281
#ifndef JVMPI_VERSION_1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4282
// need these in order to be polite about older agents
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4283
#define JVMPI_VERSION_1   ((jint)0x10000001)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4284
#define JVMPI_VERSION_1_1 ((jint)0x10000002)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4285
#define JVMPI_VERSION_1_2 ((jint)0x10000003)
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4286
#endif // !JVMPI_VERSION_1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4287
34633
2a6c7c7b30a7 8132510: Replace ThreadLocalStorage with compiler/language-based thread-local variables
dholmes
parents: 34317
diff changeset
  4288
  Thread* thread = Thread::current_or_null();
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4289
  if (thread != NULL && thread->is_Java_thread()) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4290
    if (Threads::is_supported_jni_version_including_1_1(version)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4291
      *(JNIEnv**)penv = ((JavaThread*) thread)->jni_environment();
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4292
      ret = JNI_OK;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4293
      return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4294
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4295
    } else if (version == JVMPI_VERSION_1 ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4296
               version == JVMPI_VERSION_1_1 ||
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4297
               version == JVMPI_VERSION_1_2) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4298
      tty->print_cr("ERROR: JVMPI, an experimental interface, is no longer supported.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4299
      tty->print_cr("Please use the supported interface: the JVM Tool Interface (JVM TI).");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4300
      ret = JNI_EVERSION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4301
      return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4302
    } else if (JvmtiExport::is_jvmdi_version(version)) {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4303
      tty->print_cr("FATAL ERROR: JVMDI is no longer supported.");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4304
      tty->print_cr("Please use the supported interface: the JVM Tool Interface (JVM TI).");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4305
      ret = JNI_EVERSION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4306
      return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4307
    } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4308
      *penv = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4309
      ret = JNI_EVERSION;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4310
      return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4311
    }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4312
  } else {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4313
    *penv = NULL;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4314
    ret = JNI_EDETACHED;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4315
    return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4316
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4317
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4318
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4319
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4320
jint JNICALL jni_AttachCurrentThreadAsDaemon(JavaVM *vm, void **penv, void *_args) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4321
  HOTSPOT_JNI_ATTACHCURRENTTHREADASDAEMON_ENTRY(vm, penv, _args);
47765
b7c7428eaab9 8189610: Reconcile jvm.h and all jvm_md.h between java.base and hotspot
coleenp
parents: 47662
diff changeset
  4322
  if (vm_created == 0) {
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4323
  HOTSPOT_JNI_ATTACHCURRENTTHREADASDAEMON_RETURN((uint32_t) JNI_ERR);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4324
    return JNI_ERR;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4325
  }
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4326
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4327
  JNIWrapper("AttachCurrentThreadAsDaemon");
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4328
  jint ret = attach_current_thread(vm, penv, _args, true);
22520
b9e88eed82d7 8030812: Change the solaris DTrace implementation to use USDT2 instead of USDT1
sla
parents: 22190
diff changeset
  4329
  HOTSPOT_JNI_ATTACHCURRENTTHREADASDAEMON_RETURN(ret);
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4330
  return ret;
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4331
}
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4332
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4333
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4334
} // End extern "C"
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4335
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4336
const struct JNIInvokeInterface_ jni_InvokeInterface = {
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4337
    NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4338
    NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4339
    NULL,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4340
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4341
    jni_DestroyJavaVM,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4342
    jni_AttachCurrentThread,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4343
    jni_DetachCurrentThread,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4344
    jni_GetEnv,
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4345
    jni_AttachCurrentThreadAsDaemon
489c9b5090e2 Initial load
duke
parents:
diff changeset
  4346
};