author | jrose |
Fri, 03 Dec 2010 15:53:57 -0800 | |
changeset 7436 | dbc43da3d512 |
parent 7397 | 5b173b4ca846 |
child 7900 | 4c7fc6332f7e |
permissions | -rw-r--r-- |
1 | 1 |
/* |
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5420
diff
changeset
|
2 |
* Copyright (c) 1997, 2010, Oracle and/or its affiliates. All rights reserved. |
1 | 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 |
* |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5420
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5420
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5420
diff
changeset
|
21 |
* questions. |
1 | 22 |
* |
23 |
*/ |
|
24 |
||
7397 | 25 |
#ifndef SHARE_VM_CLASSFILE_VMSYMBOLS_HPP |
26 |
#define SHARE_VM_CLASSFILE_VMSYMBOLS_HPP |
|
27 |
||
28 |
#include "oops/symbolOop.hpp" |
|
29 |
||
1 | 30 |
// The classes vmSymbols and vmSymbolHandles are a name spaces for fast lookup of |
31 |
// symbols commonly used in the VM. The first class return a symbolOop, while the |
|
32 |
// second class returns a SymbolHandle. The underlying data structure is shared |
|
33 |
// between the two classes. |
|
34 |
// |
|
35 |
// Sample usage: |
|
36 |
// |
|
37 |
// symbolOop obj = vmSymbols::java_lang_Object()(); |
|
38 |
// SymbolHandle handle = vmSymbolHandles::java_lang_Object(); |
|
39 |
||
40 |
||
41 |
// Useful sub-macros exported by this header file: |
|
42 |
||
43 |
#define VM_SYMBOL_ENUM_NAME(name) name##_enum |
|
44 |
#define VM_INTRINSIC_IGNORE(id, class, name, sig, flags) /*ignored*/ |
|
45 |
#define VM_SYMBOL_IGNORE(id, name) /*ignored*/ |
|
46 |
#define VM_ALIAS_IGNORE(id, id2) /*ignored*/ |
|
47 |
||
48 |
||
49 |
// Mapping function names to values. New entries should be added below. |
|
50 |
||
51 |
#define VM_SYMBOLS_DO(template, do_alias) \ |
|
52 |
/* commonly used class names */ \ |
|
53 |
template(java_lang_System, "java/lang/System") \ |
|
54 |
template(java_lang_Object, "java/lang/Object") \ |
|
55 |
template(java_lang_Class, "java/lang/Class") \ |
|
56 |
template(java_lang_String, "java/lang/String") \ |
|
2336
427ce3320578
6810653: Change String cache class used by Hotspot from String to StringValue
phh
parents:
2259
diff
changeset
|
57 |
template(java_lang_StringValue, "java/lang/StringValue") \ |
2342 | 58 |
template(java_lang_StringCache, "java/lang/StringValue$StringCache") \ |
1 | 59 |
template(java_lang_Thread, "java/lang/Thread") \ |
60 |
template(java_lang_ThreadGroup, "java/lang/ThreadGroup") \ |
|
61 |
template(java_lang_Cloneable, "java/lang/Cloneable") \ |
|
62 |
template(java_lang_Throwable, "java/lang/Throwable") \ |
|
63 |
template(java_lang_ClassLoader, "java/lang/ClassLoader") \ |
|
64 |
template(java_lang_ClassLoader_NativeLibrary, "java/lang/ClassLoader\x024NativeLibrary") \ |
|
65 |
template(java_lang_ThreadDeath, "java/lang/ThreadDeath") \ |
|
66 |
template(java_lang_Boolean, "java/lang/Boolean") \ |
|
67 |
template(java_lang_Character, "java/lang/Character") \ |
|
190
e9a0a9dcd4f6
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
1
diff
changeset
|
68 |
template(java_lang_Character_CharacterCache, "java/lang/Character$CharacterCache") \ |
1 | 69 |
template(java_lang_Float, "java/lang/Float") \ |
70 |
template(java_lang_Double, "java/lang/Double") \ |
|
71 |
template(java_lang_Byte, "java/lang/Byte") \ |
|
190
e9a0a9dcd4f6
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
1
diff
changeset
|
72 |
template(java_lang_Byte_Cache, "java/lang/Byte$ByteCache") \ |
1 | 73 |
template(java_lang_Short, "java/lang/Short") \ |
190
e9a0a9dcd4f6
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
1
diff
changeset
|
74 |
template(java_lang_Short_ShortCache, "java/lang/Short$ShortCache") \ |
1 | 75 |
template(java_lang_Integer, "java/lang/Integer") \ |
190
e9a0a9dcd4f6
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
1
diff
changeset
|
76 |
template(java_lang_Integer_IntegerCache, "java/lang/Integer$IntegerCache") \ |
1 | 77 |
template(java_lang_Long, "java/lang/Long") \ |
190
e9a0a9dcd4f6
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
1
diff
changeset
|
78 |
template(java_lang_Long_LongCache, "java/lang/Long$LongCache") \ |
1 | 79 |
template(java_lang_Shutdown, "java/lang/Shutdown") \ |
80 |
template(java_lang_ref_Reference, "java/lang/ref/Reference") \ |
|
81 |
template(java_lang_ref_SoftReference, "java/lang/ref/SoftReference") \ |
|
82 |
template(java_lang_ref_WeakReference, "java/lang/ref/WeakReference") \ |
|
83 |
template(java_lang_ref_FinalReference, "java/lang/ref/FinalReference") \ |
|
84 |
template(java_lang_ref_PhantomReference, "java/lang/ref/PhantomReference") \ |
|
85 |
template(java_lang_ref_Finalizer, "java/lang/ref/Finalizer") \ |
|
86 |
template(java_lang_reflect_AccessibleObject, "java/lang/reflect/AccessibleObject") \ |
|
87 |
template(java_lang_reflect_Method, "java/lang/reflect/Method") \ |
|
88 |
template(java_lang_reflect_Constructor, "java/lang/reflect/Constructor") \ |
|
89 |
template(java_lang_reflect_Field, "java/lang/reflect/Field") \ |
|
90 |
template(java_lang_reflect_Array, "java/lang/reflect/Array") \ |
|
91 |
template(java_lang_StringBuffer, "java/lang/StringBuffer") \ |
|
4450
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
92 |
template(java_lang_StringBuilder, "java/lang/StringBuilder") \ |
1 | 93 |
template(java_lang_CharSequence, "java/lang/CharSequence") \ |
94 |
template(java_security_AccessControlContext, "java/security/AccessControlContext") \ |
|
95 |
template(java_security_ProtectionDomain, "java/security/ProtectionDomain") \ |
|
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") \ |
|
191
314312979e7a
6621621: HashMap front cache should be enabled only with AggressiveOpts
phh
parents:
190
diff
changeset
|
107 |
template(java_util_HashMap, "java/util/HashMap") \ |
1 | 108 |
template(java_lang_Compiler, "java/lang/Compiler") \ |
109 |
template(sun_misc_Signal, "sun/misc/Signal") \ |
|
110 |
template(java_lang_AssertionStatusDirectives, "java/lang/AssertionStatusDirectives") \ |
|
191
314312979e7a
6621621: HashMap front cache should be enabled only with AggressiveOpts
phh
parents:
190
diff
changeset
|
111 |
template(sun_jkernel_DownloadManager, "sun/jkernel/DownloadManager") \ |
1 | 112 |
template(getBootClassPathEntryForClass_name, "getBootClassPathEntryForClass") \ |
4485
76684005deef
6888880: JKernel VM to inject the sun.jkernel.DownloadManager as a boot classloader hook
mchung
parents:
4429
diff
changeset
|
113 |
template(setBootClassLoaderHook_name, "setBootClassLoaderHook") \ |
1 | 114 |
\ |
115 |
/* class file format tags */ \ |
|
116 |
template(tag_source_file, "SourceFile") \ |
|
117 |
template(tag_inner_classes, "InnerClasses") \ |
|
118 |
template(tag_constant_value, "ConstantValue") \ |
|
119 |
template(tag_code, "Code") \ |
|
120 |
template(tag_exceptions, "Exceptions") \ |
|
121 |
template(tag_line_number_table, "LineNumberTable") \ |
|
122 |
template(tag_local_variable_table, "LocalVariableTable") \ |
|
123 |
template(tag_local_variable_type_table, "LocalVariableTypeTable") \ |
|
124 |
template(tag_stack_map_table, "StackMapTable") \ |
|
125 |
template(tag_synthetic, "Synthetic") \ |
|
126 |
template(tag_deprecated, "Deprecated") \ |
|
127 |
template(tag_source_debug_extension, "SourceDebugExtension") \ |
|
128 |
template(tag_signature, "Signature") \ |
|
129 |
template(tag_runtime_visible_annotations, "RuntimeVisibleAnnotations") \ |
|
130 |
template(tag_runtime_invisible_annotations, "RuntimeInvisibleAnnotations") \ |
|
131 |
template(tag_runtime_visible_parameter_annotations, "RuntimeVisibleParameterAnnotations") \ |
|
132 |
template(tag_runtime_invisible_parameter_annotations,"RuntimeInvisibleParameterAnnotations") \ |
|
133 |
template(tag_annotation_default, "AnnotationDefault") \ |
|
134 |
template(tag_enclosing_method, "EnclosingMethod") \ |
|
7436
dbc43da3d512
7001379: bootstrap method data needs to be moved from constant pool to a classfile attribute
jrose
parents:
7397
diff
changeset
|
135 |
template(tag_bootstrap_methods, "BootstrapMethods") \ |
1 | 136 |
\ |
137 |
/* exception klasses: at least all exceptions thrown by the VM have entries here */ \ |
|
138 |
template(java_lang_ArithmeticException, "java/lang/ArithmeticException") \ |
|
139 |
template(java_lang_ArrayIndexOutOfBoundsException, "java/lang/ArrayIndexOutOfBoundsException") \ |
|
140 |
template(java_lang_ArrayStoreException, "java/lang/ArrayStoreException") \ |
|
141 |
template(java_lang_ClassCastException, "java/lang/ClassCastException") \ |
|
142 |
template(java_lang_ClassNotFoundException, "java/lang/ClassNotFoundException") \ |
|
143 |
template(java_lang_CloneNotSupportedException, "java/lang/CloneNotSupportedException") \ |
|
144 |
template(java_lang_IllegalAccessException, "java/lang/IllegalAccessException") \ |
|
145 |
template(java_lang_IllegalArgumentException, "java/lang/IllegalArgumentException") \ |
|
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
146 |
template(java_lang_IllegalStateException, "java/lang/IllegalStateException") \ |
1 | 147 |
template(java_lang_IllegalMonitorStateException, "java/lang/IllegalMonitorStateException") \ |
148 |
template(java_lang_IllegalThreadStateException, "java/lang/IllegalThreadStateException") \ |
|
149 |
template(java_lang_IndexOutOfBoundsException, "java/lang/IndexOutOfBoundsException") \ |
|
150 |
template(java_lang_InstantiationException, "java/lang/InstantiationException") \ |
|
151 |
template(java_lang_InstantiationError, "java/lang/InstantiationError") \ |
|
152 |
template(java_lang_InterruptedException, "java/lang/InterruptedException") \ |
|
153 |
template(java_lang_LinkageError, "java/lang/LinkageError") \ |
|
154 |
template(java_lang_NegativeArraySizeException, "java/lang/NegativeArraySizeException") \ |
|
155 |
template(java_lang_NoSuchFieldException, "java/lang/NoSuchFieldException") \ |
|
156 |
template(java_lang_NoSuchMethodException, "java/lang/NoSuchMethodException") \ |
|
157 |
template(java_lang_NullPointerException, "java/lang/NullPointerException") \ |
|
158 |
template(java_lang_StringIndexOutOfBoundsException, "java/lang/StringIndexOutOfBoundsException")\ |
|
159 |
template(java_lang_InvalidClassException, "java/lang/InvalidClassException") \ |
|
160 |
template(java_lang_reflect_InvocationTargetException, "java/lang/reflect/InvocationTargetException") \ |
|
161 |
template(java_lang_Exception, "java/lang/Exception") \ |
|
162 |
template(java_lang_RuntimeException, "java/lang/RuntimeException") \ |
|
163 |
template(java_io_IOException, "java/io/IOException") \ |
|
164 |
template(java_security_PrivilegedActionException, "java/security/PrivilegedActionException") \ |
|
165 |
\ |
|
166 |
/* error klasses: at least all errors thrown by the VM have entries here */ \ |
|
167 |
template(java_lang_AbstractMethodError, "java/lang/AbstractMethodError") \ |
|
168 |
template(java_lang_ClassCircularityError, "java/lang/ClassCircularityError") \ |
|
169 |
template(java_lang_ClassFormatError, "java/lang/ClassFormatError") \ |
|
170 |
template(java_lang_UnsupportedClassVersionError, "java/lang/UnsupportedClassVersionError") \ |
|
171 |
template(java_lang_Error, "java/lang/Error") \ |
|
172 |
template(java_lang_ExceptionInInitializerError, "java/lang/ExceptionInInitializerError") \ |
|
173 |
template(java_lang_IllegalAccessError, "java/lang/IllegalAccessError") \ |
|
174 |
template(java_lang_IncompatibleClassChangeError, "java/lang/IncompatibleClassChangeError") \ |
|
175 |
template(java_lang_InternalError, "java/lang/InternalError") \ |
|
176 |
template(java_lang_NoClassDefFoundError, "java/lang/NoClassDefFoundError") \ |
|
177 |
template(java_lang_NoSuchFieldError, "java/lang/NoSuchFieldError") \ |
|
178 |
template(java_lang_NoSuchMethodError, "java/lang/NoSuchMethodError") \ |
|
179 |
template(java_lang_OutOfMemoryError, "java/lang/OutOfMemoryError") \ |
|
180 |
template(java_lang_UnsatisfiedLinkError, "java/lang/UnsatisfiedLinkError") \ |
|
181 |
template(java_lang_VerifyError, "java/lang/VerifyError") \ |
|
182 |
template(java_lang_SecurityException, "java/lang/SecurityException") \ |
|
183 |
template(java_lang_VirtualMachineError, "java/lang/VirtualMachineError") \ |
|
184 |
template(java_lang_StackOverflowError, "java/lang/StackOverflowError") \ |
|
185 |
template(java_lang_StackTraceElement, "java/lang/StackTraceElement") \ |
|
186 |
template(java_util_concurrent_locks_AbstractOwnableSynchronizer, "java/util/concurrent/locks/AbstractOwnableSynchronizer") \ |
|
187 |
\ |
|
188 |
/* class symbols needed by intrinsics */ \ |
|
189 |
VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, template, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_ALIAS_IGNORE) \ |
|
190 |
\ |
|
191 |
/* Support for reflection based on dynamic bytecode generation (JDK 1.4 and above) */ \ |
|
192 |
\ |
|
193 |
template(sun_reflect_FieldInfo, "sun/reflect/FieldInfo") \ |
|
194 |
template(sun_reflect_MethodInfo, "sun/reflect/MethodInfo") \ |
|
195 |
template(sun_reflect_MagicAccessorImpl, "sun/reflect/MagicAccessorImpl") \ |
|
196 |
template(sun_reflect_MethodAccessorImpl, "sun/reflect/MethodAccessorImpl") \ |
|
197 |
template(sun_reflect_ConstructorAccessorImpl, "sun/reflect/ConstructorAccessorImpl") \ |
|
198 |
template(sun_reflect_SerializationConstructorAccessorImpl, "sun/reflect/SerializationConstructorAccessorImpl") \ |
|
199 |
template(sun_reflect_DelegatingClassLoader, "sun/reflect/DelegatingClassLoader") \ |
|
200 |
template(sun_reflect_Reflection, "sun/reflect/Reflection") \ |
|
201 |
template(checkedExceptions_name, "checkedExceptions") \ |
|
202 |
template(clazz_name, "clazz") \ |
|
203 |
template(exceptionTypes_name, "exceptionTypes") \ |
|
204 |
template(modifiers_name, "modifiers") \ |
|
205 |
template(newConstructor_name, "newConstructor") \ |
|
206 |
template(newConstructor_signature, "(Lsun/reflect/MethodInfo;)Ljava/lang/reflect/Constructor;") \ |
|
207 |
template(newField_name, "newField") \ |
|
208 |
template(newField_signature, "(Lsun/reflect/FieldInfo;)Ljava/lang/reflect/Field;") \ |
|
209 |
template(newMethod_name, "newMethod") \ |
|
210 |
template(newMethod_signature, "(Lsun/reflect/MethodInfo;)Ljava/lang/reflect/Method;") \ |
|
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
211 |
/* the following two names must be in order: */ \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
212 |
template(invokeExact_name, "invokeExact") \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
213 |
template(invokeGeneric_name, "invokeGeneric") \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
214 |
template(invokeVarargs_name, "invokeVarargs") \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
215 |
template(star_name, "*") /*not really a name*/ \ |
1 | 216 |
template(invoke_name, "invoke") \ |
217 |
template(override_name, "override") \ |
|
218 |
template(parameterTypes_name, "parameterTypes") \ |
|
219 |
template(returnType_name, "returnType") \ |
|
220 |
template(signature_name, "signature") \ |
|
221 |
template(slot_name, "slot") \ |
|
222 |
\ |
|
223 |
/* Support for annotations (JDK 1.5 and above) */ \ |
|
224 |
\ |
|
225 |
template(annotations_name, "annotations") \ |
|
226 |
template(parameter_annotations_name, "parameterAnnotations") \ |
|
227 |
template(annotation_default_name, "annotationDefault") \ |
|
228 |
template(sun_reflect_ConstantPool, "sun/reflect/ConstantPool") \ |
|
229 |
template(constantPoolOop_name, "constantPoolOop") \ |
|
230 |
template(sun_reflect_UnsafeStaticFieldAccessorImpl, "sun/reflect/UnsafeStaticFieldAccessorImpl")\ |
|
231 |
template(base_name, "base") \ |
|
232 |
\ |
|
2534 | 233 |
/* Support for JSR 292 & invokedynamic (JDK 1.7 and above) */ \ |
4564
55dfb20908d0
6893081: method handle & invokedynamic code needs additional cleanup (post 6815692, 6858164)
twisti
parents:
4562
diff
changeset
|
234 |
template(java_dyn_InvokeDynamic, "java/dyn/InvokeDynamic") \ |
2570
ecc7862946d4
6655646: dynamic languages need dynamically linked call sites
jrose
parents:
2534
diff
changeset
|
235 |
template(java_dyn_Linkage, "java/dyn/Linkage") \ |
ecc7862946d4
6655646: dynamic languages need dynamically linked call sites
jrose
parents:
2534
diff
changeset
|
236 |
template(java_dyn_CallSite, "java/dyn/CallSite") \ |
2534 | 237 |
template(java_dyn_MethodHandle, "java/dyn/MethodHandle") \ |
238 |
template(java_dyn_MethodType, "java/dyn/MethodType") \ |
|
239 |
template(java_dyn_WrongMethodTypeException, "java/dyn/WrongMethodTypeException") \ |
|
240 |
template(java_dyn_MethodType_signature, "Ljava/dyn/MethodType;") \ |
|
241 |
template(java_dyn_MethodHandle_signature, "Ljava/dyn/MethodHandle;") \ |
|
242 |
/* internal classes known only to the JVM: */ \ |
|
243 |
template(java_dyn_MethodTypeForm, "java/dyn/MethodTypeForm") \ |
|
244 |
template(java_dyn_MethodTypeForm_signature, "Ljava/dyn/MethodTypeForm;") \ |
|
245 |
template(sun_dyn_MemberName, "sun/dyn/MemberName") \ |
|
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
246 |
template(sun_dyn_MemberName_signature, "Lsun/dyn/MemberName;") \ |
2534 | 247 |
template(sun_dyn_MethodHandleImpl, "sun/dyn/MethodHandleImpl") \ |
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
248 |
template(sun_dyn_MethodHandleNatives, "sun/dyn/MethodHandleNatives") \ |
2534 | 249 |
template(sun_dyn_AdapterMethodHandle, "sun/dyn/AdapterMethodHandle") \ |
250 |
template(sun_dyn_BoundMethodHandle, "sun/dyn/BoundMethodHandle") \ |
|
251 |
template(sun_dyn_DirectMethodHandle, "sun/dyn/DirectMethodHandle") \ |
|
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
252 |
/* internal up-calls made only by the JVM, via class sun.dyn.MethodHandleNatives: */ \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
253 |
template(findMethodHandleType_name, "findMethodHandleType") \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
254 |
template(findMethodHandleType_signature, "(Ljava/lang/Class;[Ljava/lang/Class;)Ljava/dyn/MethodType;") \ |
6463
f4362c8da849
6939224: MethodHandle.invokeGeneric needs to perform the correct set of conversions
jrose
parents:
5882
diff
changeset
|
255 |
template(notifyGenericMethodType_name, "notifyGenericMethodType") \ |
f4362c8da849
6939224: MethodHandle.invokeGeneric needs to perform the correct set of conversions
jrose
parents:
5882
diff
changeset
|
256 |
template(notifyGenericMethodType_signature, "(Ljava/dyn/MethodType;)V") \ |
5882 | 257 |
template(linkMethodHandleConstant_name, "linkMethodHandleConstant") \ |
258 |
template(linkMethodHandleConstant_signature, "(Ljava/lang/Class;ILjava/lang/Class;Ljava/lang/String;Ljava/lang/Object;)Ljava/dyn/MethodHandle;") \ |
|
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
259 |
template(makeDynamicCallSite_name, "makeDynamicCallSite") \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
260 |
template(makeDynamicCallSite_signature, "(Ljava/dyn/MethodHandle;Ljava/lang/String;Ljava/dyn/MethodType;Ljava/lang/Object;Lsun/dyn/MemberName;I)Ljava/dyn/CallSite;") \ |
2534 | 261 |
NOT_LP64( do_alias(machine_word_signature, int_signature) ) \ |
262 |
LP64_ONLY( do_alias(machine_word_signature, long_signature) ) \ |
|
263 |
\ |
|
264 |
/* common method and field names */ \ |
|
1 | 265 |
template(object_initializer_name, "<init>") \ |
266 |
template(class_initializer_name, "<clinit>") \ |
|
267 |
template(println_name, "println") \ |
|
268 |
template(printStackTrace_name, "printStackTrace") \ |
|
269 |
template(main_name, "main") \ |
|
270 |
template(name_name, "name") \ |
|
271 |
template(priority_name, "priority") \ |
|
272 |
template(stillborn_name, "stillborn") \ |
|
273 |
template(group_name, "group") \ |
|
274 |
template(daemon_name, "daemon") \ |
|
275 |
template(eetop_name, "eetop") \ |
|
276 |
template(thread_status_name, "threadStatus") \ |
|
277 |
template(run_method_name, "run") \ |
|
278 |
template(exit_method_name, "exit") \ |
|
279 |
template(add_method_name, "add") \ |
|
280 |
template(parent_name, "parent") \ |
|
281 |
template(threads_name, "threads") \ |
|
282 |
template(groups_name, "groups") \ |
|
283 |
template(maxPriority_name, "maxPriority") \ |
|
284 |
template(destroyed_name, "destroyed") \ |
|
285 |
template(vmAllowSuspension_name, "vmAllowSuspension") \ |
|
286 |
template(nthreads_name, "nthreads") \ |
|
287 |
template(ngroups_name, "ngroups") \ |
|
288 |
template(shutdown_method_name, "shutdown") \ |
|
289 |
template(finalize_method_name, "finalize") \ |
|
290 |
template(reference_lock_name, "lock") \ |
|
291 |
template(reference_discovered_name, "discovered") \ |
|
292 |
template(run_finalizers_on_exit_name, "runFinalizersOnExit") \ |
|
293 |
template(uncaughtException_name, "uncaughtException") \ |
|
294 |
template(dispatchUncaughtException_name, "dispatchUncaughtException") \ |
|
295 |
template(initializeSystemClass_name, "initializeSystemClass") \ |
|
296 |
template(loadClass_name, "loadClass") \ |
|
297 |
template(loadClassInternal_name, "loadClassInternal") \ |
|
298 |
template(get_name, "get") \ |
|
299 |
template(put_name, "put") \ |
|
300 |
template(type_name, "type") \ |
|
301 |
template(findNative_name, "findNative") \ |
|
302 |
template(deadChild_name, "deadChild") \ |
|
303 |
template(addClass_name, "addClass") \ |
|
304 |
template(getFromClass_name, "getFromClass") \ |
|
305 |
template(dispatch_name, "dispatch") \ |
|
306 |
template(getSystemClassLoader_name, "getSystemClassLoader") \ |
|
307 |
template(fillInStackTrace_name, "fillInStackTrace") \ |
|
308 |
template(getCause_name, "getCause") \ |
|
309 |
template(initCause_name, "initCause") \ |
|
310 |
template(setProperty_name, "setProperty") \ |
|
311 |
template(getProperty_name, "getProperty") \ |
|
312 |
template(context_name, "context") \ |
|
313 |
template(privilegedContext_name, "privilegedContext") \ |
|
314 |
template(contextClassLoader_name, "contextClassLoader") \ |
|
315 |
template(inheritedAccessControlContext_name, "inheritedAccessControlContext") \ |
|
316 |
template(isPrivileged_name, "isPrivileged") \ |
|
317 |
template(wait_name, "wait") \ |
|
318 |
template(checkPackageAccess_name, "checkPackageAccess") \ |
|
319 |
template(stackSize_name, "stackSize") \ |
|
320 |
template(thread_id_name, "tid") \ |
|
321 |
template(newInstance0_name, "newInstance0") \ |
|
322 |
template(limit_name, "limit") \ |
|
323 |
template(forName_name, "forName") \ |
|
324 |
template(forName0_name, "forName0") \ |
|
325 |
template(isJavaIdentifierStart_name, "isJavaIdentifierStart") \ |
|
326 |
template(isJavaIdentifierPart_name, "isJavaIdentifierPart") \ |
|
327 |
template(exclusive_owner_thread_name, "exclusiveOwnerThread") \ |
|
328 |
template(park_blocker_name, "parkBlocker") \ |
|
329 |
template(park_event_name, "nativeParkEventPointer") \ |
|
190
e9a0a9dcd4f6
6395208: Elide autoboxing for calls to HashMap.get(int) and HashMap.get(long)
never
parents:
1
diff
changeset
|
330 |
template(cache_field_name, "cache") \ |
1 | 331 |
template(value_name, "value") \ |
191
314312979e7a
6621621: HashMap front cache should be enabled only with AggressiveOpts
phh
parents:
190
diff
changeset
|
332 |
template(frontCacheEnabled_name, "frontCacheEnabled") \ |
618
9641c2c8f977
6714404: Add UseStringCache switch to enable String caching under AggressiveOpts
kvn
parents:
595
diff
changeset
|
333 |
template(stringCacheEnabled_name, "stringCacheEnabled") \ |
2862
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
334 |
template(numberOfLeadingZeros_name, "numberOfLeadingZeros") \ |
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
335 |
template(numberOfTrailingZeros_name, "numberOfTrailingZeros") \ |
2255
54abdf3e1055
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
1890
diff
changeset
|
336 |
template(bitCount_name, "bitCount") \ |
2342 | 337 |
template(profile_name, "profile") \ |
2348 | 338 |
template(equals_name, "equals") \ |
2570
ecc7862946d4
6655646: dynamic languages need dynamically linked call sites
jrose
parents:
2534
diff
changeset
|
339 |
template(target_name, "target") \ |
2534 | 340 |
template(toString_name, "toString") \ |
341 |
template(values_name, "values") \ |
|
342 |
template(receiver_name, "receiver") \ |
|
2570
ecc7862946d4
6655646: dynamic languages need dynamically linked call sites
jrose
parents:
2534
diff
changeset
|
343 |
template(vmmethod_name, "vmmethod") \ |
2534 | 344 |
template(vmtarget_name, "vmtarget") \ |
345 |
template(vmentry_name, "vmentry") \ |
|
346 |
template(vmslots_name, "vmslots") \ |
|
347 |
template(vmindex_name, "vmindex") \ |
|
348 |
template(vmargslot_name, "vmargslot") \ |
|
349 |
template(flags_name, "flags") \ |
|
350 |
template(argument_name, "argument") \ |
|
351 |
template(conversion_name, "conversion") \ |
|
352 |
template(rtype_name, "rtype") \ |
|
353 |
template(ptypes_name, "ptypes") \ |
|
354 |
template(form_name, "form") \ |
|
355 |
template(erasedType_name, "erasedType") \ |
|
6463
f4362c8da849
6939224: MethodHandle.invokeGeneric needs to perform the correct set of conversions
jrose
parents:
5882
diff
changeset
|
356 |
template(genericInvoker_name, "genericInvoker") \ |
4450
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
357 |
template(append_name, "append") \ |
1 | 358 |
\ |
359 |
/* non-intrinsic name/signature pairs: */ \ |
|
360 |
template(register_method_name, "register") \ |
|
361 |
do_alias(register_method_signature, object_void_signature) \ |
|
362 |
\ |
|
363 |
/* name symbols needed by intrinsics */ \ |
|
364 |
VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, VM_SYMBOL_IGNORE, template, VM_SYMBOL_IGNORE, VM_ALIAS_IGNORE) \ |
|
365 |
\ |
|
366 |
/* common signatures names */ \ |
|
367 |
template(void_method_signature, "()V") \ |
|
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
368 |
template(void_boolean_signature, "()Z") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
369 |
template(void_byte_signature, "()B") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
370 |
template(void_char_signature, "()C") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
371 |
template(void_short_signature, "()S") \ |
1 | 372 |
template(void_int_signature, "()I") \ |
373 |
template(void_long_signature, "()J") \ |
|
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
374 |
template(void_float_signature, "()F") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
375 |
template(void_double_signature, "()D") \ |
1 | 376 |
template(int_void_signature, "(I)V") \ |
377 |
template(int_int_signature, "(I)I") \ |
|
5352
cee8f7acb7bc
6946040: add intrinsic for short and char reverseBytes
never
parents:
4573
diff
changeset
|
378 |
template(char_char_signature, "(C)C") \ |
cee8f7acb7bc
6946040: add intrinsic for short and char reverseBytes
never
parents:
4573
diff
changeset
|
379 |
template(short_short_signature, "(S)S") \ |
1 | 380 |
template(int_bool_signature, "(I)Z") \ |
381 |
template(float_int_signature, "(F)I") \ |
|
382 |
template(double_long_signature, "(D)J") \ |
|
383 |
template(double_double_signature, "(D)D") \ |
|
384 |
template(int_float_signature, "(I)F") \ |
|
2255
54abdf3e1055
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
1890
diff
changeset
|
385 |
template(long_int_signature, "(J)I") \ |
1 | 386 |
template(long_long_signature, "(J)J") \ |
387 |
template(long_double_signature, "(J)D") \ |
|
388 |
template(byte_signature, "B") \ |
|
389 |
template(char_signature, "C") \ |
|
390 |
template(double_signature, "D") \ |
|
391 |
template(float_signature, "F") \ |
|
392 |
template(int_signature, "I") \ |
|
393 |
template(long_signature, "J") \ |
|
394 |
template(short_signature, "S") \ |
|
395 |
template(bool_signature, "Z") \ |
|
396 |
template(void_signature, "V") \ |
|
397 |
template(byte_array_signature, "[B") \ |
|
398 |
template(char_array_signature, "[C") \ |
|
399 |
template(object_void_signature, "(Ljava/lang/Object;)V") \ |
|
400 |
template(object_int_signature, "(Ljava/lang/Object;)I") \ |
|
401 |
template(object_boolean_signature, "(Ljava/lang/Object;)Z") \ |
|
402 |
template(string_void_signature, "(Ljava/lang/String;)V") \ |
|
403 |
template(string_int_signature, "(Ljava/lang/String;)I") \ |
|
404 |
template(throwable_void_signature, "(Ljava/lang/Throwable;)V") \ |
|
405 |
template(void_throwable_signature, "()Ljava/lang/Throwable;") \ |
|
406 |
template(throwable_throwable_signature, "(Ljava/lang/Throwable;)Ljava/lang/Throwable;") \ |
|
407 |
template(class_void_signature, "(Ljava/lang/Class;)V") \ |
|
408 |
template(class_int_signature, "(Ljava/lang/Class;)I") \ |
|
409 |
template(class_boolean_signature, "(Ljava/lang/Class;)Z") \ |
|
410 |
template(throwable_string_void_signature, "(Ljava/lang/Throwable;Ljava/lang/String;)V") \ |
|
411 |
template(string_array_void_signature, "([Ljava/lang/String;)V") \ |
|
412 |
template(string_array_string_array_void_signature, "([Ljava/lang/String;[Ljava/lang/String;)V") \ |
|
413 |
template(thread_throwable_void_signature, "(Ljava/lang/Thread;Ljava/lang/Throwable;)V") \ |
|
414 |
template(thread_void_signature, "(Ljava/lang/Thread;)V") \ |
|
415 |
template(threadgroup_runnable_void_signature, "(Ljava/lang/ThreadGroup;Ljava/lang/Runnable;)V") \ |
|
416 |
template(threadgroup_string_void_signature, "(Ljava/lang/ThreadGroup;Ljava/lang/String;)V") \ |
|
417 |
template(string_class_signature, "(Ljava/lang/String;)Ljava/lang/Class;") \ |
|
418 |
template(object_object_object_signature, "(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;") \ |
|
419 |
template(string_string_string_signature, "(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;") \ |
|
420 |
template(string_string_signature, "(Ljava/lang/String;)Ljava/lang/String;") \ |
|
421 |
template(classloader_string_long_signature, "(Ljava/lang/ClassLoader;Ljava/lang/String;)J") \ |
|
422 |
template(byte_array_void_signature, "([B)V") \ |
|
423 |
template(char_array_void_signature, "([C)V") \ |
|
424 |
template(int_int_void_signature, "(II)V") \ |
|
425 |
template(long_long_void_signature, "(JJ)V") \ |
|
426 |
template(void_classloader_signature, "()Ljava/lang/ClassLoader;") \ |
|
427 |
template(void_object_signature, "()Ljava/lang/Object;") \ |
|
428 |
template(void_class_signature, "()Ljava/lang/Class;") \ |
|
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
429 |
template(void_string_signature, "()Ljava/lang/String;") \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
430 |
template(object_array_object_signature, "([Ljava/lang/Object;)Ljava/lang/Object;") \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
431 |
template(object_object_array_object_signature, "(Ljava/lang/Object;[Ljava/lang/Object;)Ljava/lang/Object;")\ |
1 | 432 |
template(exception_void_signature, "(Ljava/lang/Exception;)V") \ |
433 |
template(protectiondomain_signature, "[Ljava/security/ProtectionDomain;") \ |
|
434 |
template(accesscontrolcontext_signature, "Ljava/security/AccessControlContext;") \ |
|
435 |
template(class_protectiondomain_signature, "(Ljava/lang/Class;Ljava/security/ProtectionDomain;)V") \ |
|
436 |
template(thread_signature, "Ljava/lang/Thread;") \ |
|
437 |
template(thread_array_signature, "[Ljava/lang/Thread;") \ |
|
438 |
template(threadgroup_signature, "Ljava/lang/ThreadGroup;") \ |
|
439 |
template(threadgroup_array_signature, "[Ljava/lang/ThreadGroup;") \ |
|
440 |
template(class_array_signature, "[Ljava/lang/Class;") \ |
|
441 |
template(classloader_signature, "Ljava/lang/ClassLoader;") \ |
|
442 |
template(object_signature, "Ljava/lang/Object;") \ |
|
443 |
template(class_signature, "Ljava/lang/Class;") \ |
|
444 |
template(string_signature, "Ljava/lang/String;") \ |
|
445 |
template(reference_signature, "Ljava/lang/ref/Reference;") \ |
|
1890 | 446 |
template(concurrenthashmap_signature, "Ljava/util/concurrent/ConcurrentHashMap;") \ |
4450
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
447 |
template(String_StringBuilder_signature, "(Ljava/lang/String;)Ljava/lang/StringBuilder;") \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
448 |
template(int_StringBuilder_signature, "(I)Ljava/lang/StringBuilder;") \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
449 |
template(char_StringBuilder_signature, "(C)Ljava/lang/StringBuilder;") \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
450 |
template(String_StringBuffer_signature, "(Ljava/lang/String;)Ljava/lang/StringBuffer;") \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
451 |
template(int_StringBuffer_signature, "(I)Ljava/lang/StringBuffer;") \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
452 |
template(char_StringBuffer_signature, "(C)Ljava/lang/StringBuffer;") \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
453 |
template(int_String_signature, "(I)Ljava/lang/String;") \ |
1 | 454 |
/* signature symbols needed by intrinsics */ \ |
455 |
VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, template, VM_ALIAS_IGNORE) \ |
|
456 |
\ |
|
457 |
/* symbol aliases needed by intrinsics */ \ |
|
458 |
VM_INTRINSICS_DO(VM_INTRINSIC_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, do_alias) \ |
|
459 |
\ |
|
460 |
/* returned by the C1 compiler in case there's not enough memory to allocate a new symbol*/ \ |
|
461 |
template(dummy_symbol_oop, "illegal symbol") \ |
|
462 |
\ |
|
463 |
/* used by ClassFormatError when class name is not known yet */ \ |
|
464 |
template(unknown_class_name, "<Unknown>") \ |
|
465 |
\ |
|
1890 | 466 |
/* used to identify class loaders handling parallel class loading */ \ |
2265
56439ca57904
6819853: VM does not detect JDK which supports parallel class loaders
acorn
parents:
2105
diff
changeset
|
467 |
template(parallelCapable_name, "parallelLockMap") \ |
1890 | 468 |
\ |
1 | 469 |
/* JVM monitoring and management support */ \ |
470 |
template(java_lang_StackTraceElement_array, "[Ljava/lang/StackTraceElement;") \ |
|
471 |
template(java_lang_management_ThreadState, "java/lang/management/ThreadState") \ |
|
472 |
template(java_lang_management_MemoryUsage, "java/lang/management/MemoryUsage") \ |
|
473 |
template(java_lang_management_ThreadInfo, "java/lang/management/ThreadInfo") \ |
|
474 |
template(sun_management_ManagementFactory, "sun/management/ManagementFactory") \ |
|
475 |
template(sun_management_Sensor, "sun/management/Sensor") \ |
|
476 |
template(sun_management_Agent, "sun/management/Agent") \ |
|
477 |
template(createMemoryPoolMBean_name, "createMemoryPoolMBean") \ |
|
478 |
template(createMemoryManagerMBean_name, "createMemoryManagerMBean") \ |
|
479 |
template(createGarbageCollectorMBean_name, "createGarbageCollectorMBean") \ |
|
480 |
template(createMemoryPoolMBean_signature, "(Ljava/lang/String;ZJJ)Ljava/lang/management/MemoryPoolMBean;") \ |
|
481 |
template(createMemoryManagerMBean_signature, "(Ljava/lang/String;)Ljava/lang/management/MemoryManagerMBean;") \ |
|
482 |
template(createGarbageCollectorMBean_signature, "(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/management/GarbageCollectorMBean;") \ |
|
483 |
template(trigger_name, "trigger") \ |
|
484 |
template(clear_name, "clear") \ |
|
485 |
template(trigger_method_signature, "(ILjava/lang/management/MemoryUsage;)V") \ |
|
486 |
template(startAgent_name, "startAgent") \ |
|
487 |
template(java_lang_management_ThreadInfo_constructor_signature, "(Ljava/lang/Thread;ILjava/lang/Object;Ljava/lang/Thread;JJJJ[Ljava/lang/StackTraceElement;)V") \ |
|
488 |
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") \ |
|
489 |
template(long_long_long_long_void_signature, "(JJJJ)V") \ |
|
490 |
\ |
|
491 |
template(java_lang_management_MemoryPoolMXBean, "java/lang/management/MemoryPoolMXBean") \ |
|
492 |
template(java_lang_management_MemoryManagerMXBean, "java/lang/management/MemoryManagerMXBean") \ |
|
493 |
template(java_lang_management_GarbageCollectorMXBean,"java/lang/management/GarbageCollectorMXBean") \ |
|
494 |
template(createMemoryPool_name, "createMemoryPool") \ |
|
495 |
template(createMemoryManager_name, "createMemoryManager") \ |
|
496 |
template(createGarbageCollector_name, "createGarbageCollector") \ |
|
497 |
template(createMemoryPool_signature, "(Ljava/lang/String;ZJJ)Ljava/lang/management/MemoryPoolMXBean;") \ |
|
498 |
template(createMemoryManager_signature, "(Ljava/lang/String;)Ljava/lang/management/MemoryManagerMXBean;") \ |
|
499 |
template(createGarbageCollector_signature, "(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/management/GarbageCollectorMXBean;") \ |
|
500 |
template(addThreadDumpForMonitors_name, "addThreadDumpForMonitors") \ |
|
501 |
template(addThreadDumpForSynchronizers_name, "addThreadDumpForSynchronizers") \ |
|
502 |
template(addThreadDumpForMonitors_signature, "(Ljava/lang/management/ThreadInfo;[Ljava/lang/Object;[I)V") \ |
|
503 |
template(addThreadDumpForSynchronizers_signature, "(Ljava/lang/management/ThreadInfo;[Ljava/lang/Object;)V") \ |
|
504 |
\ |
|
505 |
/* JVMTI/java.lang.instrument support and VM Attach mechanism */ \ |
|
506 |
template(sun_misc_VMSupport, "sun/misc/VMSupport") \ |
|
507 |
template(appendToClassPathForInstrumentation_name, "appendToClassPathForInstrumentation") \ |
|
508 |
do_alias(appendToClassPathForInstrumentation_signature, string_void_signature) \ |
|
509 |
template(serializePropertiesToByteArray_name, "serializePropertiesToByteArray") \ |
|
510 |
template(serializePropertiesToByteArray_signature, "()[B") \ |
|
511 |
template(serializeAgentPropertiesToByteArray_name, "serializeAgentPropertiesToByteArray") \ |
|
512 |
template(classRedefinedCount_name, "classRedefinedCount") \ |
|
513 |
/*end*/ |
|
514 |
||
515 |
||
516 |
||
517 |
// Here are all the intrinsics known to the runtime and the CI. |
|
518 |
// Each intrinsic consists of a public enum name (like _hashCode), |
|
519 |
// followed by a specification of its klass, name, and signature: |
|
520 |
// template(<id>, <klass>, <name>, <sig>, <FCODE>) |
|
521 |
// |
|
522 |
// If you add an intrinsic here, you must also define its name |
|
523 |
// and signature as members of the VM symbols. The VM symbols for |
|
524 |
// the intrinsic name and signature may be defined above. |
|
525 |
// |
|
526 |
// Because the VM_SYMBOLS_DO macro makes reference to VM_INTRINSICS_DO, |
|
527 |
// you can also define an intrinsic's name and/or signature locally to the |
|
528 |
// intrinsic, if this makes sense. (It often does make sense.) |
|
529 |
// |
|
530 |
// For example: |
|
531 |
// do_intrinsic(_foo, java_lang_Object, foo_name, foo_signature, F_xx) |
|
532 |
// do_name( foo_name, "foo") |
|
533 |
// do_signature(foo_signature, "()F") |
|
534 |
// klass = vmSymbols::java_lang_Object() |
|
535 |
// name = vmSymbols::foo_name() |
|
536 |
// signature = vmSymbols::foo_signature() |
|
537 |
// |
|
538 |
// The name and/or signature might be a "well known" symbol |
|
539 |
// like "equal" or "()I", in which case there will be no local |
|
540 |
// re-definition of the symbol. |
|
541 |
// |
|
542 |
// The do_class, do_name, and do_signature calls are all used for the |
|
543 |
// same purpose: Define yet another VM symbol. They could all be merged |
|
544 |
// into a common 'do_symbol' call, but it seems useful to record our |
|
545 |
// intentions here about kinds of symbols (class vs. name vs. signature). |
|
546 |
// |
|
547 |
// The F_xx is one of the Flags enum; see below. |
|
548 |
// |
|
549 |
// for Emacs: (let ((c-backslash-column 120) (c-backslash-max-column 120)) (c-backslash-region (point) (point-max) nil t)) |
|
550 |
#define VM_INTRINSICS_DO(do_intrinsic, do_class, do_name, do_signature, do_alias) \ |
|
551 |
do_intrinsic(_hashCode, java_lang_Object, hashCode_name, void_int_signature, F_R) \ |
|
552 |
do_name( hashCode_name, "hashCode") \ |
|
553 |
do_intrinsic(_getClass, java_lang_Object, getClass_name, void_class_signature, F_R) \ |
|
554 |
do_name( getClass_name, "getClass") \ |
|
555 |
do_intrinsic(_clone, java_lang_Object, clone_name, void_object_signature, F_R) \ |
|
556 |
do_name( clone_name, "clone") \ |
|
557 |
\ |
|
558 |
/* Math & StrictMath intrinsics are defined in terms of just a few signatures: */ \ |
|
559 |
do_class(java_lang_Math, "java/lang/Math") \ |
|
560 |
do_class(java_lang_StrictMath, "java/lang/StrictMath") \ |
|
561 |
do_signature(double2_double_signature, "(DD)D") \ |
|
562 |
do_signature(int2_int_signature, "(II)I") \ |
|
563 |
\ |
|
564 |
/* here are the math names, all together: */ \ |
|
565 |
do_name(abs_name,"abs") do_name(sin_name,"sin") do_name(cos_name,"cos") \ |
|
566 |
do_name(tan_name,"tan") do_name(atan2_name,"atan2") do_name(sqrt_name,"sqrt") \ |
|
567 |
do_name(log_name,"log") do_name(log10_name,"log10") do_name(pow_name,"pow") \ |
|
568 |
do_name(exp_name,"exp") do_name(min_name,"min") do_name(max_name,"max") \ |
|
569 |
\ |
|
570 |
do_intrinsic(_dabs, java_lang_Math, abs_name, double_double_signature, F_S) \ |
|
571 |
do_intrinsic(_dsin, java_lang_Math, sin_name, double_double_signature, F_S) \ |
|
572 |
do_intrinsic(_dcos, java_lang_Math, cos_name, double_double_signature, F_S) \ |
|
573 |
do_intrinsic(_dtan, java_lang_Math, tan_name, double_double_signature, F_S) \ |
|
574 |
do_intrinsic(_datan2, java_lang_Math, atan2_name, double2_double_signature, F_S) \ |
|
575 |
do_intrinsic(_dsqrt, java_lang_Math, sqrt_name, double_double_signature, F_S) \ |
|
576 |
do_intrinsic(_dlog, java_lang_Math, log_name, double_double_signature, F_S) \ |
|
577 |
do_intrinsic(_dlog10, java_lang_Math, log10_name, double_double_signature, F_S) \ |
|
578 |
do_intrinsic(_dpow, java_lang_Math, pow_name, double2_double_signature, F_S) \ |
|
579 |
do_intrinsic(_dexp, java_lang_Math, exp_name, double_double_signature, F_S) \ |
|
580 |
do_intrinsic(_min, java_lang_Math, min_name, int2_int_signature, F_S) \ |
|
581 |
do_intrinsic(_max, java_lang_Math, max_name, int2_int_signature, F_S) \ |
|
582 |
\ |
|
583 |
do_intrinsic(_floatToRawIntBits, java_lang_Float, floatToRawIntBits_name, float_int_signature, F_S) \ |
|
584 |
do_name( floatToRawIntBits_name, "floatToRawIntBits") \ |
|
585 |
do_intrinsic(_floatToIntBits, java_lang_Float, floatToIntBits_name, float_int_signature, F_S) \ |
|
586 |
do_name( floatToIntBits_name, "floatToIntBits") \ |
|
587 |
do_intrinsic(_intBitsToFloat, java_lang_Float, intBitsToFloat_name, int_float_signature, F_S) \ |
|
588 |
do_name( intBitsToFloat_name, "intBitsToFloat") \ |
|
589 |
do_intrinsic(_doubleToRawLongBits, java_lang_Double, doubleToRawLongBits_name, double_long_signature, F_S) \ |
|
590 |
do_name( doubleToRawLongBits_name, "doubleToRawLongBits") \ |
|
591 |
do_intrinsic(_doubleToLongBits, java_lang_Double, doubleToLongBits_name, double_long_signature, F_S) \ |
|
592 |
do_name( doubleToLongBits_name, "doubleToLongBits") \ |
|
593 |
do_intrinsic(_longBitsToDouble, java_lang_Double, longBitsToDouble_name, long_double_signature, F_S) \ |
|
594 |
do_name( longBitsToDouble_name, "longBitsToDouble") \ |
|
2255
54abdf3e1055
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
1890
diff
changeset
|
595 |
\ |
2862
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
596 |
do_intrinsic(_numberOfLeadingZeros_i, java_lang_Integer, numberOfLeadingZeros_name,int_int_signature, F_S) \ |
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
597 |
do_intrinsic(_numberOfLeadingZeros_l, java_lang_Long, numberOfLeadingZeros_name,long_int_signature, F_S) \ |
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
598 |
\ |
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
599 |
do_intrinsic(_numberOfTrailingZeros_i, java_lang_Integer, numberOfTrailingZeros_name,int_int_signature, F_S) \ |
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
600 |
do_intrinsic(_numberOfTrailingZeros_l, java_lang_Long, numberOfTrailingZeros_name,long_int_signature, F_S) \ |
fad636edf18f
6823354: Add intrinsics for {Integer,Long}.{numberOfLeadingZeros,numberOfTrailingZeros}()
twisti
parents:
2570
diff
changeset
|
601 |
\ |
2255
54abdf3e1055
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
1890
diff
changeset
|
602 |
do_intrinsic(_bitCount_i, java_lang_Integer, bitCount_name, int_int_signature, F_S) \ |
54abdf3e1055
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
1890
diff
changeset
|
603 |
do_intrinsic(_bitCount_l, java_lang_Long, bitCount_name, long_int_signature, F_S) \ |
54abdf3e1055
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
1890
diff
changeset
|
604 |
\ |
1 | 605 |
do_intrinsic(_reverseBytes_i, java_lang_Integer, reverseBytes_name, int_int_signature, F_S) \ |
606 |
do_name( reverseBytes_name, "reverseBytes") \ |
|
607 |
do_intrinsic(_reverseBytes_l, java_lang_Long, reverseBytes_name, long_long_signature, F_S) \ |
|
608 |
/* (symbol reverseBytes_name defined above) */ \ |
|
5352
cee8f7acb7bc
6946040: add intrinsic for short and char reverseBytes
never
parents:
4573
diff
changeset
|
609 |
do_intrinsic(_reverseBytes_c, java_lang_Character, reverseBytes_name, char_char_signature, F_S) \ |
cee8f7acb7bc
6946040: add intrinsic for short and char reverseBytes
never
parents:
4573
diff
changeset
|
610 |
/* (symbol reverseBytes_name defined above) */ \ |
cee8f7acb7bc
6946040: add intrinsic for short and char reverseBytes
never
parents:
4573
diff
changeset
|
611 |
do_intrinsic(_reverseBytes_s, java_lang_Short, reverseBytes_name, short_short_signature, F_S) \ |
cee8f7acb7bc
6946040: add intrinsic for short and char reverseBytes
never
parents:
4573
diff
changeset
|
612 |
/* (symbol reverseBytes_name defined above) */ \ |
1 | 613 |
\ |
614 |
do_intrinsic(_identityHashCode, java_lang_System, identityHashCode_name, object_int_signature, F_S) \ |
|
615 |
do_name( identityHashCode_name, "identityHashCode") \ |
|
616 |
do_intrinsic(_currentTimeMillis, java_lang_System, currentTimeMillis_name, void_long_signature, F_S) \ |
|
617 |
\ |
|
618 |
do_name( currentTimeMillis_name, "currentTimeMillis") \ |
|
619 |
do_intrinsic(_nanoTime, java_lang_System, nanoTime_name, void_long_signature, F_S) \ |
|
620 |
do_name( nanoTime_name, "nanoTime") \ |
|
621 |
\ |
|
622 |
do_intrinsic(_arraycopy, java_lang_System, arraycopy_name, arraycopy_signature, F_S) \ |
|
623 |
do_name( arraycopy_name, "arraycopy") \ |
|
624 |
do_signature(arraycopy_signature, "(Ljava/lang/Object;ILjava/lang/Object;II)V") \ |
|
625 |
do_intrinsic(_isInterrupted, java_lang_Thread, isInterrupted_name, isInterrupted_signature, F_R) \ |
|
626 |
do_name( isInterrupted_name, "isInterrupted") \ |
|
627 |
do_signature(isInterrupted_signature, "(Z)Z") \ |
|
628 |
do_intrinsic(_currentThread, java_lang_Thread, currentThread_name, currentThread_signature, F_S) \ |
|
629 |
do_name( currentThread_name, "currentThread") \ |
|
630 |
do_signature(currentThread_signature, "()Ljava/lang/Thread;") \ |
|
631 |
\ |
|
632 |
/* reflective intrinsics, for java/lang/Class, etc. */ \ |
|
633 |
do_intrinsic(_isAssignableFrom, java_lang_Class, isAssignableFrom_name, class_boolean_signature, F_RN) \ |
|
634 |
do_name( isAssignableFrom_name, "isAssignableFrom") \ |
|
635 |
do_intrinsic(_isInstance, java_lang_Class, isInstance_name, object_boolean_signature, F_RN) \ |
|
636 |
do_name( isInstance_name, "isInstance") \ |
|
637 |
do_intrinsic(_getModifiers, java_lang_Class, getModifiers_name, void_int_signature, F_RN) \ |
|
638 |
do_name( getModifiers_name, "getModifiers") \ |
|
639 |
do_intrinsic(_isInterface, java_lang_Class, isInterface_name, void_boolean_signature, F_RN) \ |
|
640 |
do_name( isInterface_name, "isInterface") \ |
|
641 |
do_intrinsic(_isArray, java_lang_Class, isArray_name, void_boolean_signature, F_RN) \ |
|
642 |
do_name( isArray_name, "isArray") \ |
|
643 |
do_intrinsic(_isPrimitive, java_lang_Class, isPrimitive_name, void_boolean_signature, F_RN) \ |
|
644 |
do_name( isPrimitive_name, "isPrimitive") \ |
|
645 |
do_intrinsic(_getSuperclass, java_lang_Class, getSuperclass_name, void_class_signature, F_RN) \ |
|
646 |
do_name( getSuperclass_name, "getSuperclass") \ |
|
647 |
do_intrinsic(_getComponentType, java_lang_Class, getComponentType_name, void_class_signature, F_RN) \ |
|
648 |
do_name( getComponentType_name, "getComponentType") \ |
|
649 |
\ |
|
650 |
do_intrinsic(_getClassAccessFlags, sun_reflect_Reflection, getClassAccessFlags_name, class_int_signature, F_SN) \ |
|
651 |
do_name( getClassAccessFlags_name, "getClassAccessFlags") \ |
|
652 |
do_intrinsic(_getLength, java_lang_reflect_Array, getLength_name, object_int_signature, F_SN) \ |
|
653 |
do_name( getLength_name, "getLength") \ |
|
654 |
\ |
|
655 |
do_intrinsic(_getCallerClass, sun_reflect_Reflection, getCallerClass_name, getCallerClass_signature, F_SN) \ |
|
656 |
do_name( getCallerClass_name, "getCallerClass") \ |
|
657 |
do_signature(getCallerClass_signature, "(I)Ljava/lang/Class;") \ |
|
658 |
\ |
|
659 |
do_intrinsic(_newArray, java_lang_reflect_Array, newArray_name, newArray_signature, F_SN) \ |
|
660 |
do_name( newArray_name, "newArray") \ |
|
661 |
do_signature(newArray_signature, "(Ljava/lang/Class;I)Ljava/lang/Object;") \ |
|
662 |
\ |
|
663 |
do_intrinsic(_copyOf, java_util_Arrays, copyOf_name, copyOf_signature, F_S) \ |
|
664 |
do_name( copyOf_name, "copyOf") \ |
|
665 |
do_signature(copyOf_signature, "([Ljava/lang/Object;ILjava/lang/Class;)[Ljava/lang/Object;") \ |
|
666 |
\ |
|
667 |
do_intrinsic(_copyOfRange, java_util_Arrays, copyOfRange_name, copyOfRange_signature, F_S) \ |
|
668 |
do_name( copyOfRange_name, "copyOfRange") \ |
|
669 |
do_signature(copyOfRange_signature, "([Ljava/lang/Object;IILjava/lang/Class;)[Ljava/lang/Object;") \ |
|
670 |
\ |
|
595
a2be4c89de81
6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents:
218
diff
changeset
|
671 |
do_intrinsic(_equalsC, java_util_Arrays, equals_name, equalsC_signature, F_S) \ |
a2be4c89de81
6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents:
218
diff
changeset
|
672 |
do_signature(equalsC_signature, "([C[C)Z") \ |
a2be4c89de81
6695049: (coll) Create an x86 intrinsic for Arrays.equals
rasbold
parents:
218
diff
changeset
|
673 |
\ |
1 | 674 |
do_intrinsic(_compareTo, java_lang_String, compareTo_name, string_int_signature, F_R) \ |
675 |
do_name( compareTo_name, "compareTo") \ |
|
676 |
do_intrinsic(_indexOf, java_lang_String, indexOf_name, string_int_signature, F_R) \ |
|
677 |
do_name( indexOf_name, "indexOf") \ |
|
2348 | 678 |
do_intrinsic(_equals, java_lang_String, equals_name, object_boolean_signature, F_R) \ |
1 | 679 |
\ |
680 |
do_class(java_nio_Buffer, "java/nio/Buffer") \ |
|
681 |
do_intrinsic(_checkIndex, java_nio_Buffer, checkIndex_name, int_int_signature, F_R) \ |
|
682 |
do_name( checkIndex_name, "checkIndex") \ |
|
683 |
\ |
|
684 |
do_class(sun_misc_AtomicLongCSImpl, "sun/misc/AtomicLongCSImpl") \ |
|
685 |
do_intrinsic(_get_AtomicLong, sun_misc_AtomicLongCSImpl, get_name, void_long_signature, F_R) \ |
|
686 |
/* (symbols get_name and void_long_signature defined above) */ \ |
|
687 |
\ |
|
688 |
do_intrinsic(_attemptUpdate, sun_misc_AtomicLongCSImpl, attemptUpdate_name, attemptUpdate_signature, F_R) \ |
|
689 |
do_name( attemptUpdate_name, "attemptUpdate") \ |
|
690 |
do_signature(attemptUpdate_signature, "(JJ)Z") \ |
|
691 |
\ |
|
692 |
/* support for sun.misc.Unsafe */ \ |
|
693 |
do_class(sun_misc_Unsafe, "sun/misc/Unsafe") \ |
|
694 |
\ |
|
695 |
do_intrinsic(_allocateInstance, sun_misc_Unsafe, allocateInstance_name, allocateInstance_signature, F_RN) \ |
|
696 |
do_name( allocateInstance_name, "allocateInstance") \ |
|
697 |
do_signature(allocateInstance_signature, "(Ljava/lang/Class;)Ljava/lang/Object;") \ |
|
698 |
do_intrinsic(_copyMemory, sun_misc_Unsafe, copyMemory_name, copyMemory_signature, F_RN) \ |
|
699 |
do_name( copyMemory_name, "copyMemory") \ |
|
700 |
do_signature(copyMemory_signature, "(Ljava/lang/Object;JLjava/lang/Object;JJ)V") \ |
|
701 |
do_intrinsic(_park, sun_misc_Unsafe, park_name, park_signature, F_RN) \ |
|
702 |
do_name( park_name, "park") \ |
|
703 |
do_signature(park_signature, "(ZJ)V") \ |
|
704 |
do_intrinsic(_unpark, sun_misc_Unsafe, unpark_name, unpark_signature, F_RN) \ |
|
705 |
do_name( unpark_name, "unpark") \ |
|
706 |
do_alias( unpark_signature, /*(LObject;)V*/ object_void_signature) \ |
|
707 |
\ |
|
708 |
/* unsafe memory references (there are a lot of them...) */ \ |
|
709 |
do_signature(getObject_signature, "(Ljava/lang/Object;J)Ljava/lang/Object;") \ |
|
710 |
do_signature(putObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;)V") \ |
|
711 |
do_signature(getBoolean_signature, "(Ljava/lang/Object;J)Z") \ |
|
712 |
do_signature(putBoolean_signature, "(Ljava/lang/Object;JZ)V") \ |
|
713 |
do_signature(getByte_signature, "(Ljava/lang/Object;J)B") \ |
|
714 |
do_signature(putByte_signature, "(Ljava/lang/Object;JB)V") \ |
|
715 |
do_signature(getShort_signature, "(Ljava/lang/Object;J)S") \ |
|
716 |
do_signature(putShort_signature, "(Ljava/lang/Object;JS)V") \ |
|
717 |
do_signature(getChar_signature, "(Ljava/lang/Object;J)C") \ |
|
718 |
do_signature(putChar_signature, "(Ljava/lang/Object;JC)V") \ |
|
719 |
do_signature(getInt_signature, "(Ljava/lang/Object;J)I") \ |
|
720 |
do_signature(putInt_signature, "(Ljava/lang/Object;JI)V") \ |
|
721 |
do_signature(getLong_signature, "(Ljava/lang/Object;J)J") \ |
|
722 |
do_signature(putLong_signature, "(Ljava/lang/Object;JJ)V") \ |
|
723 |
do_signature(getFloat_signature, "(Ljava/lang/Object;J)F") \ |
|
724 |
do_signature(putFloat_signature, "(Ljava/lang/Object;JF)V") \ |
|
725 |
do_signature(getDouble_signature, "(Ljava/lang/Object;J)D") \ |
|
726 |
do_signature(putDouble_signature, "(Ljava/lang/Object;JD)V") \ |
|
727 |
\ |
|
728 |
do_name(getObject_name,"getObject") do_name(putObject_name,"putObject") \ |
|
729 |
do_name(getBoolean_name,"getBoolean") do_name(putBoolean_name,"putBoolean") \ |
|
730 |
do_name(getByte_name,"getByte") do_name(putByte_name,"putByte") \ |
|
731 |
do_name(getShort_name,"getShort") do_name(putShort_name,"putShort") \ |
|
732 |
do_name(getChar_name,"getChar") do_name(putChar_name,"putChar") \ |
|
733 |
do_name(getInt_name,"getInt") do_name(putInt_name,"putInt") \ |
|
734 |
do_name(getLong_name,"getLong") do_name(putLong_name,"putLong") \ |
|
735 |
do_name(getFloat_name,"getFloat") do_name(putFloat_name,"putFloat") \ |
|
736 |
do_name(getDouble_name,"getDouble") do_name(putDouble_name,"putDouble") \ |
|
737 |
\ |
|
738 |
do_intrinsic(_getObject, sun_misc_Unsafe, getObject_name, getObject_signature, F_RN) \ |
|
739 |
do_intrinsic(_getBoolean, sun_misc_Unsafe, getBoolean_name, getBoolean_signature, F_RN) \ |
|
740 |
do_intrinsic(_getByte, sun_misc_Unsafe, getByte_name, getByte_signature, F_RN) \ |
|
741 |
do_intrinsic(_getShort, sun_misc_Unsafe, getShort_name, getShort_signature, F_RN) \ |
|
742 |
do_intrinsic(_getChar, sun_misc_Unsafe, getChar_name, getChar_signature, F_RN) \ |
|
743 |
do_intrinsic(_getInt, sun_misc_Unsafe, getInt_name, getInt_signature, F_RN) \ |
|
744 |
do_intrinsic(_getLong, sun_misc_Unsafe, getLong_name, getLong_signature, F_RN) \ |
|
745 |
do_intrinsic(_getFloat, sun_misc_Unsafe, getFloat_name, getFloat_signature, F_RN) \ |
|
746 |
do_intrinsic(_getDouble, sun_misc_Unsafe, getDouble_name, getDouble_signature, F_RN) \ |
|
747 |
do_intrinsic(_putObject, sun_misc_Unsafe, putObject_name, putObject_signature, F_RN) \ |
|
748 |
do_intrinsic(_putBoolean, sun_misc_Unsafe, putBoolean_name, putBoolean_signature, F_RN) \ |
|
749 |
do_intrinsic(_putByte, sun_misc_Unsafe, putByte_name, putByte_signature, F_RN) \ |
|
750 |
do_intrinsic(_putShort, sun_misc_Unsafe, putShort_name, putShort_signature, F_RN) \ |
|
751 |
do_intrinsic(_putChar, sun_misc_Unsafe, putChar_name, putChar_signature, F_RN) \ |
|
752 |
do_intrinsic(_putInt, sun_misc_Unsafe, putInt_name, putInt_signature, F_RN) \ |
|
753 |
do_intrinsic(_putLong, sun_misc_Unsafe, putLong_name, putLong_signature, F_RN) \ |
|
754 |
do_intrinsic(_putFloat, sun_misc_Unsafe, putFloat_name, putFloat_signature, F_RN) \ |
|
755 |
do_intrinsic(_putDouble, sun_misc_Unsafe, putDouble_name, putDouble_signature, F_RN) \ |
|
756 |
\ |
|
757 |
do_name(getObjectVolatile_name,"getObjectVolatile") do_name(putObjectVolatile_name,"putObjectVolatile") \ |
|
758 |
do_name(getBooleanVolatile_name,"getBooleanVolatile") do_name(putBooleanVolatile_name,"putBooleanVolatile") \ |
|
759 |
do_name(getByteVolatile_name,"getByteVolatile") do_name(putByteVolatile_name,"putByteVolatile") \ |
|
760 |
do_name(getShortVolatile_name,"getShortVolatile") do_name(putShortVolatile_name,"putShortVolatile") \ |
|
761 |
do_name(getCharVolatile_name,"getCharVolatile") do_name(putCharVolatile_name,"putCharVolatile") \ |
|
762 |
do_name(getIntVolatile_name,"getIntVolatile") do_name(putIntVolatile_name,"putIntVolatile") \ |
|
763 |
do_name(getLongVolatile_name,"getLongVolatile") do_name(putLongVolatile_name,"putLongVolatile") \ |
|
764 |
do_name(getFloatVolatile_name,"getFloatVolatile") do_name(putFloatVolatile_name,"putFloatVolatile") \ |
|
765 |
do_name(getDoubleVolatile_name,"getDoubleVolatile") do_name(putDoubleVolatile_name,"putDoubleVolatile") \ |
|
766 |
\ |
|
767 |
do_intrinsic(_getObjectVolatile, sun_misc_Unsafe, getObjectVolatile_name, getObject_signature, F_RN) \ |
|
768 |
do_intrinsic(_getBooleanVolatile, sun_misc_Unsafe, getBooleanVolatile_name, getBoolean_signature, F_RN) \ |
|
769 |
do_intrinsic(_getByteVolatile, sun_misc_Unsafe, getByteVolatile_name, getByte_signature, F_RN) \ |
|
770 |
do_intrinsic(_getShortVolatile, sun_misc_Unsafe, getShortVolatile_name, getShort_signature, F_RN) \ |
|
771 |
do_intrinsic(_getCharVolatile, sun_misc_Unsafe, getCharVolatile_name, getChar_signature, F_RN) \ |
|
772 |
do_intrinsic(_getIntVolatile, sun_misc_Unsafe, getIntVolatile_name, getInt_signature, F_RN) \ |
|
773 |
do_intrinsic(_getLongVolatile, sun_misc_Unsafe, getLongVolatile_name, getLong_signature, F_RN) \ |
|
774 |
do_intrinsic(_getFloatVolatile, sun_misc_Unsafe, getFloatVolatile_name, getFloat_signature, F_RN) \ |
|
775 |
do_intrinsic(_getDoubleVolatile, sun_misc_Unsafe, getDoubleVolatile_name, getDouble_signature, F_RN) \ |
|
776 |
do_intrinsic(_putObjectVolatile, sun_misc_Unsafe, putObjectVolatile_name, putObject_signature, F_RN) \ |
|
777 |
do_intrinsic(_putBooleanVolatile, sun_misc_Unsafe, putBooleanVolatile_name, putBoolean_signature, F_RN) \ |
|
778 |
do_intrinsic(_putByteVolatile, sun_misc_Unsafe, putByteVolatile_name, putByte_signature, F_RN) \ |
|
779 |
do_intrinsic(_putShortVolatile, sun_misc_Unsafe, putShortVolatile_name, putShort_signature, F_RN) \ |
|
780 |
do_intrinsic(_putCharVolatile, sun_misc_Unsafe, putCharVolatile_name, putChar_signature, F_RN) \ |
|
781 |
do_intrinsic(_putIntVolatile, sun_misc_Unsafe, putIntVolatile_name, putInt_signature, F_RN) \ |
|
782 |
do_intrinsic(_putLongVolatile, sun_misc_Unsafe, putLongVolatile_name, putLong_signature, F_RN) \ |
|
783 |
do_intrinsic(_putFloatVolatile, sun_misc_Unsafe, putFloatVolatile_name, putFloat_signature, F_RN) \ |
|
784 |
do_intrinsic(_putDoubleVolatile, sun_misc_Unsafe, putDoubleVolatile_name, putDouble_signature, F_RN) \ |
|
785 |
\ |
|
786 |
/* %%% these are redundant except perhaps for getAddress, but Unsafe has native methods for them */ \ |
|
787 |
do_signature(getByte_raw_signature, "(J)B") \ |
|
788 |
do_signature(putByte_raw_signature, "(JB)V") \ |
|
789 |
do_signature(getShort_raw_signature, "(J)S") \ |
|
790 |
do_signature(putShort_raw_signature, "(JS)V") \ |
|
791 |
do_signature(getChar_raw_signature, "(J)C") \ |
|
792 |
do_signature(putChar_raw_signature, "(JC)V") \ |
|
793 |
do_signature(putInt_raw_signature, "(JI)V") \ |
|
794 |
do_alias(getLong_raw_signature, /*(J)J*/ long_long_signature) \ |
|
795 |
do_alias(putLong_raw_signature, /*(JJ)V*/ long_long_void_signature) \ |
|
796 |
do_signature(getFloat_raw_signature, "(J)F") \ |
|
797 |
do_signature(putFloat_raw_signature, "(JF)V") \ |
|
798 |
do_alias(getDouble_raw_signature, /*(J)D*/ long_double_signature) \ |
|
799 |
do_signature(putDouble_raw_signature, "(JD)V") \ |
|
800 |
do_alias(getAddress_raw_signature, /*(J)J*/ long_long_signature) \ |
|
801 |
do_alias(putAddress_raw_signature, /*(JJ)V*/ long_long_void_signature) \ |
|
802 |
\ |
|
803 |
do_name( getAddress_name, "getAddress") \ |
|
804 |
do_name( putAddress_name, "putAddress") \ |
|
805 |
\ |
|
806 |
do_intrinsic(_getByte_raw, sun_misc_Unsafe, getByte_name, getByte_raw_signature, F_RN) \ |
|
807 |
do_intrinsic(_getShort_raw, sun_misc_Unsafe, getShort_name, getShort_raw_signature, F_RN) \ |
|
808 |
do_intrinsic(_getChar_raw, sun_misc_Unsafe, getChar_name, getChar_raw_signature, F_RN) \ |
|
2255
54abdf3e1055
6378821: bitCount() should use POPC on SPARC processors and AMD+10h
twisti
parents:
1890
diff
changeset
|
809 |
do_intrinsic(_getInt_raw, sun_misc_Unsafe, getInt_name, long_int_signature, F_RN) \ |
1 | 810 |
do_intrinsic(_getLong_raw, sun_misc_Unsafe, getLong_name, getLong_raw_signature, F_RN) \ |
811 |
do_intrinsic(_getFloat_raw, sun_misc_Unsafe, getFloat_name, getFloat_raw_signature, F_RN) \ |
|
812 |
do_intrinsic(_getDouble_raw, sun_misc_Unsafe, getDouble_name, getDouble_raw_signature, F_RN) \ |
|
813 |
do_intrinsic(_getAddress_raw, sun_misc_Unsafe, getAddress_name, getAddress_raw_signature, F_RN) \ |
|
814 |
do_intrinsic(_putByte_raw, sun_misc_Unsafe, putByte_name, putByte_raw_signature, F_RN) \ |
|
815 |
do_intrinsic(_putShort_raw, sun_misc_Unsafe, putShort_name, putShort_raw_signature, F_RN) \ |
|
816 |
do_intrinsic(_putChar_raw, sun_misc_Unsafe, putChar_name, putChar_raw_signature, F_RN) \ |
|
817 |
do_intrinsic(_putInt_raw, sun_misc_Unsafe, putInt_name, putInt_raw_signature, F_RN) \ |
|
818 |
do_intrinsic(_putLong_raw, sun_misc_Unsafe, putLong_name, putLong_raw_signature, F_RN) \ |
|
819 |
do_intrinsic(_putFloat_raw, sun_misc_Unsafe, putFloat_name, putFloat_raw_signature, F_RN) \ |
|
820 |
do_intrinsic(_putDouble_raw, sun_misc_Unsafe, putDouble_name, putDouble_raw_signature, F_RN) \ |
|
821 |
do_intrinsic(_putAddress_raw, sun_misc_Unsafe, putAddress_name, putAddress_raw_signature, F_RN) \ |
|
822 |
\ |
|
823 |
do_intrinsic(_compareAndSwapObject, sun_misc_Unsafe, compareAndSwapObject_name, compareAndSwapObject_signature, F_RN) \ |
|
824 |
do_name( compareAndSwapObject_name, "compareAndSwapObject") \ |
|
825 |
do_signature(compareAndSwapObject_signature, "(Ljava/lang/Object;JLjava/lang/Object;Ljava/lang/Object;)Z") \ |
|
826 |
do_intrinsic(_compareAndSwapLong, sun_misc_Unsafe, compareAndSwapLong_name, compareAndSwapLong_signature, F_RN) \ |
|
827 |
do_name( compareAndSwapLong_name, "compareAndSwapLong") \ |
|
828 |
do_signature(compareAndSwapLong_signature, "(Ljava/lang/Object;JJJ)Z") \ |
|
829 |
do_intrinsic(_compareAndSwapInt, sun_misc_Unsafe, compareAndSwapInt_name, compareAndSwapInt_signature, F_RN) \ |
|
830 |
do_name( compareAndSwapInt_name, "compareAndSwapInt") \ |
|
831 |
do_signature(compareAndSwapInt_signature, "(Ljava/lang/Object;JII)Z") \ |
|
832 |
do_intrinsic(_putOrderedObject, sun_misc_Unsafe, putOrderedObject_name, putOrderedObject_signature, F_RN) \ |
|
833 |
do_name( putOrderedObject_name, "putOrderedObject") \ |
|
834 |
do_alias( putOrderedObject_signature, /*(LObject;JLObject;)V*/ putObject_signature) \ |
|
835 |
do_intrinsic(_putOrderedLong, sun_misc_Unsafe, putOrderedLong_name, putOrderedLong_signature, F_RN) \ |
|
836 |
do_name( putOrderedLong_name, "putOrderedLong") \ |
|
837 |
do_alias( putOrderedLong_signature, /*(Ljava/lang/Object;JJ)V*/ putLong_signature) \ |
|
838 |
do_intrinsic(_putOrderedInt, sun_misc_Unsafe, putOrderedInt_name, putOrderedInt_signature, F_RN) \ |
|
839 |
do_name( putOrderedInt_name, "putOrderedInt") \ |
|
840 |
do_alias( putOrderedInt_signature, /*(Ljava/lang/Object;JI)V*/ putInt_signature) \ |
|
841 |
\ |
|
842 |
/* prefetch_signature is shared by all prefetch variants */ \ |
|
843 |
do_signature( prefetch_signature, "(Ljava/lang/Object;J)V") \ |
|
844 |
\ |
|
845 |
do_intrinsic(_prefetchRead, sun_misc_Unsafe, prefetchRead_name, prefetch_signature, F_RN) \ |
|
846 |
do_name( prefetchRead_name, "prefetchRead") \ |
|
847 |
do_intrinsic(_prefetchWrite, sun_misc_Unsafe, prefetchWrite_name, prefetch_signature, F_RN) \ |
|
848 |
do_name( prefetchWrite_name, "prefetchWrite") \ |
|
849 |
do_intrinsic(_prefetchReadStatic, sun_misc_Unsafe, prefetchReadStatic_name, prefetch_signature, F_SN) \ |
|
850 |
do_name( prefetchReadStatic_name, "prefetchReadStatic") \ |
|
851 |
do_intrinsic(_prefetchWriteStatic, sun_misc_Unsafe, prefetchWriteStatic_name, prefetch_signature, F_SN) \ |
|
852 |
do_name( prefetchWriteStatic_name, "prefetchWriteStatic") \ |
|
3273
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
853 |
/*== LAST_COMPILER_INLINE*/ \ |
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
854 |
/*the compiler does have special inlining code for these; bytecode inline is just fine */ \ |
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
855 |
\ |
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
856 |
do_intrinsic(_fillInStackTrace, java_lang_Throwable, fillInStackTrace_name, void_throwable_signature, F_RNY) \ |
4450
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
857 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
858 |
do_intrinsic(_StringBuilder_void, java_lang_StringBuilder, object_initializer_name, void_method_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
859 |
do_intrinsic(_StringBuilder_int, java_lang_StringBuilder, object_initializer_name, int_void_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
860 |
do_intrinsic(_StringBuilder_String, java_lang_StringBuilder, object_initializer_name, string_void_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
861 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
862 |
do_intrinsic(_StringBuilder_append_char, java_lang_StringBuilder, append_name, char_StringBuilder_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
863 |
do_intrinsic(_StringBuilder_append_int, java_lang_StringBuilder, append_name, int_StringBuilder_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
864 |
do_intrinsic(_StringBuilder_append_String, java_lang_StringBuilder, append_name, String_StringBuilder_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
865 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
866 |
do_intrinsic(_StringBuilder_toString, java_lang_StringBuilder, toString_name, void_string_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
867 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
868 |
do_intrinsic(_StringBuffer_void, java_lang_StringBuffer, object_initializer_name, void_method_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
869 |
do_intrinsic(_StringBuffer_int, java_lang_StringBuffer, object_initializer_name, int_void_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
870 |
do_intrinsic(_StringBuffer_String, java_lang_StringBuffer, object_initializer_name, string_void_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
871 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
872 |
do_intrinsic(_StringBuffer_append_char, java_lang_StringBuffer, append_name, char_StringBuffer_signature, F_Y) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
873 |
do_intrinsic(_StringBuffer_append_int, java_lang_StringBuffer, append_name, int_StringBuffer_signature, F_Y) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
874 |
do_intrinsic(_StringBuffer_append_String, java_lang_StringBuffer, append_name, String_StringBuffer_signature, F_Y) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
875 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
876 |
do_intrinsic(_StringBuffer_toString, java_lang_StringBuffer, toString_name, void_string_signature, F_Y) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
877 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
878 |
do_intrinsic(_Integer_toString, java_lang_Integer, toString_name, int_String_signature, F_S) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
879 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
880 |
do_intrinsic(_String_String, java_lang_String, object_initializer_name, string_void_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
881 |
\ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
882 |
do_intrinsic(_Object_init, java_lang_Object, object_initializer_name, void_method_signature, F_R) \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
883 |
/* (symbol object_initializer_name defined above) */ \ |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
884 |
\ |
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
885 |
do_intrinsic(_invoke, java_lang_reflect_Method, invoke_name, object_object_array_object_signature, F_R) \ |
3273
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
886 |
/* (symbols invoke_name and invoke_signature defined above) */ \ |
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
887 |
do_intrinsic(_checkSpreadArgument, sun_dyn_MethodHandleImpl, checkSpreadArgument_name, checkSpreadArgument_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
888 |
do_name( checkSpreadArgument_name, "checkSpreadArgument") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
889 |
do_name( checkSpreadArgument_signature, "(Ljava/lang/Object;I)V") \ |
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
890 |
do_intrinsic(_invokeExact, java_dyn_MethodHandle, invokeExact_name, object_array_object_signature, F_RN) \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
891 |
do_intrinsic(_invokeGeneric, java_dyn_MethodHandle, invokeGeneric_name, object_array_object_signature, F_RN) \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
892 |
do_intrinsic(_invokeVarargs, java_dyn_MethodHandle, invokeVarargs_name, object_array_object_signature, F_R) \ |
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
5352
diff
changeset
|
893 |
do_intrinsic(_invokeDynamic, java_dyn_InvokeDynamic, star_name, object_array_object_signature, F_SN) \ |
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
894 |
\ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
895 |
/* unboxing methods: */ \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
896 |
do_intrinsic(_booleanValue, java_lang_Boolean, booleanValue_name, void_boolean_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
897 |
do_name( booleanValue_name, "booleanValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
898 |
do_intrinsic(_byteValue, java_lang_Byte, byteValue_name, void_byte_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
899 |
do_name( byteValue_name, "byteValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
900 |
do_intrinsic(_charValue, java_lang_Character, charValue_name, void_char_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
901 |
do_name( charValue_name, "charValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
902 |
do_intrinsic(_shortValue, java_lang_Short, shortValue_name, void_short_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
903 |
do_name( shortValue_name, "shortValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
904 |
do_intrinsic(_intValue, java_lang_Integer, intValue_name, void_int_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
905 |
do_name( intValue_name, "intValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
906 |
do_intrinsic(_longValue, java_lang_Long, longValue_name, void_long_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
907 |
do_name( longValue_name, "longValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
908 |
do_intrinsic(_floatValue, java_lang_Float, floatValue_name, void_float_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
909 |
do_name( floatValue_name, "floatValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
910 |
do_intrinsic(_doubleValue, java_lang_Double, doubleValue_name, void_double_signature, F_R) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
911 |
do_name( doubleValue_name, "doubleValue") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
912 |
\ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
913 |
/* boxing methods: */ \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
914 |
do_name( valueOf_name, "valueOf") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
915 |
do_intrinsic(_Boolean_valueOf, java_lang_Boolean, valueOf_name, Boolean_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
916 |
do_name( Boolean_valueOf_signature, "(Z)Ljava/lang/Boolean;") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
917 |
do_intrinsic(_Byte_valueOf, java_lang_Byte, valueOf_name, Byte_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
918 |
do_name( Byte_valueOf_signature, "(B)Ljava/lang/Byte;") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
919 |
do_intrinsic(_Character_valueOf, java_lang_Character, valueOf_name, Character_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
920 |
do_name( Character_valueOf_signature, "(C)Ljava/lang/Character;") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
921 |
do_intrinsic(_Short_valueOf, java_lang_Short, valueOf_name, Short_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
922 |
do_name( Short_valueOf_signature, "(S)Ljava/lang/Short;") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
923 |
do_intrinsic(_Integer_valueOf, java_lang_Integer, valueOf_name, Integer_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
924 |
do_name( Integer_valueOf_signature, "(I)Ljava/lang/Integer;") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
925 |
do_intrinsic(_Long_valueOf, java_lang_Long, valueOf_name, Long_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
926 |
do_name( Long_valueOf_signature, "(J)Ljava/lang/Long;") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
927 |
do_intrinsic(_Float_valueOf, java_lang_Float, valueOf_name, Float_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
928 |
do_name( Float_valueOf_signature, "(F)Ljava/lang/Float;") \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
929 |
do_intrinsic(_Double_valueOf, java_lang_Double, valueOf_name, Double_valueOf_signature, F_S) \ |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
930 |
do_name( Double_valueOf_signature, "(D)Ljava/lang/Double;") \ |
3273
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
931 |
\ |
1 | 932 |
/*end*/ |
933 |
||
934 |
||
935 |
||
3273
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
936 |
|
1 | 937 |
// Class vmSymbols |
938 |
||
939 |
class vmSymbols: AllStatic { |
|
940 |
friend class vmSymbolHandles; |
|
941 |
friend class vmIntrinsics; |
|
942 |
public: |
|
943 |
// enum for figuring positions and size of array holding symbolOops |
|
944 |
enum SID { |
|
945 |
NO_SID = 0, |
|
946 |
||
947 |
#define VM_SYMBOL_ENUM(name, string) VM_SYMBOL_ENUM_NAME(name), |
|
948 |
VM_SYMBOLS_DO(VM_SYMBOL_ENUM, VM_ALIAS_IGNORE) |
|
949 |
#undef VM_SYMBOL_ENUM |
|
950 |
||
951 |
SID_LIMIT, |
|
952 |
||
953 |
#define VM_ALIAS_ENUM(name, def) VM_SYMBOL_ENUM_NAME(name) = VM_SYMBOL_ENUM_NAME(def), |
|
954 |
VM_SYMBOLS_DO(VM_SYMBOL_IGNORE, VM_ALIAS_ENUM) |
|
955 |
#undef VM_ALIAS_ENUM |
|
956 |
||
957 |
FIRST_SID = NO_SID + 1 |
|
958 |
}; |
|
959 |
enum { |
|
960 |
log2_SID_LIMIT = 10 // checked by an assert at start-up |
|
961 |
}; |
|
962 |
||
963 |
private: |
|
964 |
// The symbol array |
|
965 |
static symbolOop _symbols[]; |
|
966 |
||
967 |
// Field signatures indexed by BasicType. |
|
968 |
static symbolOop _type_signatures[T_VOID+1]; |
|
969 |
||
970 |
public: |
|
971 |
// Initialization |
|
972 |
static void initialize(TRAPS); |
|
973 |
// Accessing |
|
974 |
#define VM_SYMBOL_DECLARE(name, ignore) \ |
|
975 |
static symbolOop name() { return _symbols[VM_SYMBOL_ENUM_NAME(name)]; } |
|
976 |
VM_SYMBOLS_DO(VM_SYMBOL_DECLARE, VM_SYMBOL_DECLARE) |
|
977 |
#undef VM_SYMBOL_DECLARE |
|
978 |
||
979 |
// GC support |
|
980 |
static void oops_do(OopClosure* f, bool do_all = false); |
|
981 |
||
982 |
static symbolOop type_signature(BasicType t) { |
|
983 |
assert((uint)t < T_VOID+1, "range check"); |
|
984 |
assert(_type_signatures[t] != NULL, "domain check"); |
|
985 |
return _type_signatures[t]; |
|
986 |
} |
|
987 |
// inverse of type_signature; returns T_OBJECT if s is not recognized |
|
988 |
static BasicType signature_type(symbolOop s); |
|
989 |
||
990 |
static symbolOop symbol_at(SID id) { |
|
991 |
assert(id >= FIRST_SID && id < SID_LIMIT, "oob"); |
|
992 |
assert(_symbols[id] != NULL, "init"); |
|
993 |
return _symbols[id]; |
|
994 |
} |
|
995 |
||
996 |
// Returns symbol's SID if one is assigned, else NO_SID. |
|
997 |
static SID find_sid(symbolOop symbol); |
|
998 |
||
999 |
#ifndef PRODUCT |
|
1000 |
// No need for this in the product: |
|
1001 |
static const char* name_for(SID sid); |
|
1002 |
#endif //PRODUCT |
|
1003 |
}; |
|
1004 |
||
1005 |
||
1006 |
// Class vmSymbolHandles |
|
1007 |
||
1008 |
class vmSymbolHandles: AllStatic { |
|
1009 |
friend class vmIntrinsics; |
|
1010 |
friend class ciObjectFactory; |
|
1011 |
||
1012 |
public: |
|
1013 |
// Accessing |
|
1014 |
#define VM_SYMBOL_HANDLE_DECLARE(name, ignore) \ |
|
1015 |
static symbolHandle name() { return symbol_handle_at(vmSymbols::VM_SYMBOL_ENUM_NAME(name)); } |
|
1016 |
VM_SYMBOLS_DO(VM_SYMBOL_HANDLE_DECLARE, VM_SYMBOL_HANDLE_DECLARE) |
|
1017 |
#undef VM_SYMBOL_HANDLE_DECLARE |
|
1018 |
||
1019 |
static symbolHandle symbol_handle_at(vmSymbols::SID id) { |
|
1020 |
return symbolHandle(&vmSymbols::_symbols[(int)id], false); |
|
1021 |
} |
|
1022 |
||
1023 |
static symbolHandle type_signature(BasicType t) { |
|
1024 |
assert(vmSymbols::type_signature(t) != NULL, "domain check"); |
|
1025 |
return symbolHandle(&vmSymbols::_type_signatures[t], false); |
|
1026 |
} |
|
1027 |
// inverse of type_signature; returns T_OBJECT if s is not recognized |
|
1028 |
static BasicType signature_type(symbolHandle s) { |
|
1029 |
return vmSymbols::signature_type(s()); |
|
1030 |
} |
|
1031 |
}; |
|
1032 |
||
1033 |
// VM Intrinsic ID's uniquely identify some very special methods |
|
1034 |
class vmIntrinsics: AllStatic { |
|
1035 |
friend class vmSymbols; |
|
1036 |
friend class ciObjectFactory; |
|
1037 |
||
1038 |
public: |
|
1039 |
// Accessing |
|
1040 |
enum ID { |
|
1041 |
_none = 0, // not an intrinsic (default answer) |
|
1042 |
||
1043 |
#define VM_INTRINSIC_ENUM(id, klass, name, sig, flags) id, |
|
1044 |
VM_INTRINSICS_DO(VM_INTRINSIC_ENUM, |
|
1045 |
VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_SYMBOL_IGNORE, VM_ALIAS_IGNORE) |
|
1046 |
#undef VM_INTRINSIC_ENUM |
|
1047 |
||
1048 |
ID_LIMIT, |
|
3273
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
1049 |
LAST_COMPILER_INLINE = _prefetchWriteStatic, |
1 | 1050 |
FIRST_ID = _none + 1 |
1051 |
}; |
|
1052 |
||
1053 |
enum Flags { |
|
1054 |
// AccessFlags syndromes relevant to intrinsics. |
|
1055 |
F_none = 0, |
|
4450
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
1056 |
F_R, // !static ?native !synchronized (R="regular") |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
1057 |
F_S, // static ?native !synchronized |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
1058 |
F_Y, // !static ?native synchronized |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
1059 |
F_RN, // !static native !synchronized |
6d700b859b3e
6892658: C2 should optimize some stringbuilder patterns
never
parents:
4429
diff
changeset
|
1060 |
F_SN, // static native !synchronized |
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1061 |
F_RNY, // !static native synchronized |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1062 |
|
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1063 |
FLAG_LIMIT |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1064 |
}; |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1065 |
enum { |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1066 |
log2_FLAG_LIMIT = 4 // checked by an assert at start-up |
1 | 1067 |
}; |
1068 |
||
1069 |
public: |
|
1070 |
static ID ID_from(int raw_id) { |
|
1071 |
assert(raw_id >= (int)_none && raw_id < (int)ID_LIMIT, |
|
1072 |
"must be a valid intrinsic ID"); |
|
1073 |
return (ID)raw_id; |
|
1074 |
} |
|
1075 |
||
1076 |
static const char* name_at(ID id); |
|
1077 |
||
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1078 |
private: |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1079 |
static ID find_id_impl(vmSymbols::SID holder, |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1080 |
vmSymbols::SID name, |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1081 |
vmSymbols::SID sig, |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1082 |
jshort flags); |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1083 |
|
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1084 |
public: |
1 | 1085 |
// Given a method's class, name, signature, and access flags, report its ID. |
1086 |
static ID find_id(vmSymbols::SID holder, |
|
1087 |
vmSymbols::SID name, |
|
1088 |
vmSymbols::SID sig, |
|
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1089 |
jshort flags) { |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1090 |
ID id = find_id_impl(holder, name, sig, flags); |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1091 |
#ifdef ASSERT |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1092 |
// ID _none does not hold the following asserts. |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1093 |
if (id == _none) return id; |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1094 |
#endif |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1095 |
assert( class_for(id) == holder, "correct id"); |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1096 |
assert( name_for(id) == name, "correct id"); |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1097 |
assert(signature_for(id) == sig, "correct id"); |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1098 |
return id; |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1099 |
} |
1 | 1100 |
|
1101 |
static void verify_method(ID actual_id, methodOop m) PRODUCT_RETURN; |
|
1102 |
||
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1103 |
// Find out the symbols behind an intrinsic: |
1 | 1104 |
static vmSymbols::SID class_for(ID id); |
1105 |
static vmSymbols::SID name_for(ID id); |
|
1106 |
static vmSymbols::SID signature_for(ID id); |
|
1107 |
static Flags flags_for(ID id); |
|
1108 |
||
1109 |
static const char* short_name_as_C_string(ID id, char* buf, int size); |
|
3273
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
1110 |
|
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
1111 |
// Access to intrinsic methods: |
6acf7084b1d3
6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents:
2862
diff
changeset
|
1112 |
static methodOop method_for(ID id); |
4562
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1113 |
|
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1114 |
// Wrapper object methods: |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1115 |
static ID for_boxing(BasicType type); |
5d93cb2d2090
6894206: JVM needs a way to traverse method handle structures
twisti
parents:
4450
diff
changeset
|
1116 |
static ID for_unboxing(BasicType type); |
4567
7fc02fbe5c7a
6893268: additional dynamic language related optimizations in C2
twisti
parents:
4564
diff
changeset
|
1117 |
|
7fc02fbe5c7a
6893268: additional dynamic language related optimizations in C2
twisti
parents:
4564
diff
changeset
|
1118 |
// Raw conversion: |
7fc02fbe5c7a
6893268: additional dynamic language related optimizations in C2
twisti
parents:
4564
diff
changeset
|
1119 |
static ID for_raw_conversion(BasicType src, BasicType dest); |
1 | 1120 |
}; |
7397 | 1121 |
|
1122 |
#endif // SHARE_VM_CLASSFILE_VMSYMBOLS_HPP |