Mercurial > hg > truffle
annotate src/share/vm/classfile/vmSymbols.hpp @ 17084:26f5733fb645
Fix the endianess issue, when using JSR/RET instruction and deoptimization happens in this subroutine
author | Stefan Anzinger <stefan.anzinger@oracle.com> |
---|---|
date | Tue, 09 Sep 2014 12:15:29 -0700 |
parents | 6ea6d4c260c8 |
children | 0563b652c052 |
rev | line source |
---|---|
0 | 1 /* |
7951 | 2 * Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved. |
0 | 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 * | |
5 * This code is free software; you can redistribute it and/or modify it | |
6 * under the terms of the GNU General Public License version 2 only, as | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * This code is distributed in the hope that it will be useful, but WITHOUT | |
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 * version 2 for more details (a copy is included in the LICENSE file that | |
13 * accompanied this code). | |
14 * | |
15 * You should have received a copy of the GNU General Public License version | |
16 * 2 along with this work; if not, write to the Free Software Foundation, | |
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 * | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1507
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1507
diff
changeset
|
20 * or visit www.oracle.com if you need additional information or have any |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1507
diff
changeset
|
21 * questions. |
0 | 22 * |
23 */ | |
24 | |
1972 | 25 #ifndef SHARE_VM_CLASSFILE_VMSYMBOLS_HPP |
26 #define SHARE_VM_CLASSFILE_VMSYMBOLS_HPP | |
27 | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
28 #include "oops/symbol.hpp" |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
29 #include "memory/iterator.hpp" |
6006
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
30 #include "trace/traceMacros.hpp" |
1972 | 31 |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
32 // The class vmSymbols is a name space for fast lookup of |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
33 // symbols commonly used in the VM. |
0 | 34 // |
35 // Sample usage: | |
36 // | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
37 // Symbol* obj = vmSymbols::java_lang_Object(); |
0 | 38 |
39 | |
40 // Useful sub-macros exported by this header file: | |
41 | |
42 #define VM_SYMBOL_ENUM_NAME(name) name##_enum | |
43 #define VM_INTRINSIC_IGNORE(id, class, name, sig, flags) /*ignored*/ | |
44 #define VM_SYMBOL_IGNORE(id, name) /*ignored*/ | |
45 #define VM_ALIAS_IGNORE(id, id2) /*ignored*/ | |
46 | |
47 | |
48 // Mapping function names to values. New entries should be added below. | |
49 | |
50 #define VM_SYMBOLS_DO(template, do_alias) \ | |
51 /* commonly used class names */ \ | |
52 template(java_lang_System, "java/lang/System") \ | |
53 template(java_lang_Object, "java/lang/Object") \ | |
54 template(java_lang_Class, "java/lang/Class") \ | |
55 template(java_lang_String, "java/lang/String") \ | |
56 template(java_lang_Thread, "java/lang/Thread") \ | |
57 template(java_lang_ThreadGroup, "java/lang/ThreadGroup") \ | |
58 template(java_lang_Cloneable, "java/lang/Cloneable") \ | |
59 template(java_lang_Throwable, "java/lang/Throwable") \ | |
60 template(java_lang_ClassLoader, "java/lang/ClassLoader") \ | |
61 template(java_lang_ClassLoader_NativeLibrary, "java/lang/ClassLoader\x024NativeLibrary") \ | |
62 template(java_lang_ThreadDeath, "java/lang/ThreadDeath") \ | |
63 template(java_lang_Boolean, "java/lang/Boolean") \ | |
64 template(java_lang_Character, "java/lang/Character") \ | |
17
ff5961f4c095
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
0
diff
changeset
|
65 template(java_lang_Character_CharacterCache, "java/lang/Character$CharacterCache") \ |
0 | 66 template(java_lang_Float, "java/lang/Float") \ |
67 template(java_lang_Double, "java/lang/Double") \ | |
68 template(java_lang_Byte, "java/lang/Byte") \ | |
10278 | 69 template(java_lang_Byte_ByteCache, "java/lang/Byte$ByteCache") \ |
0 | 70 template(java_lang_Short, "java/lang/Short") \ |
17
ff5961f4c095
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
0
diff
changeset
|
71 template(java_lang_Short_ShortCache, "java/lang/Short$ShortCache") \ |
0 | 72 template(java_lang_Integer, "java/lang/Integer") \ |
17
ff5961f4c095
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
0
diff
changeset
|
73 template(java_lang_Integer_IntegerCache, "java/lang/Integer$IntegerCache") \ |
0 | 74 template(java_lang_Long, "java/lang/Long") \ |
17
ff5961f4c095
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
0
diff
changeset
|
75 template(java_lang_Long_LongCache, "java/lang/Long$LongCache") \ |
0 | 76 template(java_lang_Shutdown, "java/lang/Shutdown") \ |
77 template(java_lang_ref_Reference, "java/lang/ref/Reference") \ | |
78 template(java_lang_ref_SoftReference, "java/lang/ref/SoftReference") \ | |
79 template(java_lang_ref_WeakReference, "java/lang/ref/WeakReference") \ | |
80 template(java_lang_ref_FinalReference, "java/lang/ref/FinalReference") \ | |
81 template(java_lang_ref_PhantomReference, "java/lang/ref/PhantomReference") \ | |
82 template(java_lang_ref_Finalizer, "java/lang/ref/Finalizer") \ | |
83 template(java_lang_reflect_AccessibleObject, "java/lang/reflect/AccessibleObject") \ | |
84 template(java_lang_reflect_Method, "java/lang/reflect/Method") \ | |
85 template(java_lang_reflect_Constructor, "java/lang/reflect/Constructor") \ | |
86 template(java_lang_reflect_Field, "java/lang/reflect/Field") \ | |
7462
ade95d680b42
8004728: Add hotspot support for parameter reflection
coleenp
parents:
7458
diff
changeset
|
87 template(java_lang_reflect_Parameter, "java/lang/reflect/Parameter") \ |
0 | 88 template(java_lang_reflect_Array, "java/lang/reflect/Array") \ |
89 template(java_lang_StringBuffer, "java/lang/StringBuffer") \ | |
1080
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
90 template(java_lang_StringBuilder, "java/lang/StringBuilder") \ |
0 | 91 template(java_lang_CharSequence, "java/lang/CharSequence") \ |
8866
16885e702c88
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
7955
diff
changeset
|
92 template(java_lang_SecurityManager, "java/lang/SecurityManager") \ |
0 | 93 template(java_security_AccessControlContext, "java/security/AccessControlContext") \ |
94 template(java_security_ProtectionDomain, "java/security/ProtectionDomain") \ | |
11010 | 95 template(impliesCreateAccessControlContext_name, "impliesCreateAccessControlContext") \ |
0 | 96 template(java_io_OutputStream, "java/io/OutputStream") \ |
97 template(java_io_Reader, "java/io/Reader") \ | |
98 template(java_io_BufferedReader, "java/io/BufferedReader") \ | |
99 template(java_io_FileInputStream, "java/io/FileInputStream") \ | |
100 template(java_io_ByteArrayInputStream, "java/io/ByteArrayInputStream") \ | |
101 template(java_io_Serializable, "java/io/Serializable") \ | |
102 template(java_util_Arrays, "java/util/Arrays") \ | |
103 template(java_util_Properties, "java/util/Properties") \ | |
104 template(java_util_Vector, "java/util/Vector") \ | |
105 template(java_util_AbstractList, "java/util/AbstractList") \ | |
106 template(java_util_Hashtable, "java/util/Hashtable") \ | |
107 template(java_lang_Compiler, "java/lang/Compiler") \ | |
108 template(sun_misc_Signal, "sun/misc/Signal") \ | |
109 template(java_lang_AssertionStatusDirectives, "java/lang/AssertionStatusDirectives") \ | |
110 template(getBootClassPathEntryForClass_name, "getBootClassPathEntryForClass") \ | |
2129
8f8dfba37802
6994753: Implement optional hook to a Java method at VM startup.
kevinw
parents:
2011
diff
changeset
|
111 template(sun_misc_PostVMInitHook, "sun/misc/PostVMInitHook") \ |
6894 | 112 template(sun_misc_Launcher_ExtClassLoader, "sun/misc/Launcher$ExtClassLoader") \ |
0 | 113 \ |
6181 | 114 /* Java runtime version access */ \ |
115 template(sun_misc_Version, "sun/misc/Version") \ | |
116 template(java_runtime_name_name, "java_runtime_name") \ | |
6921
a1b8cf9cf970
8002078: hs_err_pid file should report full JDK version string
sla
parents:
6847
diff
changeset
|
117 template(java_runtime_version_name, "java_runtime_version") \ |
6181 | 118 \ |
0 | 119 /* class file format tags */ \ |
120 template(tag_source_file, "SourceFile") \ | |
121 template(tag_inner_classes, "InnerClasses") \ | |
122 template(tag_constant_value, "ConstantValue") \ | |
123 template(tag_code, "Code") \ | |
124 template(tag_exceptions, "Exceptions") \ | |
125 template(tag_line_number_table, "LineNumberTable") \ | |
126 template(tag_local_variable_table, "LocalVariableTable") \ | |
127 template(tag_local_variable_type_table, "LocalVariableTypeTable") \ | |
7462
ade95d680b42
8004728: Add hotspot support for parameter reflection
coleenp
parents:
7458
diff
changeset
|
128 template(tag_method_parameters, "MethodParameters") \ |
0 | 129 template(tag_stack_map_table, "StackMapTable") \ |
130 template(tag_synthetic, "Synthetic") \ | |
131 template(tag_deprecated, "Deprecated") \ | |
132 template(tag_source_debug_extension, "SourceDebugExtension") \ | |
133 template(tag_signature, "Signature") \ | |
134 template(tag_runtime_visible_annotations, "RuntimeVisibleAnnotations") \ | |
135 template(tag_runtime_invisible_annotations, "RuntimeInvisibleAnnotations") \ | |
136 template(tag_runtime_visible_parameter_annotations, "RuntimeVisibleParameterAnnotations") \ | |
137 template(tag_runtime_invisible_parameter_annotations,"RuntimeInvisibleParameterAnnotations") \ | |
138 template(tag_annotation_default, "AnnotationDefault") \ | |
7457
35431a769282
8004823: Add VM support for type annotation reflection
stefank
parents:
6935
diff
changeset
|
139 template(tag_runtime_visible_type_annotations, "RuntimeVisibleTypeAnnotations") \ |
35431a769282
8004823: Add VM support for type annotation reflection
stefank
parents:
6935
diff
changeset
|
140 template(tag_runtime_invisible_type_annotations, "RuntimeInvisibleTypeAnnotations") \ |
0 | 141 template(tag_enclosing_method, "EnclosingMethod") \ |
2011
dad31fc330cd
7001379: bootstrap method data needs to be moved from constant pool to a classfile attribute
jrose
parents:
1972
diff
changeset
|
142 template(tag_bootstrap_methods, "BootstrapMethods") \ |
0 | 143 \ |
144 /* exception klasses: at least all exceptions thrown by the VM have entries here */ \ | |
145 template(java_lang_ArithmeticException, "java/lang/ArithmeticException") \ | |
146 template(java_lang_ArrayIndexOutOfBoundsException, "java/lang/ArrayIndexOutOfBoundsException") \ | |
147 template(java_lang_ArrayStoreException, "java/lang/ArrayStoreException") \ | |
148 template(java_lang_ClassCastException, "java/lang/ClassCastException") \ | |
149 template(java_lang_ClassNotFoundException, "java/lang/ClassNotFoundException") \ | |
150 template(java_lang_CloneNotSupportedException, "java/lang/CloneNotSupportedException") \ | |
151 template(java_lang_IllegalAccessException, "java/lang/IllegalAccessException") \ | |
152 template(java_lang_IllegalArgumentException, "java/lang/IllegalArgumentException") \ | |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1396
diff
changeset
|
153 template(java_lang_IllegalStateException, "java/lang/IllegalStateException") \ |
0 | 154 template(java_lang_IllegalMonitorStateException, "java/lang/IllegalMonitorStateException") \ |
155 template(java_lang_IllegalThreadStateException, "java/lang/IllegalThreadStateException") \ | |
156 template(java_lang_IndexOutOfBoundsException, "java/lang/IndexOutOfBoundsException") \ | |
157 template(java_lang_InstantiationException, "java/lang/InstantiationException") \ | |
158 template(java_lang_InstantiationError, "java/lang/InstantiationError") \ | |
159 template(java_lang_InterruptedException, "java/lang/InterruptedException") \ | |
3417
ba550512d3b2
7049415: Failure of resolution of sym.reference to the c.s.s. should be wrapped in BootstrapMethodError
jrose
parents:
3373
diff
changeset
|
160 template(java_lang_BootstrapMethodError, "java/lang/BootstrapMethodError") \ |
0 | 161 template(java_lang_LinkageError, "java/lang/LinkageError") \ |
162 template(java_lang_NegativeArraySizeException, "java/lang/NegativeArraySizeException") \ | |
163 template(java_lang_NoSuchFieldException, "java/lang/NoSuchFieldException") \ | |
164 template(java_lang_NoSuchMethodException, "java/lang/NoSuchMethodException") \ | |
165 template(java_lang_NullPointerException, "java/lang/NullPointerException") \ | |
166 template(java_lang_StringIndexOutOfBoundsException, "java/lang/StringIndexOutOfBoundsException")\ | |
6271
93c71eb28866
7188911: nightly failures after JSR 292 lazy method handle update (round 2)
twisti
parents:
6266
diff
changeset
|
167 template(java_lang_UnsupportedOperationException, "java/lang/UnsupportedOperationException") \ |
0 | 168 template(java_lang_InvalidClassException, "java/lang/InvalidClassException") \ |
169 template(java_lang_reflect_InvocationTargetException, "java/lang/reflect/InvocationTargetException") \ | |
170 template(java_lang_Exception, "java/lang/Exception") \ | |
171 template(java_lang_RuntimeException, "java/lang/RuntimeException") \ | |
172 template(java_io_IOException, "java/io/IOException") \ | |
173 template(java_security_PrivilegedActionException, "java/security/PrivilegedActionException") \ | |
174 \ | |
175 /* error klasses: at least all errors thrown by the VM have entries here */ \ | |
176 template(java_lang_AbstractMethodError, "java/lang/AbstractMethodError") \ | |
177 template(java_lang_ClassCircularityError, "java/lang/ClassCircularityError") \ | |
178 template(java_lang_ClassFormatError, "java/lang/ClassFormatError") \ | |
179 template(java_lang_UnsupportedClassVersionError, "java/lang/UnsupportedClassVersionError") \ | |
180 template(java_lang_Error, "java/lang/Error") \ | |
181 template(java_lang_ExceptionInInitializerError, "java/lang/ExceptionInInitializerError") \ | |
182 template(java_lang_IllegalAccessError, "java/lang/IllegalAccessError") \ | |
183 template(java_lang_IncompatibleClassChangeError, "java/lang/IncompatibleClassChangeError") \ | |
184 template(java_lang_InternalError, "java/lang/InternalError") \ | |
185 template(java_lang_NoClassDefFoundError, "java/lang/NoClassDefFoundError") \ | |
186 template(java_lang_NoSuchFieldError, "java/lang/NoSuchFieldError") \ | |
187 template(java_lang_NoSuchMethodError, "java/lang/NoSuchMethodError") \ | |
188 template(java_lang_OutOfMemoryError, "java/lang/OutOfMemoryError") \ | |
189 template(java_lang_UnsatisfiedLinkError, "java/lang/UnsatisfiedLinkError") \ | |
190 template(java_lang_VerifyError, "java/lang/VerifyError") \ | |
191 template(java_lang_SecurityException, "java/lang/SecurityException") \ | |
192 template(java_lang_VirtualMachineError, "java/lang/VirtualMachineError") \ | |
193 template(java_lang_StackOverflowError, "java/lang/StackOverflowError") \ | |
194 template(java_lang_StackTraceElement, "java/lang/StackTraceElement") \ | |
7587 | 195 \ |
196 /* Concurrency support */ \ | |
0 | 197 template(java_util_concurrent_locks_AbstractOwnableSynchronizer, "java/util/concurrent/locks/AbstractOwnableSynchronizer") \ |
7587 | 198 template(sun_misc_Contended_signature, "Lsun/misc/Contended;") \ |
0 | 199 \ |
200 /* class symbols needed by intrinsics */ \ | |
201 VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, template, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_ALIAS_IGNORE) \ | |
202 \ | |
203 /* Support for reflection based on dynamic bytecode generation (JDK 1.4 and above) */ \ | |
204 \ | |
205 template(sun_reflect_FieldInfo, "sun/reflect/FieldInfo") \ | |
206 template(sun_reflect_MethodInfo, "sun/reflect/MethodInfo") \ | |
207 template(sun_reflect_MagicAccessorImpl, "sun/reflect/MagicAccessorImpl") \ | |
208 template(sun_reflect_MethodAccessorImpl, "sun/reflect/MethodAccessorImpl") \ | |
209 template(sun_reflect_ConstructorAccessorImpl, "sun/reflect/ConstructorAccessorImpl") \ | |
210 template(sun_reflect_SerializationConstructorAccessorImpl, "sun/reflect/SerializationConstructorAccessorImpl") \ | |
211 template(sun_reflect_DelegatingClassLoader, "sun/reflect/DelegatingClassLoader") \ | |
212 template(sun_reflect_Reflection, "sun/reflect/Reflection") \ | |
8866
16885e702c88
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
7955
diff
changeset
|
213 template(sun_reflect_CallerSensitive, "sun/reflect/CallerSensitive") \ |
16885e702c88
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
7955
diff
changeset
|
214 template(sun_reflect_CallerSensitive_signature, "Lsun/reflect/CallerSensitive;") \ |
0 | 215 template(checkedExceptions_name, "checkedExceptions") \ |
216 template(clazz_name, "clazz") \ | |
217 template(exceptionTypes_name, "exceptionTypes") \ | |
218 template(modifiers_name, "modifiers") \ | |
219 template(newConstructor_name, "newConstructor") \ | |
220 template(newConstructor_signature, "(Lsun/reflect/MethodInfo;)Ljava/lang/reflect/Constructor;") \ | |
221 template(newField_name, "newField") \ | |
222 template(newField_signature, "(Lsun/reflect/FieldInfo;)Ljava/lang/reflect/Field;") \ | |
223 template(newMethod_name, "newMethod") \ | |
224 template(newMethod_signature, "(Lsun/reflect/MethodInfo;)Ljava/lang/reflect/Method;") \ | |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
225 template(invokeBasic_name, "invokeBasic") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
226 template(linkToVirtual_name, "linkToVirtual") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
227 template(linkToStatic_name, "linkToStatic") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
228 template(linkToSpecial_name, "linkToSpecial") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
229 template(linkToInterface_name, "linkToInterface") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
230 template(compiledLambdaForm_name, "<compiledLambdaForm>") /*fake name*/ \ |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1396
diff
changeset
|
231 template(star_name, "*") /*not really a name*/ \ |
0 | 232 template(invoke_name, "invoke") \ |
233 template(override_name, "override") \ | |
234 template(parameterTypes_name, "parameterTypes") \ | |
235 template(returnType_name, "returnType") \ | |
236 template(signature_name, "signature") \ | |
237 template(slot_name, "slot") \ | |
3905
c26de9aef2ed
7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents:
3900
diff
changeset
|
238 template(selectAlternative_name, "selectAlternative") \ |
0 | 239 \ |
240 /* Support for annotations (JDK 1.5 and above) */ \ | |
241 \ | |
242 template(annotations_name, "annotations") \ | |
7462
ade95d680b42
8004728: Add hotspot support for parameter reflection
coleenp
parents:
7458
diff
changeset
|
243 template(index_name, "index") \ |
ade95d680b42
8004728: Add hotspot support for parameter reflection
coleenp
parents:
7458
diff
changeset
|
244 template(executable_name, "executable") \ |
0 | 245 template(parameter_annotations_name, "parameterAnnotations") \ |
246 template(annotation_default_name, "annotationDefault") \ | |
247 template(sun_reflect_ConstantPool, "sun/reflect/ConstantPool") \ | |
6725
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6271
diff
changeset
|
248 template(ConstantPool_name, "constantPoolOop") \ |
0 | 249 template(sun_reflect_UnsafeStaticFieldAccessorImpl, "sun/reflect/UnsafeStaticFieldAccessorImpl")\ |
250 template(base_name, "base") \ | |
7457
35431a769282
8004823: Add VM support for type annotation reflection
stefank
parents:
6935
diff
changeset
|
251 /* Type Annotations (JDK 8 and above) */ \ |
35431a769282
8004823: Add VM support for type annotation reflection
stefank
parents:
6935
diff
changeset
|
252 template(type_annotations_name, "typeAnnotations") \ |
35431a769282
8004823: Add VM support for type annotation reflection
stefank
parents:
6935
diff
changeset
|
253 \ |
0 | 254 \ |
710 | 255 /* Support for JSR 292 & invokedynamic (JDK 1.7 and above) */ \ |
2357
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
256 template(java_lang_invoke_CallSite, "java/lang/invoke/CallSite") \ |
3852
fdb992d83a87
7071653: JSR 292: call site change notification should be pushed not pulled
twisti
parents:
3417
diff
changeset
|
257 template(java_lang_invoke_ConstantCallSite, "java/lang/invoke/ConstantCallSite") \ |
12010
ca0165daa6ec
7187554: JSR 292: JVMTI PopFrame needs to handle appendix arguments
sspitsyn
parents:
11154
diff
changeset
|
258 template(java_lang_invoke_DirectMethodHandle, "java/lang/invoke/DirectMethodHandle") \ |
3852
fdb992d83a87
7071653: JSR 292: call site change notification should be pushed not pulled
twisti
parents:
3417
diff
changeset
|
259 template(java_lang_invoke_MutableCallSite, "java/lang/invoke/MutableCallSite") \ |
fdb992d83a87
7071653: JSR 292: call site change notification should be pushed not pulled
twisti
parents:
3417
diff
changeset
|
260 template(java_lang_invoke_VolatileCallSite, "java/lang/invoke/VolatileCallSite") \ |
2357
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
261 template(java_lang_invoke_MethodHandle, "java/lang/invoke/MethodHandle") \ |
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
262 template(java_lang_invoke_MethodType, "java/lang/invoke/MethodType") \ |
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
263 template(java_lang_invoke_MethodType_signature, "Ljava/lang/invoke/MethodType;") \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
264 template(java_lang_invoke_MemberName_signature, "Ljava/lang/invoke/MemberName;") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
265 template(java_lang_invoke_LambdaForm_signature, "Ljava/lang/invoke/LambdaForm;") \ |
2357
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
266 template(java_lang_invoke_MethodHandle_signature, "Ljava/lang/invoke/MethodHandle;") \ |
710 | 267 /* internal classes known only to the JVM: */ \ |
2357
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
268 template(java_lang_invoke_MemberName, "java/lang/invoke/MemberName") \ |
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
269 template(java_lang_invoke_MethodHandleNatives, "java/lang/invoke/MethodHandleNatives") \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
270 template(java_lang_invoke_LambdaForm, "java/lang/invoke/LambdaForm") \ |
6222
6d8f36bcef55
6711908: JVM needs direct access to some annotations
jrose
parents:
6181
diff
changeset
|
271 template(java_lang_invoke_ForceInline_signature, "Ljava/lang/invoke/ForceInline;") \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
272 template(java_lang_invoke_DontInline_signature, "Ljava/lang/invoke/DontInline;") \ |
12333
cacc4c6bfc80
8025233: Move sun.invoke.Stable into java.lang.invoke package
vlivanov
parents:
12323
diff
changeset
|
273 template(java_lang_invoke_Stable_signature, "Ljava/lang/invoke/Stable;") \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
274 template(java_lang_invoke_LambdaForm_Compiled_signature, "Ljava/lang/invoke/LambdaForm$Compiled;") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
275 template(java_lang_invoke_LambdaForm_Hidden_signature, "Ljava/lang/invoke/LambdaForm$Hidden;") \ |
2357
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
276 /* internal up-calls made only by the JVM, via class sun.invoke.MethodHandleNatives: */ \ |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1396
diff
changeset
|
277 template(findMethodHandleType_name, "findMethodHandleType") \ |
2357
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
278 template(findMethodHandleType_signature, "(Ljava/lang/Class;[Ljava/lang/Class;)Ljava/lang/invoke/MethodType;") \ |
1602 | 279 template(linkMethodHandleConstant_name, "linkMethodHandleConstant") \ |
2357
8033953d67ff
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
2356
diff
changeset
|
280 template(linkMethodHandleConstant_signature, "(Ljava/lang/Class;ILjava/lang/Class;Ljava/lang/String;Ljava/lang/Object;)Ljava/lang/invoke/MethodHandle;") \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
281 template(linkMethod_name, "linkMethod") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
282 template(linkMethod_signature, "(Ljava/lang/Class;ILjava/lang/Class;Ljava/lang/String;Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/invoke/MemberName;") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
283 template(linkCallSite_name, "linkCallSite") \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
284 template(linkCallSite_signature, "(Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/invoke/MemberName;") \ |
3900
a32de5085326
7079673: JSR 292: C1 should inline bytecoded method handle adapters
twisti
parents:
3852
diff
changeset
|
285 template(setTargetNormal_name, "setTargetNormal") \ |
a32de5085326
7079673: JSR 292: C1 should inline bytecoded method handle adapters
twisti
parents:
3852
diff
changeset
|
286 template(setTargetVolatile_name, "setTargetVolatile") \ |
a32de5085326
7079673: JSR 292: C1 should inline bytecoded method handle adapters
twisti
parents:
3852
diff
changeset
|
287 template(setTarget_signature, "(Ljava/lang/invoke/MethodHandle;)V") \ |
3938 | 288 NOT_LP64( do_alias(intptr_signature, int_signature) ) \ |
289 LP64_ONLY( do_alias(intptr_signature, long_signature) ) \ | |
3905
c26de9aef2ed
7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents:
3900
diff
changeset
|
290 template(selectAlternative_signature, "(ZLjava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodHandle;)Ljava/lang/invoke/MethodHandle;") \ |
14724
c3ec1e4494b8
update BenchmarkCounters (add TimedDynamicCounters, fix -XX:+GraalCountersExcludeCompiler)
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14562
diff
changeset
|
291 \ |
c3ec1e4494b8
update BenchmarkCounters (add TimedDynamicCounters, fix -XX:+GraalCountersExcludeCompiler)
Lukas Stadler <lukas.stadler@oracle.com>
parents:
14562
diff
changeset
|
292 /* Support for Graal */ \ |
16398
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
293 template(java_util_BitSet, "java/util/BitSet") \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
294 GRAAL_ONLY(template(com_oracle_graal_compiler_CompilerThread, "com/oracle/graal/compiler/CompilerThread")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
295 GRAAL_ONLY(template(com_oracle_graal_graph_Node, "com/oracle/graal/graph/Node")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
296 GRAAL_ONLY(template(com_oracle_graal_graph_NodeClass, "com/oracle/graal/graph/NodeClass")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
297 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotGraalRuntime, "com/oracle/graal/hotspot/HotSpotGraalRuntime")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
298 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotCompiledCode, "com/oracle/graal/hotspot/HotSpotCompiledCode")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
299 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotCompiledCode_Comment, "com/oracle/graal/hotspot/HotSpotCompiledCode$Comment")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
300 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotCompiledNmethod, "com/oracle/graal/hotspot/HotSpotCompiledNmethod")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
301 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotCompiledRuntimeStub, "com/oracle/graal/hotspot/HotSpotCompiledRuntimeStub")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
302 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotForeignCallLinkage, "com/oracle/graal/hotspot/HotSpotForeignCallLinkage")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
303 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotReferenceMap, "com/oracle/graal/hotspot/HotSpotReferenceMap")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
304 GRAAL_ONLY(template(com_oracle_graal_hotspot_bridge_CompilerToVMImpl, "com/oracle/graal/hotspot/bridge/CompilerToVMImpl")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
305 GRAAL_ONLY(template(com_oracle_graal_hotspot_data_DataSection, "com/oracle/graal/hotspot/data/DataSection")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
306 GRAAL_ONLY(template(com_oracle_graal_hotspot_data_DataSectionReference, "com/oracle/graal/hotspot/data/DataSectionReference")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
307 GRAAL_ONLY(template(com_oracle_graal_hotspot_data_MetaspaceData, "com/oracle/graal/hotspot/data/MetaspaceData")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
308 GRAAL_ONLY(template(com_oracle_graal_hotspot_data_OopData, "com/oracle/graal/hotspot/data/OopData")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
309 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotInstalledCode, "com/oracle/graal/hotspot/meta/HotSpotInstalledCode")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
310 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotNmethod, "com/oracle/graal/hotspot/meta/HotSpotNmethod")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
311 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotResolvedJavaMethod, "com/oracle/graal/hotspot/meta/HotSpotResolvedJavaMethod")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
312 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotResolvedObjectType, "com/oracle/graal/hotspot/meta/HotSpotResolvedObjectType")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
313 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotMonitorValue, "com/oracle/graal/hotspot/meta/HotSpotMonitorValue")) \ |
16589
6bdd2ec553eb
handle HotSpotCompressedNullConstant in graalCodeInstaller
Lukas Stadler <lukas.stadler@oracle.com>
parents:
16580
diff
changeset
|
314 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotCompressedNullConstant, "com/oracle/graal/hotspot/meta/HotSpotCompressedNullConstant")) \ |
16398
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
315 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotObjectConstant, "com/oracle/graal/hotspot/meta/HotSpotObjectConstant")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
316 GRAAL_ONLY(template(com_oracle_graal_hotspot_meta_HotSpotMetaspaceConstant, "com/oracle/graal/hotspot/meta/HotSpotMetaspaceConstant")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
317 GRAAL_ONLY(template(com_oracle_graal_hotspot_HotSpotStackFrameReference, "com/oracle/graal/hotspot/HotSpotStackFrameReference")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
318 GRAAL_ONLY(template(com_oracle_graal_hotspot_CompilationTask, "com/oracle/graal/hotspot/CompilationTask")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
319 GRAAL_ONLY(template(com_oracle_graal_api_meta_Constant, "com/oracle/graal/api/meta/Constant")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
320 GRAAL_ONLY(template(com_oracle_graal_api_meta_PrimitiveConstant, "com/oracle/graal/api/meta/PrimitiveConstant")) \ |
17084
26f5733fb645
Fix the endianess issue, when using JSR/RET instruction and deoptimization happens in this subroutine
Stefan Anzinger <stefan.anzinger@oracle.com>
parents:
16996
diff
changeset
|
321 GRAAL_ONLY(template(com_oracle_graal_api_meta_RawConstant, "com/oracle/graal/api/meta/RawConstant")) \ |
16398
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
322 GRAAL_ONLY(template(com_oracle_graal_api_meta_NullConstant, "com/oracle/graal/api/meta/NullConstant")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
323 GRAAL_ONLY(template(com_oracle_graal_api_meta_ExceptionHandler, "com/oracle/graal/api/meta/ExceptionHandler")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
324 GRAAL_ONLY(template(com_oracle_graal_api_meta_JavaMethod, "com/oracle/graal/api/meta/JavaMethod")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
325 GRAAL_ONLY(template(com_oracle_graal_api_meta_JavaType, "com/oracle/graal/api/meta/JavaType")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
326 GRAAL_ONLY(template(com_oracle_graal_api_meta_Kind, "com/oracle/graal/api/meta/Kind")) \ |
16580
a7d9b88ecd68
use LIRKind in graalCodeInstaller, support compressed oops in frame states
Lukas Stadler <lukas.stadler@oracle.com>
parents:
16399
diff
changeset
|
327 GRAAL_ONLY(template(com_oracle_graal_api_meta_LIRKind, "com/oracle/graal/api/meta/LIRKind")) \ |
16398
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
328 GRAAL_ONLY(template(com_oracle_graal_api_meta_Value, "com/oracle/graal/api/meta/Value")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
329 GRAAL_ONLY(template(com_oracle_graal_api_code_Assumptions, "com/oracle/graal/api/code/Assumptions")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
330 GRAAL_ONLY(template(com_oracle_graal_api_code_Assumptions_MethodContents, "com/oracle/graal/api/code/Assumptions$MethodContents")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
331 GRAAL_ONLY(template(com_oracle_graal_api_code_Assumptions_ConcreteSubtype, "com/oracle/graal/api/code/Assumptions$ConcreteSubtype")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
332 GRAAL_ONLY(template(com_oracle_graal_api_code_Assumptions_NoFinalizableSubclass, "com/oracle/graal/api/code/Assumptions$NoFinalizableSubclass")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
333 GRAAL_ONLY(template(com_oracle_graal_api_code_Assumptions_ConcreteMethod, "com/oracle/graal/api/code/Assumptions$ConcreteMethod")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
334 GRAAL_ONLY(template(com_oracle_graal_api_code_Assumptions_CallSiteTargetValue,"com/oracle/graal/api/code/Assumptions$CallSiteTargetValue")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
335 GRAAL_ONLY(template(com_oracle_graal_api_code_CompilationResult, "com/oracle/graal/api/code/CompilationResult")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
336 GRAAL_ONLY(template(com_oracle_graal_api_code_CompilationResult_Call, "com/oracle/graal/api/code/CompilationResult$Call")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
337 GRAAL_ONLY(template(com_oracle_graal_api_code_CompilationResult_DataPatch, "com/oracle/graal/api/code/CompilationResult$DataPatch")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
338 GRAAL_ONLY(template(com_oracle_graal_api_code_CompilationResult_ExceptionHandler, "com/oracle/graal/api/code/CompilationResult$ExceptionHandler")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
339 GRAAL_ONLY(template(com_oracle_graal_api_code_CompilationResult_Mark, "com/oracle/graal/api/code/CompilationResult$Mark")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
340 GRAAL_ONLY(template(com_oracle_graal_api_code_CompilationResult_Infopoint, "com/oracle/graal/api/code/CompilationResult$Infopoint")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
341 GRAAL_ONLY(template(com_oracle_graal_api_code_CompilationResult_Site, "com/oracle/graal/api/code/CompilationResult$Site")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
342 GRAAL_ONLY(template(com_oracle_graal_api_code_InfopointReason, "com/oracle/graal/api/code/InfopointReason")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
343 GRAAL_ONLY(template(com_oracle_graal_api_code_InstalledCode, "com/oracle/graal/api/code/InstalledCode")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
344 GRAAL_ONLY(template(com_oracle_graal_api_code_BytecodeFrame, "com/oracle/graal/api/code/BytecodeFrame")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
345 GRAAL_ONLY(template(com_oracle_graal_api_code_BytecodePosition, "com/oracle/graal/api/code/BytecodePosition")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
346 GRAAL_ONLY(template(com_oracle_graal_api_code_DebugInfo, "com/oracle/graal/api/code/DebugInfo")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
347 GRAAL_ONLY(template(com_oracle_graal_api_code_Register, "com/oracle/graal/api/code/Register")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
348 GRAAL_ONLY(template(com_oracle_graal_api_code_RegisterValue, "com/oracle/graal/api/code/RegisterValue")) \ |
16996
6ea6d4c260c8
[SPARC/AMD64] Fixing handling of floatingpoint register handling
Stefan Anzinger <stefan.anzinger@oracle.com>
parents:
16589
diff
changeset
|
349 GRAAL_ONLY(template(com_oracle_graal_api_code_Register_RegisterCategory, "com/oracle/graal/api/code/Register$RegisterCategory")) \ |
16398
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
350 GRAAL_ONLY(template(com_oracle_graal_api_code_StackSlot, "com/oracle/graal/api/code/StackSlot")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
351 GRAAL_ONLY(template(com_oracle_graal_api_code_VirtualObject, "com/oracle/graal/api/code/VirtualObject")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
352 GRAAL_ONLY(template(com_oracle_graal_api_code_RegisterSaveLayout, "com/oracle/graal/api/code/RegisterSaveLayout")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
353 GRAAL_ONLY(template(com_oracle_graal_api_code_InvalidInstalledCodeException, "com/oracle/graal/api/code/InvalidInstalledCodeException")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
354 GRAAL_ONLY(template(com_oracle_graal_api_code_SpeculationLog, "com/oracle/graal/api/code/SpeculationLog")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
355 GRAAL_ONLY(template(com_oracle_graal_gpu_ExternalCompilationResult, "com/oracle/graal/gpu/ExternalCompilationResult")) \ |
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
356 GRAAL_ONLY(template(compileMetaspaceMethod_name, "compileMetaspaceMethod")) \ |
16399
4481cf549cfc
removed (Java based) CompilationQueue
Doug Simon <doug.simon@oracle.com>
parents:
16398
diff
changeset
|
357 GRAAL_ONLY(template(compileMetaspaceMethod_signature, "(JIJI)V")) \ |
16398
c5ab3fbec257
made Graal symbol declarations conditional upon GRAAL macro
Doug Simon <doug.simon@oracle.com>
parents:
16395
diff
changeset
|
358 GRAAL_ONLY(template(graal_mirror_name, "graal_mirror")) \ |
16006
66a9286203a2
decoupled Graal runtime initialization and Graal compilation queue initialization
Doug Simon <doug.simon@oracle.com>
parents:
15626
diff
changeset
|
359 \ |
710 | 360 /* common method and field names */ \ |
0 | 361 template(object_initializer_name, "<init>") \ |
362 template(class_initializer_name, "<clinit>") \ | |
363 template(println_name, "println") \ | |
364 template(printStackTrace_name, "printStackTrace") \ | |
365 template(main_name, "main") \ | |
366 template(name_name, "name") \ | |
367 template(priority_name, "priority") \ | |
368 template(stillborn_name, "stillborn") \ | |
369 template(group_name, "group") \ | |
370 template(daemon_name, "daemon") \ | |
371 template(eetop_name, "eetop") \ | |
372 template(thread_status_name, "threadStatus") \ | |
373 template(run_method_name, "run") \ | |
374 template(exit_method_name, "exit") \ | |
375 template(add_method_name, "add") \ | |
4916
1b0e0f8be510
7131006: java/lang/management/ThreadMXBean/ThreadLists.java
minqi
parents:
4773
diff
changeset
|
376 template(remove_method_name, "remove") \ |
0 | 377 template(parent_name, "parent") \ |
378 template(threads_name, "threads") \ | |
379 template(groups_name, "groups") \ | |
380 template(maxPriority_name, "maxPriority") \ | |
381 template(destroyed_name, "destroyed") \ | |
382 template(vmAllowSuspension_name, "vmAllowSuspension") \ | |
383 template(nthreads_name, "nthreads") \ | |
384 template(ngroups_name, "ngroups") \ | |
385 template(shutdown_method_name, "shutdown") \ | |
386 template(finalize_method_name, "finalize") \ | |
387 template(reference_lock_name, "lock") \ | |
388 template(reference_discovered_name, "discovered") \ | |
4773 | 389 template(run_finalization_name, "runFinalization") \ |
0 | 390 template(run_finalizers_on_exit_name, "runFinalizersOnExit") \ |
391 template(uncaughtException_name, "uncaughtException") \ | |
392 template(dispatchUncaughtException_name, "dispatchUncaughtException") \ | |
393 template(initializeSystemClass_name, "initializeSystemClass") \ | |
394 template(loadClass_name, "loadClass") \ | |
395 template(loadClassInternal_name, "loadClassInternal") \ | |
396 template(get_name, "get") \ | |
397 template(put_name, "put") \ | |
398 template(type_name, "type") \ | |
399 template(findNative_name, "findNative") \ | |
400 template(deadChild_name, "deadChild") \ | |
6751
2a48c84f1d04
7197269: NPG: FollowReferences has no ClassLoader -> Class link to follow
coleenp
parents:
6725
diff
changeset
|
401 template(addClass_name, "addClass") \ |
13403
9d15b81d5d1b
8016839: JSR292: AME instead of IAE when calling a method
drchase
parents:
13385
diff
changeset
|
402 template(throwIllegalAccessError_name, "throwIllegalAccessError") \ |
0 | 403 template(getFromClass_name, "getFromClass") \ |
404 template(dispatch_name, "dispatch") \ | |
405 template(getSystemClassLoader_name, "getSystemClassLoader") \ | |
406 template(fillInStackTrace_name, "fillInStackTrace") \ | |
2476
6a615eae2f34
7034585: Adjust fillInStackTrace filtering to assist 6998871
dholmes
parents:
2357
diff
changeset
|
407 template(fillInStackTrace0_name, "fillInStackTrace0") \ |
0 | 408 template(getCause_name, "getCause") \ |
409 template(initCause_name, "initCause") \ | |
410 template(setProperty_name, "setProperty") \ | |
411 template(getProperty_name, "getProperty") \ | |
412 template(context_name, "context") \ | |
413 template(privilegedContext_name, "privilegedContext") \ | |
414 template(contextClassLoader_name, "contextClassLoader") \ | |
415 template(inheritedAccessControlContext_name, "inheritedAccessControlContext") \ | |
416 template(isPrivileged_name, "isPrivileged") \ | |
11010 | 417 template(isAuthorized_name, "isAuthorized") \ |
8866
16885e702c88
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
7955
diff
changeset
|
418 template(getClassContext_name, "getClassContext") \ |
0 | 419 template(wait_name, "wait") \ |
420 template(checkPackageAccess_name, "checkPackageAccess") \ | |
421 template(stackSize_name, "stackSize") \ | |
422 template(thread_id_name, "tid") \ | |
423 template(newInstance0_name, "newInstance0") \ | |
424 template(limit_name, "limit") \ | |
12010
ca0165daa6ec
7187554: JSR 292: JVMTI PopFrame needs to handle appendix arguments
sspitsyn
parents:
11154
diff
changeset
|
425 template(member_name, "member") \ |
0 | 426 template(forName_name, "forName") \ |
427 template(forName0_name, "forName0") \ | |
428 template(isJavaIdentifierStart_name, "isJavaIdentifierStart") \ | |
429 template(isJavaIdentifierPart_name, "isJavaIdentifierPart") \ | |
430 template(exclusive_owner_thread_name, "exclusiveOwnerThread") \ | |
431 template(park_blocker_name, "parkBlocker") \ | |
432 template(park_event_name, "nativeParkEventPointer") \ | |
17
ff5961f4c095
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
0
diff
changeset
|
433 template(cache_field_name, "cache") \ |
0 | 434 template(value_name, "value") \ |
6057 | 435 template(offset_name, "offset") \ |
436 template(count_name, "count") \ | |
437 template(hash_name, "hash") \ | |
775
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
438 template(numberOfLeadingZeros_name, "numberOfLeadingZeros") \ |
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
439 template(numberOfTrailingZeros_name, "numberOfTrailingZeros") \ |
643
c771b7f43bbf
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
514
diff
changeset
|
440 template(bitCount_name, "bitCount") \ |
675 | 441 template(profile_name, "profile") \ |
681 | 442 template(equals_name, "equals") \ |
3476
65981c23c1d6
Fixed bootstrap (lowered compilation threshold and register more methods for compilation)
Thomas Wuerthinger <thomas@wuerthinger.net>
parents:
3464
diff
changeset
|
443 template(length_name, "length") \ |
726
be93aad57795
6655646: dynamic languages need dynamically linked call sites
jrose
parents:
710
diff
changeset
|
444 template(target_name, "target") \ |
710 | 445 template(toString_name, "toString") \ |
446 template(values_name, "values") \ | |
447 template(receiver_name, "receiver") \ | |
448 template(vmtarget_name, "vmtarget") \ | |
6725
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6271
diff
changeset
|
449 template(next_target_name, "next_target") \ |
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6271
diff
changeset
|
450 template(vmloader_name, "vmloader") \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
451 template(vmindex_name, "vmindex") \ |
3905
c26de9aef2ed
7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents:
3900
diff
changeset
|
452 template(vmcount_name, "vmcount") \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
453 template(vmentry_name, "vmentry") \ |
710 | 454 template(flags_name, "flags") \ |
455 template(rtype_name, "rtype") \ | |
456 template(ptypes_name, "ptypes") \ | |
457 template(form_name, "form") \ | |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
458 template(basicType_name, "basicType") \ |
1080
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
459 template(append_name, "append") \ |
3938 | 460 template(klass_name, "klass") \ |
461 template(array_klass_name, "array_klass") \ | |
462 template(oop_size_name, "oop_size") \ | |
463 template(static_oop_field_count_name, "static_oop_field_count") \ | |
10343
6bd680e9ea35
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
10280
diff
changeset
|
464 template(protection_domain_name, "protection_domain") \ |
6bd680e9ea35
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
10280
diff
changeset
|
465 template(init_lock_name, "init_lock") \ |
6bd680e9ea35
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
10280
diff
changeset
|
466 template(signers_name, "signers_name") \ |
6725
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6271
diff
changeset
|
467 template(loader_data_name, "loader_data") \ |
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6271
diff
changeset
|
468 template(dependencies_name, "dependencies") \ |
0 | 469 \ |
470 /* non-intrinsic name/signature pairs: */ \ | |
471 template(register_method_name, "register") \ | |
472 do_alias(register_method_signature, object_void_signature) \ | |
473 \ | |
474 /* name symbols needed by intrinsics */ \ | |
475 VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, VM_SYMBOL_IGNORE, template, VM_SYMBOL_IGNORE, VM_ALIAS_IGNORE) \ | |
476 \ | |
477 /* common signatures names */ \ | |
478 template(void_method_signature, "()V") \ | |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
479 template(void_boolean_signature, "()Z") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
480 template(void_byte_signature, "()B") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
481 template(void_char_signature, "()C") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
482 template(void_short_signature, "()S") \ |
0 | 483 template(void_int_signature, "()I") \ |
484 template(void_long_signature, "()J") \ | |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
485 template(void_float_signature, "()F") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
486 template(void_double_signature, "()D") \ |
3650
0e8a2a629afb
Pass-by compilation broker.
Thomas Wuerthinger <thomas.wuerthinger@oracle.com>
parents:
3632
diff
changeset
|
487 template(bool_void_signature, "(Z)V") \ |
0 | 488 template(int_void_signature, "(I)V") \ |
489 template(int_int_signature, "(I)I") \ | |
1396
d7f654633cfe
6946040: add intrinsic for short and char reverseBytes
never
parents:
1144
diff
changeset
|
490 template(char_char_signature, "(C)C") \ |
d7f654633cfe
6946040: add intrinsic for short and char reverseBytes
never
parents:
1144
diff
changeset
|
491 template(short_short_signature, "(S)S") \ |
0 | 492 template(int_bool_signature, "(I)Z") \ |
493 template(float_int_signature, "(F)I") \ | |
494 template(double_long_signature, "(D)J") \ | |
495 template(double_double_signature, "(D)D") \ | |
496 template(int_float_signature, "(I)F") \ | |
643
c771b7f43bbf
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
514
diff
changeset
|
497 template(long_int_signature, "(J)I") \ |
0 | 498 template(long_long_signature, "(J)J") \ |
499 template(long_double_signature, "(J)D") \ | |
500 template(byte_signature, "B") \ | |
501 template(char_signature, "C") \ | |
502 template(double_signature, "D") \ | |
503 template(float_signature, "F") \ | |
504 template(int_signature, "I") \ | |
505 template(long_signature, "J") \ | |
506 template(short_signature, "S") \ | |
507 template(bool_signature, "Z") \ | |
508 template(void_signature, "V") \ | |
509 template(byte_array_signature, "[B") \ | |
510 template(char_array_signature, "[C") \ | |
3363
167b70ff3abc
6939861: JVM should handle more conversion operations
never
parents:
3261
diff
changeset
|
511 template(int_array_signature, "[I") \ |
0 | 512 template(object_void_signature, "(Ljava/lang/Object;)V") \ |
513 template(object_int_signature, "(Ljava/lang/Object;)I") \ | |
514 template(object_boolean_signature, "(Ljava/lang/Object;)Z") \ | |
515 template(string_void_signature, "(Ljava/lang/String;)V") \ | |
516 template(string_int_signature, "(Ljava/lang/String;)I") \ | |
517 template(throwable_void_signature, "(Ljava/lang/Throwable;)V") \ | |
518 template(void_throwable_signature, "()Ljava/lang/Throwable;") \ | |
519 template(throwable_throwable_signature, "(Ljava/lang/Throwable;)Ljava/lang/Throwable;") \ | |
520 template(class_void_signature, "(Ljava/lang/Class;)V") \ | |
521 template(class_int_signature, "(Ljava/lang/Class;)I") \ | |
6006
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
522 template(class_long_signature, "(Ljava/lang/Class;)J") \ |
0 | 523 template(class_boolean_signature, "(Ljava/lang/Class;)Z") \ |
524 template(throwable_string_void_signature, "(Ljava/lang/Throwable;Ljava/lang/String;)V") \ | |
525 template(string_array_void_signature, "([Ljava/lang/String;)V") \ | |
526 template(string_array_string_array_void_signature, "([Ljava/lang/String;[Ljava/lang/String;)V") \ | |
527 template(thread_throwable_void_signature, "(Ljava/lang/Thread;Ljava/lang/Throwable;)V") \ | |
528 template(thread_void_signature, "(Ljava/lang/Thread;)V") \ | |
529 template(threadgroup_runnable_void_signature, "(Ljava/lang/ThreadGroup;Ljava/lang/Runnable;)V") \ | |
530 template(threadgroup_string_void_signature, "(Ljava/lang/ThreadGroup;Ljava/lang/String;)V") \ | |
531 template(string_class_signature, "(Ljava/lang/String;)Ljava/lang/Class;") \ | |
532 template(object_object_object_signature, "(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;") \ | |
533 template(string_string_string_signature, "(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;") \ | |
534 template(string_string_signature, "(Ljava/lang/String;)Ljava/lang/String;") \ | |
535 template(classloader_string_long_signature, "(Ljava/lang/ClassLoader;Ljava/lang/String;)J") \ | |
536 template(byte_array_void_signature, "([B)V") \ | |
537 template(char_array_void_signature, "([C)V") \ | |
538 template(int_int_void_signature, "(II)V") \ | |
539 template(long_long_void_signature, "(JJ)V") \ | |
540 template(void_classloader_signature, "()Ljava/lang/ClassLoader;") \ | |
541 template(void_object_signature, "()Ljava/lang/Object;") \ | |
542 template(void_class_signature, "()Ljava/lang/Class;") \ | |
8866
16885e702c88
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
7955
diff
changeset
|
543 template(void_class_array_signature, "()[Ljava/lang/Class;") \ |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1396
diff
changeset
|
544 template(void_string_signature, "()Ljava/lang/String;") \ |
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1396
diff
changeset
|
545 template(object_array_object_signature, "([Ljava/lang/Object;)Ljava/lang/Object;") \ |
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1396
diff
changeset
|
546 template(object_object_array_object_signature, "(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;")\ |
0 | 547 template(exception_void_signature, "(Ljava/lang/Exception;)V") \ |
548 template(protectiondomain_signature, "[Ljava/security/ProtectionDomain;") \ | |
549 template(accesscontrolcontext_signature, "Ljava/security/AccessControlContext;") \ | |
550 template(class_protectiondomain_signature, "(Ljava/lang/Class;Ljava/security/ProtectionDomain;)V") \ | |
551 template(thread_signature, "Ljava/lang/Thread;") \ | |
552 template(thread_array_signature, "[Ljava/lang/Thread;") \ | |
553 template(threadgroup_signature, "Ljava/lang/ThreadGroup;") \ | |
554 template(threadgroup_array_signature, "[Ljava/lang/ThreadGroup;") \ | |
555 template(class_array_signature, "[Ljava/lang/Class;") \ | |
556 template(classloader_signature, "Ljava/lang/ClassLoader;") \ | |
557 template(object_signature, "Ljava/lang/Object;") \ | |
558 template(class_signature, "Ljava/lang/Class;") \ | |
559 template(string_signature, "Ljava/lang/String;") \ | |
560 template(reference_signature, "Ljava/lang/ref/Reference;") \ | |
7462
ade95d680b42
8004728: Add hotspot support for parameter reflection
coleenp
parents:
7458
diff
changeset
|
561 template(executable_signature, "Ljava/lang/reflect/Executable;") \ |
514 | 562 template(concurrenthashmap_signature, "Ljava/util/concurrent/ConcurrentHashMap;") \ |
1080
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
563 template(String_StringBuilder_signature, "(Ljava/lang/String;)Ljava/lang/StringBuilder;") \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
564 template(int_StringBuilder_signature, "(I)Ljava/lang/StringBuilder;") \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
565 template(char_StringBuilder_signature, "(C)Ljava/lang/StringBuilder;") \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
566 template(String_StringBuffer_signature, "(Ljava/lang/String;)Ljava/lang/StringBuffer;") \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
567 template(int_StringBuffer_signature, "(I)Ljava/lang/StringBuffer;") \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
568 template(char_StringBuffer_signature, "(C)Ljava/lang/StringBuffer;") \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
569 template(int_String_signature, "(I)Ljava/lang/String;") \ |
0 | 570 /* signature symbols needed by intrinsics */ \ |
571 VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, template, VM_ALIAS_IGNORE) \ | |
572 \ | |
573 /* symbol aliases needed by intrinsics */ \ | |
574 VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, do_alias) \ | |
575 \ | |
576 /* returned by the C1 compiler in case there's not enough memory to allocate a new symbol*/ \ | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
577 template(dummy_symbol, "illegal symbol") \ |
0 | 578 \ |
579 /* used by ClassFormatError when class name is not known yet */ \ | |
580 template(unknown_class_name, "<Unknown>") \ | |
581 \ | |
514 | 582 /* used to identify class loaders handling parallel class loading */ \ |
653
e55bcaf3a6a1
6819853: VM does not detect JDK which supports parallel class loaders
acorn
parents:
579
diff
changeset
|
583 template(parallelCapable_name, "parallelLockMap") \ |
514 | 584 \ |
0 | 585 /* JVM monitoring and management support */ \ |
586 template(java_lang_StackTraceElement_array, "[Ljava/lang/StackTraceElement;") \ | |
587 template(java_lang_management_ThreadState, "java/lang/management/ThreadState") \ | |
588 template(java_lang_management_MemoryUsage, "java/lang/management/MemoryUsage") \ | |
589 template(java_lang_management_ThreadInfo, "java/lang/management/ThreadInfo") \ | |
590 template(sun_management_ManagementFactory, "sun/management/ManagementFactory") \ | |
591 template(sun_management_Sensor, "sun/management/Sensor") \ | |
592 template(sun_management_Agent, "sun/management/Agent") \ | |
10215
31a4e55f8c9d
8004095: Add support for JMX interface to Diagnostic Framework and Commands
fparain
parents:
8866
diff
changeset
|
593 template(sun_management_DiagnosticCommandImpl, "sun/management/DiagnosticCommandImpl") \ |
3356
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
594 template(sun_management_GarbageCollectorImpl, "sun/management/GarbageCollectorImpl") \ |
10215
31a4e55f8c9d
8004095: Add support for JMX interface to Diagnostic Framework and Commands
fparain
parents:
8866
diff
changeset
|
595 template(sun_management_ManagementFactoryHelper, "sun/management/ManagementFactoryHelper") \ |
31a4e55f8c9d
8004095: Add support for JMX interface to Diagnostic Framework and Commands
fparain
parents:
8866
diff
changeset
|
596 template(getDiagnosticCommandMBean_name, "getDiagnosticCommandMBean") \ |
31a4e55f8c9d
8004095: Add support for JMX interface to Diagnostic Framework and Commands
fparain
parents:
8866
diff
changeset
|
597 template(getDiagnosticCommandMBean_signature, "()Lcom/sun/management/DiagnosticCommandMBean;") \ |
3356
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
598 template(getGcInfoBuilder_name, "getGcInfoBuilder") \ |
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
599 template(getGcInfoBuilder_signature, "()Lsun/management/GcInfoBuilder;") \ |
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
600 template(com_sun_management_GcInfo, "com/sun/management/GcInfo") \ |
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
601 template(com_sun_management_GcInfo_constructor_signature, "(Lsun/management/GcInfoBuilder;JJJ[Ljava/lang/management/MemoryUsage;[Ljava/lang/management/MemoryUsage;[Ljava/lang/Object;)V") \ |
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
602 template(createGCNotification_name, "createGCNotification") \ |
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
603 template(createGCNotification_signature, "(JLjava/lang/String;Ljava/lang/String;Ljava/lang/String;Lcom/sun/management/GcInfo;)V") \ |
10215
31a4e55f8c9d
8004095: Add support for JMX interface to Diagnostic Framework and Commands
fparain
parents:
8866
diff
changeset
|
604 template(createDiagnosticFrameworkNotification_name, "createDiagnosticFrameworkNotification") \ |
0 | 605 template(createMemoryPoolMBean_name, "createMemoryPoolMBean") \ |
606 template(createMemoryManagerMBean_name, "createMemoryManagerMBean") \ | |
607 template(createGarbageCollectorMBean_name, "createGarbageCollectorMBean") \ | |
608 template(createMemoryPoolMBean_signature, "(Ljava/lang/String;ZJJ)Ljava/lang/management/MemoryPoolMBean;") \ | |
609 template(createMemoryManagerMBean_signature, "(Ljava/lang/String;)Ljava/lang/management/MemoryManagerMBean;") \ | |
610 template(createGarbageCollectorMBean_signature, "(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/management/GarbageCollectorMBean;") \ | |
611 template(trigger_name, "trigger") \ | |
612 template(clear_name, "clear") \ | |
613 template(trigger_method_signature, "(ILjava/lang/management/MemoryUsage;)V") \ | |
614 template(startAgent_name, "startAgent") \ | |
5895
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4916
diff
changeset
|
615 template(startRemoteAgent_name, "startRemoteManagementAgent") \ |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4916
diff
changeset
|
616 template(startLocalAgent_name, "startLocalManagementAgent") \ |
645162d94294
7110104: It should be possible to stop and start JMX Agent at runtime
dsamersoff
parents:
4916
diff
changeset
|
617 template(stopRemoteAgent_name, "stopRemoteManagementAgent") \ |
0 | 618 template(java_lang_management_ThreadInfo_constructor_signature, "(Ljava/lang/Thread;ILjava/lang/Object;Ljava/lang/Thread;JJJJ[Ljava/lang/StackTraceElement;)V") \ |
619 template(java_lang_management_ThreadInfo_with_locks_constructor_signature, "(Ljava/lang/Thread;ILjava/lang/Object;Ljava/lang/Thread;JJJJ[Ljava/lang/StackTraceElement;[Ljava/lang/Object;[I[Ljava/lang/Object;)V") \ | |
620 template(long_long_long_long_void_signature, "(JJJJ)V") \ | |
621 \ | |
622 template(java_lang_management_MemoryPoolMXBean, "java/lang/management/MemoryPoolMXBean") \ | |
623 template(java_lang_management_MemoryManagerMXBean, "java/lang/management/MemoryManagerMXBean") \ | |
624 template(java_lang_management_GarbageCollectorMXBean,"java/lang/management/GarbageCollectorMXBean") \ | |
3356
78542e2b5e35
7036199: Adding a notification to the implementation of GarbageCollectorMXBeans
fparain
parents:
3261
diff
changeset
|
625 template(gcInfoBuilder_name, "gcInfoBuilder") \ |
0 | 626 template(createMemoryPool_name, "createMemoryPool") \ |
627 template(createMemoryManager_name, "createMemoryManager") \ | |
628 template(createGarbageCollector_name, "createGarbageCollector") \ | |
629 template(createMemoryPool_signature, "(Ljava/lang/String;ZJJ)Ljava/lang/management/MemoryPoolMXBean;") \ | |
630 template(createMemoryManager_signature, "(Ljava/lang/String;)Ljava/lang/management/MemoryManagerMXBean;") \ | |
631 template(createGarbageCollector_signature, "(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/management/GarbageCollectorMXBean;") \ | |
632 template(addThreadDumpForMonitors_name, "addThreadDumpForMonitors") \ | |
633 template(addThreadDumpForSynchronizers_name, "addThreadDumpForSynchronizers") \ | |
634 template(addThreadDumpForMonitors_signature, "(Ljava/lang/management/ThreadInfo;[Ljava/lang/Object;[I)V") \ | |
635 template(addThreadDumpForSynchronizers_signature, "(Ljava/lang/management/ThreadInfo;[Ljava/lang/Object;)V") \ | |
636 \ | |
637 /* JVMTI/java.lang.instrument support and VM Attach mechanism */ \ | |
638 template(sun_misc_VMSupport, "sun/misc/VMSupport") \ | |
639 template(appendToClassPathForInstrumentation_name, "appendToClassPathForInstrumentation") \ | |
640 do_alias(appendToClassPathForInstrumentation_signature, string_void_signature) \ | |
641 template(serializePropertiesToByteArray_name, "serializePropertiesToByteArray") \ | |
642 template(serializePropertiesToByteArray_signature, "()[B") \ | |
643 template(serializeAgentPropertiesToByteArray_name, "serializeAgentPropertiesToByteArray") \ | |
644 template(classRedefinedCount_name, "classRedefinedCount") \ | |
6006
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
645 \ |
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
646 /* trace signatures */ \ |
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
647 TRACE_TEMPLATES(template) \ |
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
648 \ |
0 | 649 /*end*/ |
650 | |
651 // Here are all the intrinsics known to the runtime and the CI. | |
652 // Each intrinsic consists of a public enum name (like _hashCode), | |
653 // followed by a specification of its klass, name, and signature: | |
654 // template(<id>, <klass>, <name>, <sig>, <FCODE>) | |
655 // | |
656 // If you add an intrinsic here, you must also define its name | |
657 // and signature as members of the VM symbols. The VM symbols for | |
658 // the intrinsic name and signature may be defined above. | |
659 // | |
660 // Because the VM_SYMBOLS_DO macro makes reference to VM_INTRINSICS_DO, | |
661 // you can also define an intrinsic's name and/or signature locally to the | |
662 // intrinsic, if this makes sense. (It often does make sense.) | |
663 // | |
664 // For example: | |
665 // do_intrinsic(_foo, java_lang_Object, foo_name, foo_signature, F_xx) | |
666 // do_name( foo_name, "foo") | |
667 // do_signature(foo_signature, "()F") | |
668 // klass = vmSymbols::java_lang_Object() | |
669 // name = vmSymbols::foo_name() | |
670 // signature = vmSymbols::foo_signature() | |
671 // | |
672 // The name and/or signature might be a "well known" symbol | |
673 // like "equal" or "()I", in which case there will be no local | |
674 // re-definition of the symbol. | |
675 // | |
676 // The do_class, do_name, and do_signature calls are all used for the | |
677 // same purpose: Define yet another VM symbol. They could all be merged | |
678 // into a common 'do_symbol' call, but it seems useful to record our | |
679 // intentions here about kinds of symbols (class vs. name vs. signature). | |
680 // | |
681 // The F_xx is one of the Flags enum; see below. | |
682 // | |
683 // for Emacs: (let ((c-backslash-column 120) (c-backslash-max-column 120)) (c-backslash-region (point) (point-max) nil t)) | |
684 #define VM_INTRINSICS_DO(do_intrinsic, do_class, do_name, do_signature, do_alias) \ | |
685 do_intrinsic(_hashCode, java_lang_Object, hashCode_name, void_int_signature, F_R) \ | |
686 do_name( hashCode_name, "hashCode") \ | |
687 do_intrinsic(_getClass, java_lang_Object, getClass_name, void_class_signature, F_R) \ | |
688 do_name( getClass_name, "getClass") \ | |
689 do_intrinsic(_clone, java_lang_Object, clone_name, void_object_signature, F_R) \ | |
690 do_name( clone_name, "clone") \ | |
691 \ | |
692 /* Math & StrictMath intrinsics are defined in terms of just a few signatures: */ \ | |
693 do_class(java_lang_Math, "java/lang/Math") \ | |
694 do_class(java_lang_StrictMath, "java/lang/StrictMath") \ | |
695 do_signature(double2_double_signature, "(DD)D") \ | |
696 do_signature(int2_int_signature, "(II)I") \ | |
12972
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
697 do_signature(long2_long_signature, "(JJ)J") \ |
0 | 698 \ |
699 /* here are the math names, all together: */ \ | |
700 do_name(abs_name,"abs") do_name(sin_name,"sin") do_name(cos_name,"cos") \ | |
701 do_name(tan_name,"tan") do_name(atan2_name,"atan2") do_name(sqrt_name,"sqrt") \ | |
702 do_name(log_name,"log") do_name(log10_name,"log10") do_name(pow_name,"pow") \ | |
703 do_name(exp_name,"exp") do_name(min_name,"min") do_name(max_name,"max") \ | |
704 \ | |
12323 | 705 do_name(addExact_name,"addExact") \ |
12972
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
706 do_name(decrementExact_name,"decrementExact") \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
707 do_name(incrementExact_name,"incrementExact") \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
708 do_name(multiplyExact_name,"multiplyExact") \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
709 do_name(negateExact_name,"negateExact") \ |
12323 | 710 do_name(subtractExact_name,"subtractExact") \ |
711 \ | |
0 | 712 do_intrinsic(_dabs, java_lang_Math, abs_name, double_double_signature, F_S) \ |
713 do_intrinsic(_dsin, java_lang_Math, sin_name, double_double_signature, F_S) \ | |
714 do_intrinsic(_dcos, java_lang_Math, cos_name, double_double_signature, F_S) \ | |
715 do_intrinsic(_dtan, java_lang_Math, tan_name, double_double_signature, F_S) \ | |
716 do_intrinsic(_datan2, java_lang_Math, atan2_name, double2_double_signature, F_S) \ | |
717 do_intrinsic(_dsqrt, java_lang_Math, sqrt_name, double_double_signature, F_S) \ | |
718 do_intrinsic(_dlog, java_lang_Math, log_name, double_double_signature, F_S) \ | |
719 do_intrinsic(_dlog10, java_lang_Math, log10_name, double_double_signature, F_S) \ | |
720 do_intrinsic(_dpow, java_lang_Math, pow_name, double2_double_signature, F_S) \ | |
721 do_intrinsic(_dexp, java_lang_Math, exp_name, double_double_signature, F_S) \ | |
722 do_intrinsic(_min, java_lang_Math, min_name, int2_int_signature, F_S) \ | |
723 do_intrinsic(_max, java_lang_Math, max_name, int2_int_signature, F_S) \ | |
12972
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
724 do_intrinsic(_addExactI, java_lang_Math, addExact_name, int2_int_signature, F_S) \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
725 do_intrinsic(_addExactL, java_lang_Math, addExact_name, long2_long_signature, F_S) \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
726 do_intrinsic(_decrementExactI, java_lang_Math, decrementExact_name, int_int_signature, F_S) \ |
14909 | 727 do_intrinsic(_decrementExactL, java_lang_Math, decrementExact_name, long2_long_signature, F_S) \ |
12972
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
728 do_intrinsic(_incrementExactI, java_lang_Math, incrementExact_name, int_int_signature, F_S) \ |
14909 | 729 do_intrinsic(_incrementExactL, java_lang_Math, incrementExact_name, long2_long_signature, F_S) \ |
12972
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
730 do_intrinsic(_multiplyExactI, java_lang_Math, multiplyExact_name, int2_int_signature, F_S) \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
731 do_intrinsic(_multiplyExactL, java_lang_Math, multiplyExact_name, long2_long_signature, F_S) \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
732 do_intrinsic(_negateExactI, java_lang_Math, negateExact_name, int_int_signature, F_S) \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
733 do_intrinsic(_negateExactL, java_lang_Math, negateExact_name, long_long_signature, F_S) \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
734 do_intrinsic(_subtractExactI, java_lang_Math, subtractExact_name, int2_int_signature, F_S) \ |
59e8ad757e19
8026844: Various Math functions needs intrinsification
rbackman
parents:
12333
diff
changeset
|
735 do_intrinsic(_subtractExactL, java_lang_Math, subtractExact_name, long2_long_signature, F_S) \ |
0 | 736 \ |
737 do_intrinsic(_floatToRawIntBits, java_lang_Float, floatToRawIntBits_name, float_int_signature, F_S) \ | |
738 do_name( floatToRawIntBits_name, "floatToRawIntBits") \ | |
739 do_intrinsic(_floatToIntBits, java_lang_Float, floatToIntBits_name, float_int_signature, F_S) \ | |
740 do_name( floatToIntBits_name, "floatToIntBits") \ | |
741 do_intrinsic(_intBitsToFloat, java_lang_Float, intBitsToFloat_name, int_float_signature, F_S) \ | |
742 do_name( intBitsToFloat_name, "intBitsToFloat") \ | |
743 do_intrinsic(_doubleToRawLongBits, java_lang_Double, doubleToRawLongBits_name, double_long_signature, F_S) \ | |
744 do_name( doubleToRawLongBits_name, "doubleToRawLongBits") \ | |
745 do_intrinsic(_doubleToLongBits, java_lang_Double, doubleToLongBits_name, double_long_signature, F_S) \ | |
746 do_name( doubleToLongBits_name, "doubleToLongBits") \ | |
747 do_intrinsic(_longBitsToDouble, java_lang_Double, longBitsToDouble_name, long_double_signature, F_S) \ | |
748 do_name( longBitsToDouble_name, "longBitsToDouble") \ | |
643
c771b7f43bbf
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
514
diff
changeset
|
749 \ |
775
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
750 do_intrinsic(_numberOfLeadingZeros_i, java_lang_Integer, numberOfLeadingZeros_name,int_int_signature, F_S) \ |
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
751 do_intrinsic(_numberOfLeadingZeros_l, java_lang_Long, numberOfLeadingZeros_name,long_int_signature, F_S) \ |
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
752 \ |
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
753 do_intrinsic(_numberOfTrailingZeros_i, java_lang_Integer, numberOfTrailingZeros_name,int_int_signature, F_S) \ |
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
754 do_intrinsic(_numberOfTrailingZeros_l, java_lang_Long, numberOfTrailingZeros_name,long_int_signature, F_S) \ |
93c14e5562c4
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
726
diff
changeset
|
755 \ |
643
c771b7f43bbf
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
514
diff
changeset
|
756 do_intrinsic(_bitCount_i, java_lang_Integer, bitCount_name, int_int_signature, F_S) \ |
c771b7f43bbf
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
514
diff
changeset
|
757 do_intrinsic(_bitCount_l, java_lang_Long, bitCount_name, long_int_signature, F_S) \ |
c771b7f43bbf
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
514
diff
changeset
|
758 \ |
0 | 759 do_intrinsic(_reverseBytes_i, java_lang_Integer, reverseBytes_name, int_int_signature, F_S) \ |
760 do_name( reverseBytes_name, "reverseBytes") \ | |
761 do_intrinsic(_reverseBytes_l, java_lang_Long, reverseBytes_name, long_long_signature, F_S) \ | |
762 /* (symbol reverseBytes_name defined above) */ \ | |
1396
d7f654633cfe
6946040: add intrinsic for short and char reverseBytes
never
parents:
1144
diff
changeset
|
763 do_intrinsic(_reverseBytes_c, java_lang_Character, reverseBytes_name, char_char_signature, F_S) \ |
d7f654633cfe
6946040: add intrinsic for short and char reverseBytes
never
parents:
1144
diff
changeset
|
764 /* (symbol reverseBytes_name defined above) */ \ |
d7f654633cfe
6946040: add intrinsic for short and char reverseBytes
never
parents:
1144
diff
changeset
|
765 do_intrinsic(_reverseBytes_s, java_lang_Short, reverseBytes_name, short_short_signature, F_S) \ |
d7f654633cfe
6946040: add intrinsic for short and char reverseBytes
never
parents:
1144
diff
changeset
|
766 /* (symbol reverseBytes_name defined above) */ \ |
0 | 767 \ |
768 do_intrinsic(_identityHashCode, java_lang_System, identityHashCode_name, object_int_signature, F_S) \ | |
769 do_name( identityHashCode_name, "identityHashCode") \ | |
770 do_intrinsic(_currentTimeMillis, java_lang_System, currentTimeMillis_name, void_long_signature, F_S) \ | |
771 \ | |
772 do_name( currentTimeMillis_name, "currentTimeMillis") \ | |
773 do_intrinsic(_nanoTime, java_lang_System, nanoTime_name, void_long_signature, F_S) \ | |
774 do_name( nanoTime_name, "nanoTime") \ | |
775 \ | |
6006
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
776 TRACE_INTRINSICS(do_intrinsic, do_class, do_name, do_signature, do_alias) \ |
0105f367a14c
7160570: Intrinsification support for tracing framework
rbackman
parents:
5895
diff
changeset
|
777 \ |
0 | 778 do_intrinsic(_arraycopy, java_lang_System, arraycopy_name, arraycopy_signature, F_S) \ |
779 do_name( arraycopy_name, "arraycopy") \ | |
780 do_signature(arraycopy_signature, "(Ljava/lang/Object;ILjava/lang/Object;II)V") \ | |
781 do_intrinsic(_isInterrupted, java_lang_Thread, isInterrupted_name, isInterrupted_signature, F_R) \ | |
782 do_name( isInterrupted_name, "isInterrupted") \ | |
783 do_signature(isInterrupted_signature, "(Z)Z") \ | |
784 do_intrinsic(_currentThread, java_lang_Thread, currentThread_name, currentThread_signature, F_S) \ | |
785 do_name( currentThread_name, "currentThread") \ | |
786 do_signature(currentThread_signature, "()Ljava/lang/Thread;") \ | |
787 \ | |
788 /* reflective intrinsics, for java/lang/Class, etc. */ \ | |
789 do_intrinsic(_isAssignableFrom, java_lang_Class, isAssignableFrom_name, class_boolean_signature, F_RN) \ | |
790 do_name( isAssignableFrom_name, "isAssignableFrom") \ | |
791 do_intrinsic(_isInstance, java_lang_Class, isInstance_name, object_boolean_signature, F_RN) \ | |
792 do_name( isInstance_name, "isInstance") \ | |
793 do_intrinsic(_getModifiers, java_lang_Class, getModifiers_name, void_int_signature, F_RN) \ | |
794 do_name( getModifiers_name, "getModifiers") \ | |
795 do_intrinsic(_isInterface, java_lang_Class, isInterface_name, void_boolean_signature, F_RN) \ | |
796 do_name( isInterface_name, "isInterface") \ | |
797 do_intrinsic(_isArray, java_lang_Class, isArray_name, void_boolean_signature, F_RN) \ | |
798 do_name( isArray_name, "isArray") \ | |
799 do_intrinsic(_isPrimitive, java_lang_Class, isPrimitive_name, void_boolean_signature, F_RN) \ | |
800 do_name( isPrimitive_name, "isPrimitive") \ | |
801 do_intrinsic(_getSuperclass, java_lang_Class, getSuperclass_name, void_class_signature, F_RN) \ | |
802 do_name( getSuperclass_name, "getSuperclass") \ | |
803 do_intrinsic(_getComponentType, java_lang_Class, getComponentType_name, void_class_signature, F_RN) \ | |
804 do_name( getComponentType_name, "getComponentType") \ | |
805 \ | |
806 do_intrinsic(_getClassAccessFlags, sun_reflect_Reflection, getClassAccessFlags_name, class_int_signature, F_SN) \ | |
807 do_name( getClassAccessFlags_name, "getClassAccessFlags") \ | |
808 do_intrinsic(_getLength, java_lang_reflect_Array, getLength_name, object_int_signature, F_SN) \ | |
809 do_name( getLength_name, "getLength") \ | |
810 \ | |
8866
16885e702c88
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
7955
diff
changeset
|
811 do_intrinsic(_getCallerClass, sun_reflect_Reflection, getCallerClass_name, void_class_signature, F_SN) \ |
0 | 812 do_name( getCallerClass_name, "getCallerClass") \ |
813 \ | |
814 do_intrinsic(_newArray, java_lang_reflect_Array, newArray_name, newArray_signature, F_SN) \ | |
815 do_name( newArray_name, "newArray") \ | |
816 do_signature(newArray_signature, "(Ljava/lang/Class;I)Ljava/lang/Object;") \ | |
817 \ | |
818 do_intrinsic(_copyOf, java_util_Arrays, copyOf_name, copyOf_signature, F_S) \ | |
819 do_name( copyOf_name, "copyOf") \ | |
820 do_signature(copyOf_signature, "([Ljava/lang/Object;ILjava/lang/Class;)[Ljava/lang/Object;") \ | |
821 \ | |
822 do_intrinsic(_copyOfRange, java_util_Arrays, copyOfRange_name, copyOfRange_signature, F_S) \ | |
823 do_name( copyOfRange_name, "copyOfRange") \ | |
824 do_signature(copyOfRange_signature, "([Ljava/lang/Object;IILjava/lang/Class;)[Ljava/lang/Object;") \ | |
825 \ | |
169
9148c65abefc
6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents:
45
diff
changeset
|
826 do_intrinsic(_equalsC, java_util_Arrays, equals_name, equalsC_signature, F_S) \ |
9148c65abefc
6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents:
45
diff
changeset
|
827 do_signature(equalsC_signature, "([C[C)Z") \ |
9148c65abefc
6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents:
45
diff
changeset
|
828 \ |
0 | 829 do_intrinsic(_compareTo, java_lang_String, compareTo_name, string_int_signature, F_R) \ |
830 do_name( compareTo_name, "compareTo") \ | |
831 do_intrinsic(_indexOf, java_lang_String, indexOf_name, string_int_signature, F_R) \ | |
832 do_name( indexOf_name, "indexOf") \ | |
681 | 833 do_intrinsic(_equals, java_lang_String, equals_name, object_boolean_signature, F_R) \ |
0 | 834 \ |
835 do_class(java_nio_Buffer, "java/nio/Buffer") \ | |
836 do_intrinsic(_checkIndex, java_nio_Buffer, checkIndex_name, int_int_signature, F_R) \ | |
837 do_name( checkIndex_name, "checkIndex") \ | |
838 \ | |
7637
b30b3c2a0cf2
6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents:
7615
diff
changeset
|
839 do_class(sun_nio_cs_iso8859_1_Encoder, "sun/nio/cs/ISO_8859_1$Encoder") \ |
b30b3c2a0cf2
6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents:
7615
diff
changeset
|
840 do_intrinsic(_encodeISOArray, sun_nio_cs_iso8859_1_Encoder, encodeISOArray_name, encodeISOArray_signature, F_S) \ |
b30b3c2a0cf2
6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents:
7615
diff
changeset
|
841 do_name( encodeISOArray_name, "encodeISOArray") \ |
b30b3c2a0cf2
6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents:
7615
diff
changeset
|
842 do_signature(encodeISOArray_signature, "([CI[BII)I") \ |
b30b3c2a0cf2
6896617: Optimize sun.nio.cs.ISO_8859_1$Encode.encodeArrayLoop() on x86
kvn
parents:
7615
diff
changeset
|
843 \ |
3249
e1162778c1c8
7009266: G1: assert(obj->is_oop_or_null(true )) failed: Error
johnc
parents:
2357
diff
changeset
|
844 /* java/lang/ref/Reference */ \ |
e1162778c1c8
7009266: G1: assert(obj->is_oop_or_null(true )) failed: Error
johnc
parents:
2357
diff
changeset
|
845 do_intrinsic(_Reference_get, java_lang_ref_Reference, get_name, void_object_signature, F_R) \ |
e1162778c1c8
7009266: G1: assert(obj->is_oop_or_null(true )) failed: Error
johnc
parents:
2357
diff
changeset
|
846 \ |
6894 | 847 /* support for com.sum.crypto.provider.AESCrypt and some of its callers */ \ |
848 do_class(com_sun_crypto_provider_aescrypt, "com/sun/crypto/provider/AESCrypt") \ | |
849 do_intrinsic(_aescrypt_encryptBlock, com_sun_crypto_provider_aescrypt, encryptBlock_name, byteArray_int_byteArray_int_signature, F_R) \ | |
850 do_intrinsic(_aescrypt_decryptBlock, com_sun_crypto_provider_aescrypt, decryptBlock_name, byteArray_int_byteArray_int_signature, F_R) \ | |
851 do_name( encryptBlock_name, "encryptBlock") \ | |
852 do_name( decryptBlock_name, "decryptBlock") \ | |
853 do_signature(byteArray_int_byteArray_int_signature, "([BI[BI)V") \ | |
854 \ | |
855 do_class(com_sun_crypto_provider_cipherBlockChaining, "com/sun/crypto/provider/CipherBlockChaining") \ | |
856 do_intrinsic(_cipherBlockChaining_encryptAESCrypt, com_sun_crypto_provider_cipherBlockChaining, encrypt_name, byteArray_int_int_byteArray_int_signature, F_R) \ | |
857 do_intrinsic(_cipherBlockChaining_decryptAESCrypt, com_sun_crypto_provider_cipherBlockChaining, decrypt_name, byteArray_int_int_byteArray_int_signature, F_R) \ | |
858 do_name( encrypt_name, "encrypt") \ | |
859 do_name( decrypt_name, "decrypt") \ | |
14909 | 860 do_signature(byteArray_int_int_byteArray_int_signature, "([BII[BI)V") \ |
6894 | 861 \ |
11080
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
862 /* support for java.util.zip */ \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
863 do_class(java_util_zip_CRC32, "java/util/zip/CRC32") \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
864 do_intrinsic(_updateCRC32, java_util_zip_CRC32, update_name, int2_int_signature, F_SN) \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
865 do_name( update_name, "update") \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
866 do_intrinsic(_updateBytesCRC32, java_util_zip_CRC32, updateBytes_name, updateBytes_signature, F_SN) \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
867 do_name( updateBytes_name, "updateBytes") \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
868 do_signature(updateBytes_signature, "(I[BII)I") \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
869 do_intrinsic(_updateByteBufferCRC32, java_util_zip_CRC32, updateByteBuffer_name, updateByteBuffer_signature, F_SN) \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
870 do_name( updateByteBuffer_name, "updateByteBuffer") \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
871 do_signature(updateByteBuffer_signature, "(IJII)I") \ |
b800986664f4
7088419: Use x86 Hardware CRC32 Instruction with java.util.zip.CRC32
drchase
parents:
11019
diff
changeset
|
872 \ |
0 | 873 /* support for sun.misc.Unsafe */ \ |
874 do_class(sun_misc_Unsafe, "sun/misc/Unsafe") \ | |
875 \ | |
876 do_intrinsic(_allocateInstance, sun_misc_Unsafe, allocateInstance_name, allocateInstance_signature, F_RN) \ | |
877 do_name( allocateInstance_name, "allocateInstance") \ | |
878 do_signature(allocateInstance_signature, "(Ljava/lang/Class;)Ljava/lang/Object;") \ | |
879 do_intrinsic(_copyMemory, sun_misc_Unsafe, copyMemory_name, copyMemory_signature, F_RN) \ | |
880 do_name( copyMemory_name, "copyMemory") \ | |
881 do_signature(copyMemory_signature, "(Ljava/lang/Object;JLjava/lang/Object;JJ)V") \ | |
882 do_intrinsic(_park, sun_misc_Unsafe, park_name, park_signature, F_RN) \ | |
883 do_name( park_name, "park") \ | |
884 do_signature(park_signature, "(ZJ)V") \ | |
885 do_intrinsic(_unpark, sun_misc_Unsafe, unpark_name, unpark_signature, F_RN) \ | |
886 do_name( unpark_name, "unpark") \ | |
887 do_alias( unpark_signature, /*(LObject;)V*/ object_void_signature) \ | |
7425 | 888 do_intrinsic(_loadFence, sun_misc_Unsafe, loadFence_name, loadFence_signature, F_RN) \ |
889 do_name( loadFence_name, "loadFence") \ | |
890 do_alias( loadFence_signature, void_method_signature) \ | |
891 do_intrinsic(_storeFence, sun_misc_Unsafe, storeFence_name, storeFence_signature, F_RN) \ | |
892 do_name( storeFence_name, "storeFence") \ | |
893 do_alias( storeFence_signature, void_method_signature) \ | |
894 do_intrinsic(_fullFence, sun_misc_Unsafe, fullFence_name, fullFence_signature, F_RN) \ | |
895 do_name( fullFence_name, "fullFence") \ | |
896 do_alias( fullFence_signature, void_method_signature) \ | |
0 | 897 \ |
898 /* unsafe memory references (there are a lot of them...) */ \ | |
899 do_signature(getObject_signature, "(Ljava/lang/Object;J)Ljava/lang/Object;") \ | |
900 do_signature(putObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;)V") \ | |
901 do_signature(getBoolean_signature, "(Ljava/lang/Object;J)Z") \ | |
902 do_signature(putBoolean_signature, "(Ljava/lang/Object;JZ)V") \ | |
903 do_signature(getByte_signature, "(Ljava/lang/Object;J)B") \ | |
904 do_signature(putByte_signature, "(Ljava/lang/Object;JB)V") \ | |
905 do_signature(getShort_signature, "(Ljava/lang/Object;J)S") \ | |
906 do_signature(putShort_signature, "(Ljava/lang/Object;JS)V") \ | |
907 do_signature(getChar_signature, "(Ljava/lang/Object;J)C") \ | |
908 do_signature(putChar_signature, "(Ljava/lang/Object;JC)V") \ | |
909 do_signature(getInt_signature, "(Ljava/lang/Object;J)I") \ | |
910 do_signature(putInt_signature, "(Ljava/lang/Object;JI)V") \ | |
911 do_signature(getLong_signature, "(Ljava/lang/Object;J)J") \ | |
912 do_signature(putLong_signature, "(Ljava/lang/Object;JJ)V") \ | |
913 do_signature(getFloat_signature, "(Ljava/lang/Object;J)F") \ | |
914 do_signature(putFloat_signature, "(Ljava/lang/Object;JF)V") \ | |
915 do_signature(getDouble_signature, "(Ljava/lang/Object;J)D") \ | |
916 do_signature(putDouble_signature, "(Ljava/lang/Object;JD)V") \ | |
917 \ | |
918 do_name(getObject_name,"getObject") do_name(putObject_name,"putObject") \ | |
919 do_name(getBoolean_name,"getBoolean") do_name(putBoolean_name,"putBoolean") \ | |
920 do_name(getByte_name,"getByte") do_name(putByte_name,"putByte") \ | |
921 do_name(getShort_name,"getShort") do_name(putShort_name,"putShort") \ | |
922 do_name(getChar_name,"getChar") do_name(putChar_name,"putChar") \ | |
923 do_name(getInt_name,"getInt") do_name(putInt_name,"putInt") \ | |
924 do_name(getLong_name,"getLong") do_name(putLong_name,"putLong") \ | |
925 do_name(getFloat_name,"getFloat") do_name(putFloat_name,"putFloat") \ | |
926 do_name(getDouble_name,"getDouble") do_name(putDouble_name,"putDouble") \ | |
927 \ | |
928 do_intrinsic(_getObject, sun_misc_Unsafe, getObject_name, getObject_signature, F_RN) \ | |
929 do_intrinsic(_getBoolean, sun_misc_Unsafe, getBoolean_name, getBoolean_signature, F_RN) \ | |
930 do_intrinsic(_getByte, sun_misc_Unsafe, getByte_name, getByte_signature, F_RN) \ | |
931 do_intrinsic(_getShort, sun_misc_Unsafe, getShort_name, getShort_signature, F_RN) \ | |
932 do_intrinsic(_getChar, sun_misc_Unsafe, getChar_name, getChar_signature, F_RN) \ | |
933 do_intrinsic(_getInt, sun_misc_Unsafe, getInt_name, getInt_signature, F_RN) \ | |
934 do_intrinsic(_getLong, sun_misc_Unsafe, getLong_name, getLong_signature, F_RN) \ | |
935 do_intrinsic(_getFloat, sun_misc_Unsafe, getFloat_name, getFloat_signature, F_RN) \ | |
936 do_intrinsic(_getDouble, sun_misc_Unsafe, getDouble_name, getDouble_signature, F_RN) \ | |
937 do_intrinsic(_putObject, sun_misc_Unsafe, putObject_name, putObject_signature, F_RN) \ | |
938 do_intrinsic(_putBoolean, sun_misc_Unsafe, putBoolean_name, putBoolean_signature, F_RN) \ | |
939 do_intrinsic(_putByte, sun_misc_Unsafe, putByte_name, putByte_signature, F_RN) \ | |
940 do_intrinsic(_putShort, sun_misc_Unsafe, putShort_name, putShort_signature, F_RN) \ | |
941 do_intrinsic(_putChar, sun_misc_Unsafe, putChar_name, putChar_signature, F_RN) \ | |
942 do_intrinsic(_putInt, sun_misc_Unsafe, putInt_name, putInt_signature, F_RN) \ | |
943 do_intrinsic(_putLong, sun_misc_Unsafe, putLong_name, putLong_signature, F_RN) \ | |
944 do_intrinsic(_putFloat, sun_misc_Unsafe, putFloat_name, putFloat_signature, F_RN) \ | |
945 do_intrinsic(_putDouble, sun_misc_Unsafe, putDouble_name, putDouble_signature, F_RN) \ | |
946 \ | |
947 do_name(getObjectVolatile_name,"getObjectVolatile") do_name(putObjectVolatile_name,"putObjectVolatile") \ | |
948 do_name(getBooleanVolatile_name,"getBooleanVolatile") do_name(putBooleanVolatile_name,"putBooleanVolatile") \ | |
949 do_name(getByteVolatile_name,"getByteVolatile") do_name(putByteVolatile_name,"putByteVolatile") \ | |
950 do_name(getShortVolatile_name,"getShortVolatile") do_name(putShortVolatile_name,"putShortVolatile") \ | |
951 do_name(getCharVolatile_name,"getCharVolatile") do_name(putCharVolatile_name,"putCharVolatile") \ | |
952 do_name(getIntVolatile_name,"getIntVolatile") do_name(putIntVolatile_name,"putIntVolatile") \ | |
953 do_name(getLongVolatile_name,"getLongVolatile") do_name(putLongVolatile_name,"putLongVolatile") \ | |
954 do_name(getFloatVolatile_name,"getFloatVolatile") do_name(putFloatVolatile_name,"putFloatVolatile") \ | |
955 do_name(getDoubleVolatile_name,"getDoubleVolatile") do_name(putDoubleVolatile_name,"putDoubleVolatile") \ | |
956 \ | |
957 do_intrinsic(_getObjectVolatile, sun_misc_Unsafe, getObjectVolatile_name, getObject_signature, F_RN) \ | |
958 do_intrinsic(_getBooleanVolatile, sun_misc_Unsafe, getBooleanVolatile_name, getBoolean_signature, F_RN) \ | |
959 do_intrinsic(_getByteVolatile, sun_misc_Unsafe, getByteVolatile_name, getByte_signature, F_RN) \ | |
960 do_intrinsic(_getShortVolatile, sun_misc_Unsafe, getShortVolatile_name, getShort_signature, F_RN) \ | |
961 do_intrinsic(_getCharVolatile, sun_misc_Unsafe, getCharVolatile_name, getChar_signature, F_RN) \ | |
962 do_intrinsic(_getIntVolatile, sun_misc_Unsafe, getIntVolatile_name, getInt_signature, F_RN) \ | |
963 do_intrinsic(_getLongVolatile, sun_misc_Unsafe, getLongVolatile_name, getLong_signature, F_RN) \ | |
964 do_intrinsic(_getFloatVolatile, sun_misc_Unsafe, getFloatVolatile_name, getFloat_signature, F_RN) \ | |
965 do_intrinsic(_getDoubleVolatile, sun_misc_Unsafe, getDoubleVolatile_name, getDouble_signature, F_RN) \ | |
966 do_intrinsic(_putObjectVolatile, sun_misc_Unsafe, putObjectVolatile_name, putObject_signature, F_RN) \ | |
967 do_intrinsic(_putBooleanVolatile, sun_misc_Unsafe, putBooleanVolatile_name, putBoolean_signature, F_RN) \ | |
968 do_intrinsic(_putByteVolatile, sun_misc_Unsafe, putByteVolatile_name, putByte_signature, F_RN) \ | |
969 do_intrinsic(_putShortVolatile, sun_misc_Unsafe, putShortVolatile_name, putShort_signature, F_RN) \ | |
970 do_intrinsic(_putCharVolatile, sun_misc_Unsafe, putCharVolatile_name, putChar_signature, F_RN) \ | |
971 do_intrinsic(_putIntVolatile, sun_misc_Unsafe, putIntVolatile_name, putInt_signature, F_RN) \ | |
972 do_intrinsic(_putLongVolatile, sun_misc_Unsafe, putLongVolatile_name, putLong_signature, F_RN) \ | |
973 do_intrinsic(_putFloatVolatile, sun_misc_Unsafe, putFloatVolatile_name, putFloat_signature, F_RN) \ | |
974 do_intrinsic(_putDoubleVolatile, sun_misc_Unsafe, putDoubleVolatile_name, putDouble_signature, F_RN) \ | |
975 \ | |
976 /* %%% these are redundant except perhaps for getAddress, but Unsafe has native methods for them */ \ | |
977 do_signature(getByte_raw_signature, "(J)B") \ | |
978 do_signature(putByte_raw_signature, "(JB)V") \ | |
979 do_signature(getShort_raw_signature, "(J)S") \ | |
980 do_signature(putShort_raw_signature, "(JS)V") \ | |
981 do_signature(getChar_raw_signature, "(J)C") \ | |
982 do_signature(putChar_raw_signature, "(JC)V") \ | |
983 do_signature(putInt_raw_signature, "(JI)V") \ | |
984 do_alias(getLong_raw_signature, /*(J)J*/ long_long_signature) \ | |
985 do_alias(putLong_raw_signature, /*(JJ)V*/ long_long_void_signature) \ | |
986 do_signature(getFloat_raw_signature, "(J)F") \ | |
987 do_signature(putFloat_raw_signature, "(JF)V") \ | |
988 do_alias(getDouble_raw_signature, /*(J)D*/ long_double_signature) \ | |
989 do_signature(putDouble_raw_signature, "(JD)V") \ | |
990 do_alias(getAddress_raw_signature, /*(J)J*/ long_long_signature) \ | |
991 do_alias(putAddress_raw_signature, /*(JJ)V*/ long_long_void_signature) \ | |
992 \ | |
993 do_name( getAddress_name, "getAddress") \ | |
994 do_name( putAddress_name, "putAddress") \ | |
995 \ | |
996 do_intrinsic(_getByte_raw, sun_misc_Unsafe, getByte_name, getByte_raw_signature, F_RN) \ | |
997 do_intrinsic(_getShort_raw, sun_misc_Unsafe, getShort_name, getShort_raw_signature, F_RN) \ | |
998 do_intrinsic(_getChar_raw, sun_misc_Unsafe, getChar_name, getChar_raw_signature, F_RN) \ | |
643
c771b7f43bbf
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
514
diff
changeset
|
999 do_intrinsic(_getInt_raw, sun_misc_Unsafe, getInt_name, long_int_signature, F_RN) \ |
0 | 1000 do_intrinsic(_getLong_raw, sun_misc_Unsafe, getLong_name, getLong_raw_signature, F_RN) \ |
1001 do_intrinsic(_getFloat_raw, sun_misc_Unsafe, getFloat_name, getFloat_raw_signature, F_RN) \ | |
1002 do_intrinsic(_getDouble_raw, sun_misc_Unsafe, getDouble_name, getDouble_raw_signature, F_RN) \ | |
1003 do_intrinsic(_getAddress_raw, sun_misc_Unsafe, getAddress_name, getAddress_raw_signature, F_RN) \ | |
1004 do_intrinsic(_putByte_raw, sun_misc_Unsafe, putByte_name, putByte_raw_signature, F_RN) \ | |
1005 do_intrinsic(_putShort_raw, sun_misc_Unsafe, putShort_name, putShort_raw_signature, F_RN) \ | |
1006 do_intrinsic(_putChar_raw, sun_misc_Unsafe, putChar_name, putChar_raw_signature, F_RN) \ | |
1007 do_intrinsic(_putInt_raw, sun_misc_Unsafe, putInt_name, putInt_raw_signature, F_RN) \ | |
1008 do_intrinsic(_putLong_raw, sun_misc_Unsafe, putLong_name, putLong_raw_signature, F_RN) \ | |
1009 do_intrinsic(_putFloat_raw, sun_misc_Unsafe, putFloat_name, putFloat_raw_signature, F_RN) \ | |
1010 do_intrinsic(_putDouble_raw, sun_misc_Unsafe, putDouble_name, putDouble_raw_signature, F_RN) \ | |
1011 do_intrinsic(_putAddress_raw, sun_misc_Unsafe, putAddress_name, putAddress_raw_signature, F_RN) \ | |
1012 \ | |
1013 do_intrinsic(_compareAndSwapObject, sun_misc_Unsafe, compareAndSwapObject_name, compareAndSwapObject_signature, F_RN) \ | |
1014 do_name( compareAndSwapObject_name, "compareAndSwapObject") \ | |
1015 do_signature(compareAndSwapObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;Ljava/lang/Object;)Z") \ | |
1016 do_intrinsic(_compareAndSwapLong, sun_misc_Unsafe, compareAndSwapLong_name, compareAndSwapLong_signature, F_RN) \ | |
1017 do_name( compareAndSwapLong_name, "compareAndSwapLong") \ | |
1018 do_signature(compareAndSwapLong_signature, "(Ljava/lang/Object;JJJ)Z") \ | |
1019 do_intrinsic(_compareAndSwapInt, sun_misc_Unsafe, compareAndSwapInt_name, compareAndSwapInt_signature, F_RN) \ | |
1020 do_name( compareAndSwapInt_name, "compareAndSwapInt") \ | |
1021 do_signature(compareAndSwapInt_signature, "(Ljava/lang/Object;JII)Z") \ | |
1022 do_intrinsic(_putOrderedObject, sun_misc_Unsafe, putOrderedObject_name, putOrderedObject_signature, F_RN) \ | |
1023 do_name( putOrderedObject_name, "putOrderedObject") \ | |
1024 do_alias( putOrderedObject_signature, /*(LObject;JLObject;)V*/ putObject_signature) \ | |
1025 do_intrinsic(_putOrderedLong, sun_misc_Unsafe, putOrderedLong_name, putOrderedLong_signature, F_RN) \ | |
1026 do_name( putOrderedLong_name, "putOrderedLong") \ | |
1027 do_alias( putOrderedLong_signature, /*(Ljava/lang/Object;JJ)V*/ putLong_signature) \ | |
1028 do_intrinsic(_putOrderedInt, sun_misc_Unsafe, putOrderedInt_name, putOrderedInt_signature, F_RN) \ | |
1029 do_name( putOrderedInt_name, "putOrderedInt") \ | |
1030 do_alias( putOrderedInt_signature, /*(Ljava/lang/Object;JI)V*/ putInt_signature) \ | |
1031 \ | |
6795
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1032 do_intrinsic(_getAndAddInt, sun_misc_Unsafe, getAndAddInt_name, getAndAddInt_signature, F_R) \ |
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1033 do_name( getAndAddInt_name, "getAndAddInt") \ |
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1034 do_signature(getAndAddInt_signature, "(Ljava/lang/Object;JI)I" ) \ |
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1035 do_intrinsic(_getAndAddLong, sun_misc_Unsafe, getAndAddLong_name, getAndAddLong_signature, F_R) \ |
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1036 do_name( getAndAddLong_name, "getAndAddLong") \ |
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1037 do_signature(getAndAddLong_signature, "(Ljava/lang/Object;JJ)J" ) \ |
7429
a46457045d66
8004330: Add missing Unsafe entry points for addAndGet() family
kvn
parents:
7425
diff
changeset
|
1038 do_intrinsic(_getAndSetInt, sun_misc_Unsafe, getAndSetInt_name, getAndSetInt_signature, F_R) \ |
a46457045d66
8004330: Add missing Unsafe entry points for addAndGet() family
kvn
parents:
7425
diff
changeset
|
1039 do_name( getAndSetInt_name, "getAndSetInt") \ |
6795
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1040 do_alias( getAndSetInt_signature, /*"(Ljava/lang/Object;JI)I"*/ getAndAddInt_signature) \ |
7429
a46457045d66
8004330: Add missing Unsafe entry points for addAndGet() family
kvn
parents:
7425
diff
changeset
|
1041 do_intrinsic(_getAndSetLong, sun_misc_Unsafe, getAndSetLong_name, getAndSetLong_signature, F_R) \ |
a46457045d66
8004330: Add missing Unsafe entry points for addAndGet() family
kvn
parents:
7425
diff
changeset
|
1042 do_name( getAndSetLong_name, "getAndSetLong") \ |
6795
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1043 do_alias( getAndSetLong_signature, /*"(Ljava/lang/Object;JJ)J"*/ getAndAddLong_signature) \ |
7429
a46457045d66
8004330: Add missing Unsafe entry points for addAndGet() family
kvn
parents:
7425
diff
changeset
|
1044 do_intrinsic(_getAndSetObject, sun_misc_Unsafe, getAndSetObject_name, getAndSetObject_signature, F_R)\ |
a46457045d66
8004330: Add missing Unsafe entry points for addAndGet() family
kvn
parents:
7425
diff
changeset
|
1045 do_name( getAndSetObject_name, "getAndSetObject") \ |
6795
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1046 do_signature(getAndSetObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;)Ljava/lang/Object;" ) \ |
7eca5de9e0b6
7023898: Intrinsify AtomicLongFieldUpdater.getAndIncrement()
roland
parents:
6725
diff
changeset
|
1047 \ |
0 | 1048 /* prefetch_signature is shared by all prefetch variants */ \ |
1049 do_signature( prefetch_signature, "(Ljava/lang/Object;J)V") \ | |
1050 \ | |
1051 do_intrinsic(_prefetchRead, sun_misc_Unsafe, prefetchRead_name, prefetch_signature, F_RN) \ | |
1052 do_name( prefetchRead_name, "prefetchRead") \ | |
1053 do_intrinsic(_prefetchWrite, sun_misc_Unsafe, prefetchWrite_name, prefetch_signature, F_RN) \ | |
1054 do_name( prefetchWrite_name, "prefetchWrite") \ | |
1055 do_intrinsic(_prefetchReadStatic, sun_misc_Unsafe, prefetchReadStatic_name, prefetch_signature, F_SN) \ | |
1056 do_name( prefetchReadStatic_name, "prefetchReadStatic") \ | |
1057 do_intrinsic(_prefetchWriteStatic, sun_misc_Unsafe, prefetchWriteStatic_name, prefetch_signature, F_SN) \ | |
1058 do_name( prefetchWriteStatic_name, "prefetchWriteStatic") \ | |
856
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1059 /*== LAST_COMPILER_INLINE*/ \ |
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1060 /*the compiler does have special inlining code for these; bytecode inline is just fine */ \ |
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1061 \ |
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1062 do_intrinsic(_fillInStackTrace, java_lang_Throwable, fillInStackTrace_name, void_throwable_signature, F_RNY) \ |
1080
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1063 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1064 do_intrinsic(_StringBuilder_void, java_lang_StringBuilder, object_initializer_name, void_method_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1065 do_intrinsic(_StringBuilder_int, java_lang_StringBuilder, object_initializer_name, int_void_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1066 do_intrinsic(_StringBuilder_String, java_lang_StringBuilder, object_initializer_name, string_void_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1067 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1068 do_intrinsic(_StringBuilder_append_char, java_lang_StringBuilder, append_name, char_StringBuilder_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1069 do_intrinsic(_StringBuilder_append_int, java_lang_StringBuilder, append_name, int_StringBuilder_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1070 do_intrinsic(_StringBuilder_append_String, java_lang_StringBuilder, append_name, String_StringBuilder_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1071 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1072 do_intrinsic(_StringBuilder_toString, java_lang_StringBuilder, toString_name, void_string_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1073 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1074 do_intrinsic(_StringBuffer_void, java_lang_StringBuffer, object_initializer_name, void_method_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1075 do_intrinsic(_StringBuffer_int, java_lang_StringBuffer, object_initializer_name, int_void_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1076 do_intrinsic(_StringBuffer_String, java_lang_StringBuffer, object_initializer_name, string_void_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1077 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1078 do_intrinsic(_StringBuffer_append_char, java_lang_StringBuffer, append_name, char_StringBuffer_signature, F_Y) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1079 do_intrinsic(_StringBuffer_append_int, java_lang_StringBuffer, append_name, int_StringBuffer_signature, F_Y) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1080 do_intrinsic(_StringBuffer_append_String, java_lang_StringBuffer, append_name, String_StringBuffer_signature, F_Y) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1081 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1082 do_intrinsic(_StringBuffer_toString, java_lang_StringBuffer, toString_name, void_string_signature, F_Y) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1083 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1084 do_intrinsic(_Integer_toString, java_lang_Integer, toString_name, int_String_signature, F_S) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1085 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1086 do_intrinsic(_String_String, java_lang_String, object_initializer_name, string_void_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1087 \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1088 do_intrinsic(_Object_init, java_lang_Object, object_initializer_name, void_method_signature, F_R) \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1089 /* (symbol object_initializer_name defined above) */ \ |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1090 \ |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1396
diff
changeset
|
1091 do_intrinsic(_invoke, java_lang_reflect_Method, invoke_name, object_object_array_object_signature, F_R) \ |
856
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1092 /* (symbols invoke_name and invoke_signature defined above) */ \ |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1093 /* the polymorphic MH intrinsics must be in compact order, with _invokeGeneric first and _linkToInterface last */ \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1094 do_intrinsic(_invokeGeneric, java_lang_invoke_MethodHandle, invoke_name, star_name, F_RN) \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1095 do_intrinsic(_invokeBasic, java_lang_invoke_MethodHandle, invokeBasic_name, star_name, F_RN) \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1096 do_intrinsic(_linkToVirtual, java_lang_invoke_MethodHandle, linkToVirtual_name, star_name, F_SN) \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1097 do_intrinsic(_linkToStatic, java_lang_invoke_MethodHandle, linkToStatic_name, star_name, F_SN) \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1098 do_intrinsic(_linkToSpecial, java_lang_invoke_MethodHandle, linkToSpecial_name, star_name, F_SN) \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1099 do_intrinsic(_linkToInterface, java_lang_invoke_MethodHandle, linkToInterface_name, star_name, F_SN) \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1100 /* special marker for bytecode generated for the JVM from a LambdaForm: */ \ |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1101 do_intrinsic(_compiledLambdaForm, java_lang_invoke_MethodHandle, compiledLambdaForm_name, star_name, F_RN) \ |
3905
c26de9aef2ed
7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents:
3900
diff
changeset
|
1102 \ |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1103 /* unboxing methods: */ \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1104 do_intrinsic(_booleanValue, java_lang_Boolean, booleanValue_name, void_boolean_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1105 do_name( booleanValue_name, "booleanValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1106 do_intrinsic(_byteValue, java_lang_Byte, byteValue_name, void_byte_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1107 do_name( byteValue_name, "byteValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1108 do_intrinsic(_charValue, java_lang_Character, charValue_name, void_char_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1109 do_name( charValue_name, "charValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1110 do_intrinsic(_shortValue, java_lang_Short, shortValue_name, void_short_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1111 do_name( shortValue_name, "shortValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1112 do_intrinsic(_intValue, java_lang_Integer, intValue_name, void_int_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1113 do_name( intValue_name, "intValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1114 do_intrinsic(_longValue, java_lang_Long, longValue_name, void_long_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1115 do_name( longValue_name, "longValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1116 do_intrinsic(_floatValue, java_lang_Float, floatValue_name, void_float_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1117 do_name( floatValue_name, "floatValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1118 do_intrinsic(_doubleValue, java_lang_Double, doubleValue_name, void_double_signature, F_R) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1119 do_name( doubleValue_name, "doubleValue") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1120 \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1121 /* boxing methods: */ \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1122 do_name( valueOf_name, "valueOf") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1123 do_intrinsic(_Boolean_valueOf, java_lang_Boolean, valueOf_name, Boolean_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1124 do_name( Boolean_valueOf_signature, "(Z)Ljava/lang/Boolean;") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1125 do_intrinsic(_Byte_valueOf, java_lang_Byte, valueOf_name, Byte_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1126 do_name( Byte_valueOf_signature, "(B)Ljava/lang/Byte;") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1127 do_intrinsic(_Character_valueOf, java_lang_Character, valueOf_name, Character_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1128 do_name( Character_valueOf_signature, "(C)Ljava/lang/Character;") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1129 do_intrinsic(_Short_valueOf, java_lang_Short, valueOf_name, Short_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1130 do_name( Short_valueOf_signature, "(S)Ljava/lang/Short;") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1131 do_intrinsic(_Integer_valueOf, java_lang_Integer, valueOf_name, Integer_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1132 do_name( Integer_valueOf_signature, "(I)Ljava/lang/Integer;") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1133 do_intrinsic(_Long_valueOf, java_lang_Long, valueOf_name, Long_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1134 do_name( Long_valueOf_signature, "(J)Ljava/lang/Long;") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1135 do_intrinsic(_Float_valueOf, java_lang_Float, valueOf_name, Float_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1136 do_name( Float_valueOf_signature, "(F)Ljava/lang/Float;") \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1137 do_intrinsic(_Double_valueOf, java_lang_Double, valueOf_name, Double_valueOf_signature, F_S) \ |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1138 do_name( Double_valueOf_signature, "(D)Ljava/lang/Double;") \ |
856
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1139 \ |
0 | 1140 /*end*/ |
1141 | |
1142 | |
1143 | |
856
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1144 |
0 | 1145 // Class vmSymbols |
1146 | |
1147 class vmSymbols: AllStatic { | |
3962
cb315dc80374
7092278: "jmap -finalizerinfo" throws "sun.jvm.hotspot.utilities.AssertionFailure: invalid cp index 0 137"
never
parents:
3938
diff
changeset
|
1148 friend class vmIntrinsics; |
cb315dc80374
7092278: "jmap -finalizerinfo" throws "sun.jvm.hotspot.utilities.AssertionFailure: invalid cp index 0 137"
never
parents:
3938
diff
changeset
|
1149 friend class VMStructs; |
0 | 1150 public: |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1151 // enum for figuring positions and size of array holding Symbol*s |
0 | 1152 enum SID { |
1153 NO_SID = 0, | |
1154 | |
1155 #define VM_SYMBOL_ENUM(name, string) VM_SYMBOL_ENUM_NAME(name), | |
1156 VM_SYMBOLS_DO(VM_SYMBOL_ENUM, VM_ALIAS_IGNORE) | |
1157 #undef VM_SYMBOL_ENUM | |
1158 | |
1159 SID_LIMIT, | |
1160 | |
1161 #define VM_ALIAS_ENUM(name, def) VM_SYMBOL_ENUM_NAME(name) = VM_SYMBOL_ENUM_NAME(def), | |
1162 VM_SYMBOLS_DO(VM_SYMBOL_IGNORE, VM_ALIAS_ENUM) | |
1163 #undef VM_ALIAS_ENUM | |
1164 | |
1165 FIRST_SID = NO_SID + 1 | |
1166 }; | |
1167 enum { | |
1168 log2_SID_LIMIT = 10 // checked by an assert at start-up | |
1169 }; | |
1170 | |
1171 private: | |
1172 // The symbol array | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1173 static Symbol* _symbols[]; |
0 | 1174 |
1175 // Field signatures indexed by BasicType. | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1176 static Symbol* _type_signatures[T_VOID+1]; |
0 | 1177 |
1178 public: | |
1179 // Initialization | |
1180 static void initialize(TRAPS); | |
1181 // Accessing | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1182 #define VM_SYMBOL_DECLARE(name, ignore) \ |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1183 static Symbol* name() { \ |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1184 return _symbols[VM_SYMBOL_ENUM_NAME(name)]; \ |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1185 } |
0 | 1186 VM_SYMBOLS_DO(VM_SYMBOL_DECLARE, VM_SYMBOL_DECLARE) |
1187 #undef VM_SYMBOL_DECLARE | |
1188 | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1189 // Sharing support |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1190 static void symbols_do(SymbolClosure* f); |
6725
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6271
diff
changeset
|
1191 static void serialize(SerializeClosure* soc); |
0 | 1192 |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1193 static Symbol* type_signature(BasicType t) { |
0 | 1194 assert((uint)t < T_VOID+1, "range check"); |
1195 assert(_type_signatures[t] != NULL, "domain check"); | |
1196 return _type_signatures[t]; | |
1197 } | |
1198 // inverse of type_signature; returns T_OBJECT if s is not recognized | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1199 static BasicType signature_type(Symbol* s); |
0 | 1200 |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1201 static Symbol* symbol_at(SID id) { |
0 | 1202 assert(id >= FIRST_SID && id < SID_LIMIT, "oob"); |
1203 assert(_symbols[id] != NULL, "init"); | |
1204 return _symbols[id]; | |
1205 } | |
1206 | |
1207 // Returns symbol's SID if one is assigned, else NO_SID. | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
2129
diff
changeset
|
1208 static SID find_sid(Symbol* symbol); |
2356
72dee110246f
6839872: remove implementation inheritance from JSR 292 APIs
jrose
parents:
2202
diff
changeset
|
1209 static SID find_sid(const char* symbol_name); |
0 | 1210 |
1211 #ifndef PRODUCT | |
1212 // No need for this in the product: | |
1213 static const char* name_for(SID sid); | |
1214 #endif //PRODUCT | |
1215 }; | |
1216 | |
1217 // VM Intrinsic ID's uniquely identify some very special methods | |
1218 class vmIntrinsics: AllStatic { | |
1219 friend class vmSymbols; | |
1220 friend class ciObjectFactory; | |
1221 | |
1222 public: | |
1223 // Accessing | |
1224 enum ID { | |
1225 _none = 0, // not an intrinsic (default answer) | |
1226 | |
1227 #define VM_INTRINSIC_ENUM(id, klass, name, sig, flags) id, | |
1228 VM_INTRINSICS_DO(VM_INTRINSIC_ENUM, | |
1229 VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_ALIAS_IGNORE) | |
1230 #undef VM_INTRINSIC_ENUM | |
1231 | |
1232 ID_LIMIT, | |
856
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1233 LAST_COMPILER_INLINE = _prefetchWriteStatic, |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1234 FIRST_MH_SIG_POLY = _invokeGeneric, |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1235 FIRST_MH_STATIC = _linkToVirtual, |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1236 LAST_MH_SIG_POLY = _linkToInterface, |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
6222
diff
changeset
|
1237 |
0 | 1238 FIRST_ID = _none + 1 |
1239 }; | |
1240 | |
1241 enum Flags { | |
1242 // AccessFlags syndromes relevant to intrinsics. | |
1243 F_none = 0, | |
1080
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1244 F_R, // !static ?native !synchronized (R="regular") |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1245 F_S, // static ?native !synchronized |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1246 F_Y, // !static ?native synchronized |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1247 F_RN, // !static native !synchronized |
7c57aead6d3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
1059
diff
changeset
|
1248 F_SN, // static native !synchronized |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1249 F_RNY, // !static native synchronized |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1250 |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1251 FLAG_LIMIT |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1252 }; |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1253 enum { |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1254 log2_FLAG_LIMIT = 4 // checked by an assert at start-up |
0 | 1255 }; |
1256 | |
1257 public: | |
1258 static ID ID_from(int raw_id) { | |
1259 assert(raw_id >= (int)_none && raw_id < (int)ID_LIMIT, | |
1260 "must be a valid intrinsic ID"); | |
1261 return (ID)raw_id; | |
1262 } | |
1263 | |
1264 static const char* name_at(ID id); | |
1265 | |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1266 private: |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1267 static ID find_id_impl(vmSymbols::SID holder, |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1268 vmSymbols::SID name, |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1269 vmSymbols::SID sig, |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1270 jshort flags); |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1271 |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1272 public: |
0 | 1273 // Given a method's class, name, signature, and access flags, report its ID. |
1274 static ID find_id(vmSymbols::SID holder, | |
1275 vmSymbols::SID name, | |
1276 vmSymbols::SID sig, | |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1277 jshort flags) { |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1278 ID id = find_id_impl(holder, name, sig, flags); |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1279 #ifdef ASSERT |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1280 // ID _none does not hold the following asserts. |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1281 if (id == _none) return id; |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1282 #endif |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1283 assert( class_for(id) == holder, "correct id"); |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1284 assert( name_for(id) == name, "correct id"); |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1285 assert(signature_for(id) == sig, "correct id"); |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1286 return id; |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1287 } |
0 | 1288 |
6725
da91efe96a93
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
6271
diff
changeset
|
1289 static void verify_method(ID actual_id, Method* m) PRODUCT_RETURN; |
0 | 1290 |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1291 // Find out the symbols behind an intrinsic: |
0 | 1292 static vmSymbols::SID class_for(ID id); |
1293 static vmSymbols::SID name_for(ID id); | |
1294 static vmSymbols::SID signature_for(ID id); | |
1295 static Flags flags_for(ID id); | |
1296 | |
1297 static const char* short_name_as_C_string(ID id, char* buf, int size); | |
856
75596850f863
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
775
diff
changeset
|
1298 |
1133
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1299 // Wrapper object methods: |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1300 static ID for_boxing(BasicType type); |
aa62b9388fce
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
1080
diff
changeset
|
1301 static ID for_unboxing(BasicType type); |
1138
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
1135
diff
changeset
|
1302 |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
1135
diff
changeset
|
1303 // Raw conversion: |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
1135
diff
changeset
|
1304 static ID for_raw_conversion(BasicType src, BasicType dest); |
0 | 1305 }; |
1972 | 1306 |
1307 #endif // SHARE_VM_CLASSFILE_VMSYMBOLS_HPP |