author | lfoltan |
Mon, 21 Oct 2019 13:13:16 -0400 | |
changeset 58722 | cba8afa5cfed |
parent 58664 | e3618c902d17 |
child 58679 | 9c3209ff7550 |
child 58756 | b7aa58d7f5aa |
permissions | -rw-r--r-- |
1 | 1 |
/* |
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52514
diff
changeset
|
2 |
* Copyright (c) 1997, 2019, 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:
5421
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5421
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:
5421
diff
changeset
|
21 |
* questions. |
1 | 22 |
* |
23 |
*/ |
|
24 |
||
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52514
diff
changeset
|
25 |
#ifndef SHARE_CLASSFILE_SYSTEMDICTIONARY_HPP |
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52514
diff
changeset
|
26 |
#define SHARE_CLASSFILE_SYSTEMDICTIONARY_HPP |
7397 | 27 |
|
54347
235883996bc7
8221698: Remove redundant includes from popular header files
iklam
parents:
53884
diff
changeset
|
28 |
#include "classfile/classLoaderData.hpp" |
7397 | 29 |
#include "oops/objArrayOop.hpp" |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
30 |
#include "oops/symbol.hpp" |
7397 | 31 |
#include "runtime/java.hpp" |
54352
e0603b4537c3
8221726: Multiple build failures after JDK-8221698 (Remove redundant includes from popular header files)
shade
parents:
54347
diff
changeset
|
32 |
#include "runtime/mutexLocker.hpp" |
7397 | 33 |
#include "runtime/reflectionUtils.hpp" |
48826 | 34 |
#include "runtime/signature.hpp" |
7397 | 35 |
#include "utilities/hashtable.hpp" |
18025 | 36 |
|
46729 | 37 |
// The dictionary in each ClassLoaderData stores all loaded classes, either |
38 |
// initiatied by its class loader or defined by its class loader: |
|
1 | 39 |
// |
46729 | 40 |
// class loader -> ClassLoaderData -> [class, protection domain set] |
1 | 41 |
// |
42 |
// Classes are loaded lazily. The default VM class loader is |
|
43 |
// represented as NULL. |
|
44 |
||
46729 | 45 |
// The underlying data structure is an open hash table (Dictionary) per |
46 |
// ClassLoaderData with a fixed number of buckets. During loading the |
|
47 |
// class loader object is locked, (for the VM loader a private lock object is used). |
|
48 |
// The global SystemDictionary_lock is held for all additions into the ClassLoaderData |
|
49 |
// dictionaries. TODO: fix lock granularity so that class loading can |
|
50 |
// be done concurrently, but only by different loaders. |
|
1 | 51 |
// |
52 |
// During loading a placeholder (name, loader) is temporarily placed in |
|
53 |
// a side data structure, and is used to detect ClassCircularityErrors |
|
54 |
// and to perform verification during GC. A GC can occur in the midst |
|
55 |
// of class loading, as we call out to Java, have to take locks, etc. |
|
56 |
// |
|
46729 | 57 |
// When class loading is finished, a new entry is added to the dictionary |
58 |
// of the class loader and the placeholder is removed. Note that the protection |
|
59 |
// domain field of the dictionary entry has not yet been filled in when |
|
60 |
// the "real" dictionary entry is created. |
|
1 | 61 |
// |
62 |
// Clients of this class who are interested in finding if a class has |
|
63 |
// been completely loaded -- not classes in the process of being loaded -- |
|
46729 | 64 |
// can read the dictionary unlocked. This is safe because |
1 | 65 |
// - entries are only deleted at safepoints |
66 |
// - readers cannot come to a safepoint while actively examining |
|
67 |
// an entry (an entry cannot be deleted from under a reader) |
|
68 |
// - entries must be fully formed before they are available to concurrent |
|
69 |
// readers (we must ensure write ordering) |
|
70 |
// |
|
71 |
// Note that placeholders are deleted at any time, as they are removed |
|
72 |
// when a class is completely loaded. Therefore, readers as well as writers |
|
73 |
// of placeholders must hold the SystemDictionary_lock. |
|
74 |
// |
|
75 |
||
54600
69cfd80f8706
8218994: Consolidate indy and condy JVM information within a BootstrapInfo data structure
lfoltan
parents:
54439
diff
changeset
|
76 |
class BootstrapInfo; |
34666 | 77 |
class ClassFileStream; |
1 | 78 |
class Dictionary; |
79 |
class PlaceholderTable; |
|
80 |
class LoaderConstraintTable; |
|
13195 | 81 |
template <MEMFLAGS F> class HashtableBucket; |
1 | 82 |
class ResolutionErrorTable; |
2534 | 83 |
class SymbolPropertyTable; |
46729 | 84 |
class ProtectionDomainCacheTable; |
85 |
class ProtectionDomainCacheEntry; |
|
46505
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46435
diff
changeset
|
86 |
class GCTimer; |
1 | 87 |
|
52319
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
88 |
#define WK_KLASS_ENUM_NAME(kname) kname##_knum |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
89 |
|
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
90 |
// Certain classes, such as java.lang.Object and java.lang.String, |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
91 |
// are "well-known", in the sense that no class loader is allowed |
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
92 |
// to provide a different definition. |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
93 |
// |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
94 |
// Each well-known class has a short klass name (like object_klass), |
52195 | 95 |
// and a vmSymbol name (like java_lang_Object). |
52319
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
96 |
// |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
97 |
// The order of these definitions is significant: the classes are |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
98 |
// resolved during early VM start-up by resolve_well_known_classes |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
99 |
// in this order. Changing the order may require careful restructuring |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
100 |
// of the VM start-up sequence. |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
101 |
// |
52195 | 102 |
#define WK_KLASSES_DO(do_klass) \ |
103 |
/* well-known classes */ \ |
|
104 |
do_klass(Object_klass, java_lang_Object ) \ |
|
105 |
do_klass(String_klass, java_lang_String ) \ |
|
106 |
do_klass(Class_klass, java_lang_Class ) \ |
|
107 |
do_klass(Cloneable_klass, java_lang_Cloneable ) \ |
|
108 |
do_klass(ClassLoader_klass, java_lang_ClassLoader ) \ |
|
109 |
do_klass(Serializable_klass, java_io_Serializable ) \ |
|
110 |
do_klass(System_klass, java_lang_System ) \ |
|
111 |
do_klass(Throwable_klass, java_lang_Throwable ) \ |
|
112 |
do_klass(Error_klass, java_lang_Error ) \ |
|
113 |
do_klass(ThreadDeath_klass, java_lang_ThreadDeath ) \ |
|
114 |
do_klass(Exception_klass, java_lang_Exception ) \ |
|
115 |
do_klass(RuntimeException_klass, java_lang_RuntimeException ) \ |
|
116 |
do_klass(SecurityManager_klass, java_lang_SecurityManager ) \ |
|
117 |
do_klass(ProtectionDomain_klass, java_security_ProtectionDomain ) \ |
|
118 |
do_klass(AccessControlContext_klass, java_security_AccessControlContext ) \ |
|
52431
b0af758a092c
8212605: Pure-Java implementation of AccessController.doPrivileged
dlong
parents:
52335
diff
changeset
|
119 |
do_klass(AccessController_klass, java_security_AccessController ) \ |
52195 | 120 |
do_klass(SecureClassLoader_klass, java_security_SecureClassLoader ) \ |
121 |
do_klass(ClassNotFoundException_klass, java_lang_ClassNotFoundException ) \ |
|
122 |
do_klass(NoClassDefFoundError_klass, java_lang_NoClassDefFoundError ) \ |
|
123 |
do_klass(LinkageError_klass, java_lang_LinkageError ) \ |
|
124 |
do_klass(ClassCastException_klass, java_lang_ClassCastException ) \ |
|
125 |
do_klass(ArrayStoreException_klass, java_lang_ArrayStoreException ) \ |
|
126 |
do_klass(VirtualMachineError_klass, java_lang_VirtualMachineError ) \ |
|
127 |
do_klass(OutOfMemoryError_klass, java_lang_OutOfMemoryError ) \ |
|
128 |
do_klass(StackOverflowError_klass, java_lang_StackOverflowError ) \ |
|
129 |
do_klass(IllegalMonitorStateException_klass, java_lang_IllegalMonitorStateException ) \ |
|
130 |
do_klass(Reference_klass, java_lang_ref_Reference ) \ |
|
131 |
\ |
|
52319
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
132 |
/* ref klasses and set reference types */ \ |
52195 | 133 |
do_klass(SoftReference_klass, java_lang_ref_SoftReference ) \ |
134 |
do_klass(WeakReference_klass, java_lang_ref_WeakReference ) \ |
|
135 |
do_klass(FinalReference_klass, java_lang_ref_FinalReference ) \ |
|
136 |
do_klass(PhantomReference_klass, java_lang_ref_PhantomReference ) \ |
|
137 |
do_klass(Finalizer_klass, java_lang_ref_Finalizer ) \ |
|
138 |
\ |
|
139 |
do_klass(Thread_klass, java_lang_Thread ) \ |
|
140 |
do_klass(ThreadGroup_klass, java_lang_ThreadGroup ) \ |
|
141 |
do_klass(Properties_klass, java_util_Properties ) \ |
|
142 |
do_klass(Module_klass, java_lang_Module ) \ |
|
143 |
do_klass(reflect_AccessibleObject_klass, java_lang_reflect_AccessibleObject ) \ |
|
144 |
do_klass(reflect_Field_klass, java_lang_reflect_Field ) \ |
|
145 |
do_klass(reflect_Parameter_klass, java_lang_reflect_Parameter ) \ |
|
146 |
do_klass(reflect_Method_klass, java_lang_reflect_Method ) \ |
|
147 |
do_klass(reflect_Constructor_klass, java_lang_reflect_Constructor ) \ |
|
148 |
\ |
|
149 |
/* NOTE: needed too early in bootstrapping process to have checks based on JDK version */ \ |
|
150 |
/* It's okay if this turns out to be NULL in non-1.4 JDKs. */ \ |
|
151 |
do_klass(reflect_MagicAccessorImpl_klass, reflect_MagicAccessorImpl ) \ |
|
152 |
do_klass(reflect_MethodAccessorImpl_klass, reflect_MethodAccessorImpl ) \ |
|
153 |
do_klass(reflect_ConstructorAccessorImpl_klass, reflect_ConstructorAccessorImpl ) \ |
|
154 |
do_klass(reflect_DelegatingClassLoader_klass, reflect_DelegatingClassLoader ) \ |
|
155 |
do_klass(reflect_ConstantPool_klass, reflect_ConstantPool ) \ |
|
156 |
do_klass(reflect_UnsafeStaticFieldAccessorImpl_klass, reflect_UnsafeStaticFieldAccessorImpl ) \ |
|
157 |
do_klass(reflect_CallerSensitive_klass, reflect_CallerSensitive ) \ |
|
58664
e3618c902d17
8218628: Add detailed message to NullPointerException describing what is null.
goetz
parents:
57828
diff
changeset
|
158 |
do_klass(reflect_NativeConstructorAccessorImpl_klass, reflect_NativeConstructorAccessorImpl ) \ |
52195 | 159 |
\ |
160 |
/* support for dynamic typing; it's OK if these are NULL in earlier JDKs */ \ |
|
161 |
do_klass(DirectMethodHandle_klass, java_lang_invoke_DirectMethodHandle ) \ |
|
162 |
do_klass(MethodHandle_klass, java_lang_invoke_MethodHandle ) \ |
|
163 |
do_klass(VarHandle_klass, java_lang_invoke_VarHandle ) \ |
|
164 |
do_klass(MemberName_klass, java_lang_invoke_MemberName ) \ |
|
165 |
do_klass(ResolvedMethodName_klass, java_lang_invoke_ResolvedMethodName ) \ |
|
166 |
do_klass(MethodHandleNatives_klass, java_lang_invoke_MethodHandleNatives ) \ |
|
167 |
do_klass(LambdaForm_klass, java_lang_invoke_LambdaForm ) \ |
|
168 |
do_klass(MethodType_klass, java_lang_invoke_MethodType ) \ |
|
169 |
do_klass(BootstrapMethodError_klass, java_lang_BootstrapMethodError ) \ |
|
170 |
do_klass(CallSite_klass, java_lang_invoke_CallSite ) \ |
|
171 |
do_klass(Context_klass, java_lang_invoke_MethodHandleNatives_CallSiteContext ) \ |
|
172 |
do_klass(ConstantCallSite_klass, java_lang_invoke_ConstantCallSite ) \ |
|
173 |
do_klass(MutableCallSite_klass, java_lang_invoke_MutableCallSite ) \ |
|
174 |
do_klass(VolatileCallSite_klass, java_lang_invoke_VolatileCallSite ) \ |
|
175 |
/* Note: MethodHandle must be first, and VolatileCallSite last in group */ \ |
|
176 |
\ |
|
177 |
do_klass(AssertionStatusDirectives_klass, java_lang_AssertionStatusDirectives ) \ |
|
178 |
do_klass(StringBuffer_klass, java_lang_StringBuffer ) \ |
|
179 |
do_klass(StringBuilder_klass, java_lang_StringBuilder ) \ |
|
54439
d9b46b7de028
8221477: Inject os/cpu-specific constants into Unsafe from JVM
adinn
parents:
54352
diff
changeset
|
180 |
do_klass(UnsafeConstants_klass, jdk_internal_misc_UnsafeConstants ) \ |
52195 | 181 |
do_klass(internal_Unsafe_klass, jdk_internal_misc_Unsafe ) \ |
182 |
do_klass(module_Modules_klass, jdk_internal_module_Modules ) \ |
|
183 |
\ |
|
184 |
/* support for CDS */ \ |
|
185 |
do_klass(ByteArrayInputStream_klass, java_io_ByteArrayInputStream ) \ |
|
186 |
do_klass(URL_klass, java_net_URL ) \ |
|
187 |
do_klass(Jar_Manifest_klass, java_util_jar_Manifest ) \ |
|
188 |
do_klass(jdk_internal_loader_ClassLoaders_klass, jdk_internal_loader_ClassLoaders ) \ |
|
189 |
do_klass(jdk_internal_loader_ClassLoaders_AppClassLoader_klass, jdk_internal_loader_ClassLoaders_AppClassLoader) \ |
|
190 |
do_klass(jdk_internal_loader_ClassLoaders_PlatformClassLoader_klass, jdk_internal_loader_ClassLoaders_PlatformClassLoader) \ |
|
191 |
do_klass(CodeSource_klass, java_security_CodeSource ) \ |
|
192 |
\ |
|
193 |
do_klass(StackTraceElement_klass, java_lang_StackTraceElement ) \ |
|
194 |
\ |
|
195 |
/* It's okay if this turns out to be NULL in non-1.4 JDKs. */ \ |
|
196 |
do_klass(nio_Buffer_klass, java_nio_Buffer ) \ |
|
197 |
\ |
|
198 |
/* Stack Walking */ \ |
|
199 |
do_klass(StackWalker_klass, java_lang_StackWalker ) \ |
|
200 |
do_klass(AbstractStackWalker_klass, java_lang_StackStreamFactory_AbstractStackWalker ) \ |
|
201 |
do_klass(StackFrameInfo_klass, java_lang_StackFrameInfo ) \ |
|
202 |
do_klass(LiveStackFrameInfo_klass, java_lang_LiveStackFrameInfo ) \ |
|
203 |
\ |
|
204 |
/* support for stack dump lock analysis */ \ |
|
205 |
do_klass(java_util_concurrent_locks_AbstractOwnableSynchronizer_klass, java_util_concurrent_locks_AbstractOwnableSynchronizer) \ |
|
206 |
\ |
|
52319
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
207 |
/* boxing klasses */ \ |
52195 | 208 |
do_klass(Boolean_klass, java_lang_Boolean ) \ |
209 |
do_klass(Character_klass, java_lang_Character ) \ |
|
210 |
do_klass(Float_klass, java_lang_Float ) \ |
|
211 |
do_klass(Double_klass, java_lang_Double ) \ |
|
212 |
do_klass(Byte_klass, java_lang_Byte ) \ |
|
213 |
do_klass(Short_klass, java_lang_Short ) \ |
|
214 |
do_klass(Integer_klass, java_lang_Integer ) \ |
|
215 |
do_klass(Long_klass, java_lang_Long ) \ |
|
216 |
\ |
|
55115
a0d4e61acb6b
8223504: Improve performance of forall loops by better inlining of "iterator()" methods
skuksenko
parents:
54807
diff
changeset
|
217 |
/* force inline of iterators */ \ |
a0d4e61acb6b
8223504: Improve performance of forall loops by better inlining of "iterator()" methods
skuksenko
parents:
54807
diff
changeset
|
218 |
do_klass(Iterator_klass, java_util_Iterator ) \ |
a0d4e61acb6b
8223504: Improve performance of forall loops by better inlining of "iterator()" methods
skuksenko
parents:
54807
diff
changeset
|
219 |
\ |
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
220 |
/*end*/ |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
221 |
|
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
222 |
|
1 | 223 |
class SystemDictionary : AllStatic { |
54600
69cfd80f8706
8218994: Consolidate indy and condy JVM information within a BootstrapInfo data structure
lfoltan
parents:
54439
diff
changeset
|
224 |
friend class BootstrapInfo; |
1 | 225 |
friend class VMStructs; |
2332
5c7b6f4ce0a1
6814659: separable cleanups and subroutines for 6655638
jrose
parents:
2105
diff
changeset
|
226 |
friend class SystemDictionaryHandles; |
1 | 227 |
|
228 |
public: |
|
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
229 |
enum WKID { |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
230 |
NO_WKID = 0, |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
231 |
|
52195 | 232 |
#define WK_KLASS_ENUM(name, symbol) WK_KLASS_ENUM_NAME(name), WK_KLASS_ENUM_NAME(symbol) = WK_KLASS_ENUM_NAME(name), |
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
233 |
WK_KLASSES_DO(WK_KLASS_ENUM) |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
234 |
#undef WK_KLASS_ENUM |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
235 |
|
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
236 |
WKID_LIMIT, |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
237 |
|
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
238 |
FIRST_WKID = NO_WKID + 1 |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
239 |
}; |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
240 |
|
1 | 241 |
// Returns a class with a given class name and class loader. Loads the |
242 |
// class if needed. If not found a NoClassDefFoundError or a |
|
243 |
// ClassNotFoundException is thrown, depending on the value on the |
|
244 |
// throw_error flag. For most uses the throw_error argument should be set |
|
245 |
// to true. |
|
246 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
247 |
static Klass* resolve_or_fail(Symbol* class_name, Handle class_loader, Handle protection_domain, bool throw_error, TRAPS); |
1 | 248 |
// Convenient call for null loader and protection domain. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
249 |
static Klass* resolve_or_fail(Symbol* class_name, bool throw_error, TRAPS); |
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
250 |
protected: |
1 | 251 |
// handle error translation for resolve_or_null results |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
252 |
static Klass* handle_resolution_exception(Symbol* class_name, bool throw_error, Klass* klass, TRAPS); |
1 | 253 |
|
254 |
public: |
|
255 |
||
256 |
// Returns a class with a given class name and class loader. |
|
257 |
// Loads the class if needed. If not found NULL is returned. |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
258 |
static Klass* resolve_or_null(Symbol* class_name, Handle class_loader, Handle protection_domain, TRAPS); |
1 | 259 |
// Version with null loader and protection domain |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
260 |
static Klass* resolve_or_null(Symbol* class_name, TRAPS); |
1 | 261 |
|
262 |
// Resolve a superclass or superinterface. Called from ClassFileParser, |
|
263 |
// parse_interfaces, resolve_instance_class_or_null, load_shared_class |
|
264 |
// "child_name" is the class whose super class or interface is being resolved. |
|
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
265 |
static InstanceKlass* resolve_super_or_fail(Symbol* child_name, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
266 |
Symbol* class_name, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
267 |
Handle class_loader, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
268 |
Handle protection_domain, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
269 |
bool is_superclass, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
270 |
TRAPS); |
1 | 271 |
|
46729 | 272 |
// Parse new stream. This won't update the dictionary or |
1 | 273 |
// class hierarchy, simply parse the stream. Used by JVMTI RedefineClasses. |
40016 | 274 |
// Also used by Unsafe_DefineAnonymousClass |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
275 |
static InstanceKlass* parse_stream(Symbol* class_name, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
276 |
Handle class_loader, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
277 |
Handle protection_domain, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
278 |
ClassFileStream* st, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
279 |
TRAPS) { |
34666 | 280 |
return parse_stream(class_name, |
281 |
class_loader, |
|
282 |
protection_domain, |
|
283 |
st, |
|
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51429
diff
changeset
|
284 |
NULL, // unsafe_anonymous_host |
34666 | 285 |
NULL, // cp_patches |
286 |
THREAD); |
|
1550
be2fc37a817f
6653858: dynamic languages need to be able to load anonymous classes
jrose
parents:
670
diff
changeset
|
287 |
} |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
288 |
static InstanceKlass* parse_stream(Symbol* class_name, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
289 |
Handle class_loader, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
290 |
Handle protection_domain, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
291 |
ClassFileStream* st, |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51429
diff
changeset
|
292 |
const InstanceKlass* unsafe_anonymous_host, |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
293 |
GrowableArray<Handle>* cp_patches, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
294 |
TRAPS); |
1 | 295 |
|
296 |
// Resolve from stream (called by jni_DefineClass and JVM_DefineClass) |
|
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
297 |
static InstanceKlass* resolve_from_stream(Symbol* class_name, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
298 |
Handle class_loader, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
299 |
Handle protection_domain, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
300 |
ClassFileStream* st, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
301 |
TRAPS); |
1 | 302 |
|
303 |
// Lookup an already loaded class. If not found NULL is returned. |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
304 |
static Klass* find(Symbol* class_name, Handle class_loader, Handle protection_domain, TRAPS); |
1 | 305 |
|
306 |
// Lookup an already loaded instance or array class. |
|
307 |
// Do not make any queries to class loaders; consult only the cache. |
|
308 |
// If not found NULL is returned. |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
309 |
static Klass* find_instance_or_array_klass(Symbol* class_name, |
1 | 310 |
Handle class_loader, |
311 |
Handle protection_domain, |
|
312 |
TRAPS); |
|
313 |
||
314 |
// Lookup an instance or array class that has already been loaded |
|
315 |
// either into the given class loader, or else into another class |
|
316 |
// loader that is constrained (via loader constraints) to produce |
|
317 |
// a consistent class. Do not take protection domains into account. |
|
318 |
// Do not make any queries to class loaders; consult only the cache. |
|
319 |
// Return NULL if the class is not found. |
|
320 |
// |
|
321 |
// This function is a strict superset of find_instance_or_array_klass. |
|
322 |
// This function (the unchecked version) makes a conservative prediction |
|
323 |
// of the result of the checked version, assuming successful lookup. |
|
324 |
// If both functions return non-null, they must return the same value. |
|
325 |
// Also, the unchecked version may sometimes be non-null where the |
|
326 |
// checked version is null. This can occur in several ways: |
|
327 |
// 1. No query has yet been made to the class loader. |
|
328 |
// 2. The class loader was queried, but chose not to delegate. |
|
329 |
// 3. ClassLoader.checkPackageAccess rejected a proposed protection domain. |
|
330 |
// 4. Loading was attempted, but there was a linkage error of some sort. |
|
331 |
// In all of these cases, the loader constraints on this type are |
|
332 |
// satisfied, and it is safe for classes in the given class loader |
|
333 |
// to manipulate strongly-typed values of the found class, subject |
|
334 |
// to local linkage and access checks. |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
335 |
static Klass* find_constrained_instance_or_array_klass(Symbol* class_name, |
1 | 336 |
Handle class_loader, |
337 |
TRAPS); |
|
338 |
||
46746
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46742
diff
changeset
|
339 |
static void classes_do(MetaspaceClosure* it); |
46380
4a51438196cf
8026985: Rewrite SystemDictionary::classes_do and Dictionary::classes_do to use KlassClosure
coleenp
parents:
46329
diff
changeset
|
340 |
// Iterate over all methods in all klasses |
46746
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46742
diff
changeset
|
341 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
342 |
static void methods_do(void f(Method*)); |
1 | 343 |
|
344 |
// Garbage collection support |
|
345 |
||
346 |
// Unload (that is, break root links to) all unmarked classes and |
|
347 |
// loaders. Returns "true" iff something was unloaded. |
|
52498
c3066f7465fa
8213307: G1 should clean up RMT with ClassUnloadingWithConcurrentMark
tschatzl
parents:
52431
diff
changeset
|
348 |
static bool do_unloading(GCTimer* gc_timer); |
1 | 349 |
|
350 |
// Applies "f->do_oop" to all root oops in the system dictionary. |
|
55740 | 351 |
// If include_handles is true (the default), then the handles in the |
57828
35db8fba55f9
8227054: ServiceThread needs to know about all OopStorage objects
kbarrett
parents:
55740
diff
changeset
|
352 |
// vm_global OopStorage object are included. |
55740 | 353 |
static void oops_do(OopClosure* f, bool include_handles = true); |
1 | 354 |
|
355 |
// System loader lock |
|
356 |
static oop system_loader_lock() { return _system_loader_lock_obj; } |
|
357 |
||
51610
cdef4df6b0e7
8206424: Use locking for cleaning ProtectionDomainTable
pchilanomate
parents:
51444
diff
changeset
|
358 |
// Protection Domain Table |
cdef4df6b0e7
8206424: Use locking for cleaning ProtectionDomainTable
pchilanomate
parents:
51444
diff
changeset
|
359 |
static ProtectionDomainCacheTable* pd_cache_table() { return _pd_cache_table; } |
cdef4df6b0e7
8206424: Use locking for cleaning ProtectionDomainTable
pchilanomate
parents:
51444
diff
changeset
|
360 |
|
1 | 361 |
public: |
362 |
// Printing |
|
54807 | 363 |
static void print(); |
46742 | 364 |
static void print_on(outputStream* st); |
365 |
static void dump(outputStream* st, bool verbose); |
|
1 | 366 |
|
367 |
// Verification |
|
368 |
static void verify(); |
|
369 |
||
370 |
// Initialization |
|
371 |
static void initialize(TRAPS); |
|
372 |
||
52319
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
373 |
// Checked fast access to the well-known classes -- so that you don't try to use them |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
374 |
// before they are resolved. |
33602 | 375 |
static InstanceKlass* check_klass(InstanceKlass* k) { |
38708
8c27a4f8b242
8154589: assert(k != NULL) failed: preloaded klass not initialized
dholmes
parents:
37301
diff
changeset
|
376 |
assert(k != NULL, "klass not loaded"); |
1 | 377 |
return k; |
378 |
} |
|
379 |
||
52195 | 380 |
static bool resolve_wk_klass(WKID id, TRAPS); |
51180
b7eb9cc56277
8203382: Rename SystemDictionary::initialize_wk_klass to resolve_wk_klass
iklam
parents:
50951
diff
changeset
|
381 |
static void resolve_wk_klasses_until(WKID limit_id, WKID &start_id, TRAPS); |
b7eb9cc56277
8203382: Rename SystemDictionary::initialize_wk_klass to resolve_wk_klass
iklam
parents:
50951
diff
changeset
|
382 |
static void resolve_wk_klasses_through(WKID end_id, WKID &start_id, TRAPS) { |
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
383 |
int limit = (int)end_id + 1; |
51180
b7eb9cc56277
8203382: Rename SystemDictionary::initialize_wk_klass to resolve_wk_klass
iklam
parents:
50951
diff
changeset
|
384 |
resolve_wk_klasses_until((WKID) limit, start_id, THREAD); |
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
385 |
} |
1 | 386 |
|
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
387 |
public: |
52195 | 388 |
#define WK_KLASS_DECLARE(name, symbol) \ |
389 |
static InstanceKlass* name() { return check_klass(_well_known_klasses[WK_KLASS_ENUM_NAME(name)]); } \ |
|
390 |
static InstanceKlass** name##_addr() { \ |
|
391 |
return &_well_known_klasses[SystemDictionary::WK_KLASS_ENUM_NAME(name)]; \ |
|
392 |
} \ |
|
393 |
static bool name##_is_loaded() { \ |
|
394 |
return _well_known_klasses[SystemDictionary::WK_KLASS_ENUM_NAME(name)] != NULL; \ |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
395 |
} |
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
396 |
WK_KLASSES_DO(WK_KLASS_DECLARE); |
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
397 |
#undef WK_KLASS_DECLARE |
1 | 398 |
|
33602 | 399 |
static InstanceKlass* well_known_klass(WKID id) { |
10546 | 400 |
assert(id >= (int)FIRST_WKID && id < (int)WKID_LIMIT, "oob"); |
401 |
return _well_known_klasses[id]; |
|
402 |
} |
|
403 |
||
33602 | 404 |
static InstanceKlass** well_known_klass_addr(WKID id) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
405 |
assert(id >= (int)FIRST_WKID && id < (int)WKID_LIMIT, "oob"); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
406 |
return &_well_known_klasses[id]; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
407 |
} |
46746
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46742
diff
changeset
|
408 |
static void well_known_klasses_do(MetaspaceClosure* it); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
409 |
|
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
410 |
// Local definition for direct access to the private array: |
394 | 411 |
#define WK_KLASS(name) _well_known_klasses[SystemDictionary::WK_KLASS_ENUM_NAME(name)] |
1 | 412 |
|
33602 | 413 |
static InstanceKlass* box_klass(BasicType t) { |
1 | 414 |
assert((uint)t < T_VOID+1, "range check"); |
415 |
return check_klass(_box_klasses[t]); |
|
416 |
} |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
417 |
static BasicType box_klass_type(Klass* k); // inverse of box_klass |
52319
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
418 |
#ifdef ASSERT |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
419 |
static bool is_well_known_klass(Klass* k) { |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
420 |
return is_well_known_klass(k->name()); |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
421 |
} |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
422 |
static bool is_well_known_klass(Symbol* class_name); |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
423 |
#endif |
1 | 424 |
|
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
425 |
protected: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
426 |
// Returns the class loader data to be used when looking up/updating the |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
427 |
// system dictionary. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
428 |
static ClassLoaderData *class_loader_data(Handle class_loader) { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
429 |
return ClassLoaderData::class_loader_data(class_loader()); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
430 |
} |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
431 |
|
1 | 432 |
public: |
433 |
// Tells whether ClassLoader.checkPackageAccess is present |
|
434 |
static bool has_checkPackageAccess() { return _has_checkPackageAccess; } |
|
435 |
||
15102
0a86564e5f61
8004728: Add hotspot support for parameter reflection
coleenp
parents:
14588
diff
changeset
|
436 |
static bool Parameter_klass_loaded() { return WK_KLASS(reflect_Parameter_klass) != NULL; } |
4571 | 437 |
static bool Class_klass_loaded() { return WK_KLASS(Class_klass) != NULL; } |
438 |
static bool Cloneable_klass_loaded() { return WK_KLASS(Cloneable_klass) != NULL; } |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
439 |
static bool Object_klass_loaded() { return WK_KLASS(Object_klass) != NULL; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
440 |
static bool ClassLoader_klass_loaded() { return WK_KLASS(ClassLoader_klass) != NULL; } |
1 | 441 |
|
47614
0ecfd6c951a6
8185694: Replace SystemDictionaryShared::_java_platform_loader with SystemDictionary::is_platform_class_loader()
ccheung
parents:
47216
diff
changeset
|
442 |
// Returns java system loader |
1 | 443 |
static oop java_system_loader(); |
444 |
||
47614
0ecfd6c951a6
8185694: Replace SystemDictionaryShared::_java_platform_loader with SystemDictionary::is_platform_class_loader()
ccheung
parents:
47216
diff
changeset
|
445 |
// Returns java platform loader |
0ecfd6c951a6
8185694: Replace SystemDictionaryShared::_java_platform_loader with SystemDictionary::is_platform_class_loader()
ccheung
parents:
47216
diff
changeset
|
446 |
static oop java_platform_loader(); |
0ecfd6c951a6
8185694: Replace SystemDictionaryShared::_java_platform_loader with SystemDictionary::is_platform_class_loader()
ccheung
parents:
47216
diff
changeset
|
447 |
|
0ecfd6c951a6
8185694: Replace SystemDictionaryShared::_java_platform_loader with SystemDictionary::is_platform_class_loader()
ccheung
parents:
47216
diff
changeset
|
448 |
// Compute the java system and platform loaders |
0ecfd6c951a6
8185694: Replace SystemDictionaryShared::_java_platform_loader with SystemDictionary::is_platform_class_loader()
ccheung
parents:
47216
diff
changeset
|
449 |
static void compute_java_loaders(TRAPS); |
1 | 450 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
451 |
// Register a new class loader |
49348
fde3feaaa4ed
8198926: Move ClassLoaderData::_dependencies to ClassLoaderData::_handles
coleenp
parents:
49037
diff
changeset
|
452 |
static ClassLoaderData* register_loader(Handle class_loader); |
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
453 |
protected: |
1 | 454 |
// Mirrors for primitive classes (created eagerly) |
455 |
static oop check_mirror(oop m) { |
|
456 |
assert(m != NULL, "mirror not initialized"); |
|
457 |
return m; |
|
458 |
} |
|
459 |
||
460 |
public: |
|
461 |
// Note: java_lang_Class::primitive_type is the inverse of java_mirror |
|
462 |
||
463 |
// Check class loader constraints |
|
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
464 |
static bool add_loader_constraint(Symbol* name, Handle loader1, |
1 | 465 |
Handle loader2, TRAPS); |
16591
73047b0eb568
8009731: Confusing error message for loader constraint violation
acorn
parents:
16352
diff
changeset
|
466 |
static Symbol* check_signature_loaders(Symbol* signature, Handle loader1, |
73047b0eb568
8009731: Confusing error message for loader constraint violation
acorn
parents:
16352
diff
changeset
|
467 |
Handle loader2, bool is_method, TRAPS); |
1 | 468 |
|
2534 | 469 |
// JSR 292 |
13391
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
470 |
// find a java.lang.invoke.MethodHandle.invoke* method for a given signature |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
471 |
// (asks Java to compute it if necessary, except in a compiler thread) |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
472 |
static methodHandle find_method_handle_invoker(Klass* klass, |
36819 | 473 |
Symbol* name, |
13391
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
474 |
Symbol* signature, |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
475 |
Klass* accessing_klass, |
13391
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
476 |
Handle *appendix_result, |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
477 |
TRAPS); |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
478 |
// for a given signature, find the internal MethodHandle method (linkTo* or invokeBasic) |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
479 |
// (does not ask Java, since this is a low-level intrinsic defined by the JVM) |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
480 |
static methodHandle find_method_handle_intrinsic(vmIntrinsics::ID iid, |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
481 |
Symbol* signature, |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
482 |
TRAPS); |
48826 | 483 |
|
484 |
// compute java_mirror (java.lang.Class instance) for a type ("I", "[[B", "LFoo;", etc.) |
|
485 |
// Either the accessing_klass or the CL/PD can be non-null, but not both. |
|
486 |
static Handle find_java_mirror_for_type(Symbol* signature, |
|
487 |
Klass* accessing_klass, |
|
488 |
Handle class_loader, |
|
489 |
Handle protection_domain, |
|
490 |
SignatureStream::FailureMode failure_mode, |
|
491 |
TRAPS); |
|
492 |
static Handle find_java_mirror_for_type(Symbol* signature, |
|
493 |
Klass* accessing_klass, |
|
494 |
SignatureStream::FailureMode failure_mode, |
|
495 |
TRAPS) { |
|
496 |
// callee will fill in CL/PD from AK, if they are needed |
|
497 |
return find_java_mirror_for_type(signature, accessing_klass, Handle(), Handle(), |
|
498 |
failure_mode, THREAD); |
|
499 |
} |
|
500 |
||
501 |
||
502 |
// fast short-cut for the one-character case: |
|
503 |
static oop find_java_mirror_for_type(char signature_char); |
|
504 |
||
13391
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
505 |
// find a java.lang.invoke.MethodType object for a given signature |
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
506 |
// (asks Java to compute it if necessary, except in a compiler thread) |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
507 |
static Handle find_method_handle_type(Symbol* signature, |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
508 |
Klass* accessing_klass, |
5420
586d3988e72b
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
4581
diff
changeset
|
509 |
TRAPS); |
13391
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
510 |
|
48514
9608f7f41c4e
8188145: MethodHandle resolution should follow JVMS sequence of lookup by name & type before type descriptor resolution
vlivanov
parents:
47774
diff
changeset
|
511 |
// find a java.lang.Class object for a given signature |
9608f7f41c4e
8188145: MethodHandle resolution should follow JVMS sequence of lookup by name & type before type descriptor resolution
vlivanov
parents:
47774
diff
changeset
|
512 |
static Handle find_field_handle_type(Symbol* signature, |
9608f7f41c4e
8188145: MethodHandle resolution should follow JVMS sequence of lookup by name & type before type descriptor resolution
vlivanov
parents:
47774
diff
changeset
|
513 |
Klass* accessing_klass, |
9608f7f41c4e
8188145: MethodHandle resolution should follow JVMS sequence of lookup by name & type before type descriptor resolution
vlivanov
parents:
47774
diff
changeset
|
514 |
TRAPS); |
9608f7f41c4e
8188145: MethodHandle resolution should follow JVMS sequence of lookup by name & type before type descriptor resolution
vlivanov
parents:
47774
diff
changeset
|
515 |
|
8676
9098d4e927e1
7012648: move JSR 292 to package java.lang.invoke and adjust names
jrose
parents:
8675
diff
changeset
|
516 |
// ask Java to compute a java.lang.invoke.MethodHandle object for a given CP entry |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
517 |
static Handle link_method_handle_constant(Klass* caller, |
5882 | 518 |
int ref_kind, //e.g., JVM_REF_invokeVirtual |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
519 |
Klass* callee, |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
520 |
Symbol* name, |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
521 |
Symbol* signature, |
5882 | 522 |
TRAPS); |
13391
30245956af37
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
13195
diff
changeset
|
523 |
|
48826 | 524 |
// ask Java to compute a constant by invoking a BSM given a Dynamic_info CP entry |
54600
69cfd80f8706
8218994: Consolidate indy and condy JVM information within a BootstrapInfo data structure
lfoltan
parents:
54439
diff
changeset
|
525 |
static void invoke_bootstrap_method(BootstrapInfo& bootstrap_specifier, TRAPS); |
2570
ecc7862946d4
6655646: dynamic languages need dynamically linked call sites
jrose
parents:
2534
diff
changeset
|
526 |
|
1 | 527 |
// Record the error when the first attempt to resolve a reference from a constant |
528 |
// pool entry to a class fails. |
|
33593
60764a78fa5c
8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents:
33160
diff
changeset
|
529 |
static void add_resolution_error(const constantPoolHandle& pool, int which, Symbol* error, |
24334
36096f7271f4
8023697: failed class resolution reports different class name in detail message for the first and subsequent times
coleenp
parents:
23872
diff
changeset
|
530 |
Symbol* message); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
531 |
static void delete_resolution_error(ConstantPool* pool); |
33593
60764a78fa5c
8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents:
33160
diff
changeset
|
532 |
static Symbol* find_resolution_error(const constantPoolHandle& pool, int which, |
24334
36096f7271f4
8023697: failed class resolution reports different class name in detail message for the first and subsequent times
coleenp
parents:
23872
diff
changeset
|
533 |
Symbol** message); |
1 | 534 |
|
46729 | 535 |
|
536 |
static ProtectionDomainCacheEntry* cache_get(Handle protection_domain); |
|
537 |
||
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
538 |
protected: |
1 | 539 |
|
540 |
enum Constants { |
|
541 |
_loader_constraint_size = 107, // number of entries in constraint table |
|
542 |
_resolution_error_size = 107, // number of entries in resolution error table |
|
2534 | 543 |
_invoke_method_size = 139, // number of entries in invoke method table |
46729 | 544 |
_placeholder_table_size = 1009 // number of entries in hash table for placeholders |
1 | 545 |
}; |
546 |
||
547 |
||
46729 | 548 |
// Static tables owned by the SystemDictionary |
1 | 549 |
|
550 |
// Hashtable holding placeholders for classes being loaded. |
|
551 |
static PlaceholderTable* _placeholders; |
|
552 |
||
553 |
// Lock object for system class loader |
|
554 |
static oop _system_loader_lock_obj; |
|
555 |
||
556 |
// Constraints on class loaders |
|
557 |
static LoaderConstraintTable* _loader_constraints; |
|
558 |
||
559 |
// Resolution errors |
|
560 |
static ResolutionErrorTable* _resolution_errors; |
|
561 |
||
2534 | 562 |
// Invoke methods (JSR 292) |
563 |
static SymbolPropertyTable* _invoke_method_table; |
|
564 |
||
46729 | 565 |
// ProtectionDomain cache |
566 |
static ProtectionDomainCacheTable* _pd_cache_table; |
|
1 | 567 |
|
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
568 |
protected: |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
569 |
static void validate_protection_domain(InstanceKlass* klass, |
1 | 570 |
Handle class_loader, |
571 |
Handle protection_domain, TRAPS); |
|
572 |
||
573 |
friend class VM_PopulateDumpSharedSpace; |
|
574 |
friend class TraversePlaceholdersClosure; |
|
575 |
static PlaceholderTable* placeholders() { return _placeholders; } |
|
576 |
static LoaderConstraintTable* constraints() { return _loader_constraints; } |
|
577 |
static ResolutionErrorTable* resolution_errors() { return _resolution_errors; } |
|
2534 | 578 |
static SymbolPropertyTable* invoke_method_table() { return _invoke_method_table; } |
1 | 579 |
|
580 |
// Basic loading operations |
|
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
581 |
static InstanceKlass* resolve_instance_class_or_null_helper(Symbol* name, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
582 |
Handle class_loader, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
583 |
Handle protection_domain, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
584 |
TRAPS); |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
51180
diff
changeset
|
585 |
static InstanceKlass* resolve_instance_class_or_null(Symbol* class_name, Handle class_loader, Handle protection_domain, TRAPS); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
586 |
static Klass* resolve_array_class_or_null(Symbol* class_name, Handle class_loader, Handle protection_domain, TRAPS); |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
587 |
static InstanceKlass* handle_parallel_super_load(Symbol* class_name, Symbol* supername, Handle class_loader, Handle protection_domain, Handle lockObject, TRAPS); |
1 | 588 |
// Wait on SystemDictionary_lock; unlocks lockObject before |
589 |
// waiting; relocks lockObject with correct recursion count |
|
590 |
// after waiting, but before reentering SystemDictionary_lock |
|
591 |
// to preserve lock order semantics. |
|
592 |
static void double_lock_wait(Handle lockObject, TRAPS); |
|
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
593 |
static void define_instance_class(InstanceKlass* k, TRAPS); |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
594 |
static InstanceKlass* find_or_define_instance_class(Symbol* class_name, |
1 | 595 |
Handle class_loader, |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
596 |
InstanceKlass* k, TRAPS); |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
597 |
static bool is_shared_class_visible(Symbol* class_name, InstanceKlass* ik, |
36508 | 598 |
Handle class_loader, TRAPS); |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
599 |
static InstanceKlass* load_shared_class(InstanceKlass* ik, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
600 |
Handle class_loader, |
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
601 |
Handle protection_domain, |
53884
1a7b57d02107
8218751: Do not store original classfiles inside the CDS archive
iklam
parents:
53746
diff
changeset
|
602 |
const ClassFileStream *cfs, |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
603 |
TRAPS); |
52335
6507eeb6f047
8203953: Rename SystemDictionary::load_shared_class(Symbol*, Handle, TRAPS) to load_shared_boot_class().
jiangli
parents:
52319
diff
changeset
|
604 |
static InstanceKlass* load_shared_boot_class(Symbol* class_name, |
6507eeb6f047
8203953: Rename SystemDictionary::load_shared_class(Symbol*, Handle, TRAPS) to load_shared_boot_class().
jiangli
parents:
52319
diff
changeset
|
605 |
TRAPS); |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
606 |
static InstanceKlass* load_instance_class(Symbol* class_name, Handle class_loader, TRAPS); |
1 | 607 |
static Handle compute_loader_lock_object(Handle class_loader, TRAPS); |
608 |
static void check_loader_lock_contention(Handle loader_lock, TRAPS); |
|
1890 | 609 |
static bool is_parallelCapable(Handle class_loader); |
4445
1356c4b003de
6893504: LinkageError for bootstrap duplicate class definitions.
acorn
parents:
3820
diff
changeset
|
610 |
static bool is_parallelDefine(Handle class_loader); |
1 | 611 |
|
16617
6235d2c7549f
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
16352
diff
changeset
|
612 |
public: |
46271
979ebd346ecf
8169881: Remove implicit Handle conversions oop->Handle
coleenp
parents:
41690
diff
changeset
|
613 |
static bool is_system_class_loader(oop class_loader); |
979ebd346ecf
8169881: Remove implicit Handle conversions oop->Handle
coleenp
parents:
41690
diff
changeset
|
614 |
static bool is_platform_class_loader(oop class_loader); |
16617
6235d2c7549f
7198429: need checked categorization of caller-sensitive methods in the JDK
twisti
parents:
16352
diff
changeset
|
615 |
|
48463
474cec233fb2
8154587: Resolution fails for default method named 'clone'
hseigel
parents:
47774
diff
changeset
|
616 |
// Returns TRUE if the method is a non-public member of class java.lang.Object. |
474cec233fb2
8154587: Resolution fails for default method named 'clone'
hseigel
parents:
47774
diff
changeset
|
617 |
static bool is_nonpublic_Object_method(Method* m) { |
474cec233fb2
8154587: Resolution fails for default method named 'clone'
hseigel
parents:
47774
diff
changeset
|
618 |
assert(m != NULL, "Unexpected NULL Method*"); |
474cec233fb2
8154587: Resolution fails for default method named 'clone'
hseigel
parents:
47774
diff
changeset
|
619 |
return !m->is_public() && m->method_holder() == SystemDictionary::Object_klass(); |
474cec233fb2
8154587: Resolution fails for default method named 'clone'
hseigel
parents:
47774
diff
changeset
|
620 |
} |
474cec233fb2
8154587: Resolution fails for default method named 'clone'
hseigel
parents:
47774
diff
changeset
|
621 |
|
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
622 |
protected: |
1 | 623 |
// Setup link to hierarchy |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
624 |
static void add_to_hierarchy(InstanceKlass* k, TRAPS); |
1 | 625 |
|
626 |
// Basic find on loaded classes |
|
47774 | 627 |
static InstanceKlass* find_class(unsigned int hash, |
46729 | 628 |
Symbol* name, Dictionary* dictionary); |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
629 |
static InstanceKlass* find_class(Symbol* class_name, ClassLoaderData* loader_data); |
1 | 630 |
|
631 |
// Basic find on classes in the midst of being loaded |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
632 |
static Symbol* find_placeholder(Symbol* name, ClassLoaderData* loader_data); |
1 | 633 |
|
634 |
// Add a placeholder for a class being loaded |
|
635 |
static void add_placeholder(int index, |
|
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
636 |
Symbol* class_name, |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
637 |
ClassLoaderData* loader_data); |
1 | 638 |
static void remove_placeholder(int index, |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
639 |
Symbol* class_name, |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
640 |
ClassLoaderData* loader_data); |
1 | 641 |
|
642 |
// Performs cleanups after resolve_super_or_fail. This typically needs |
|
643 |
// to be called on failure. |
|
644 |
// Won't throw, but can block. |
|
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7900
diff
changeset
|
645 |
static void resolution_cleanups(Symbol* class_name, |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
646 |
ClassLoaderData* loader_data, |
1 | 647 |
TRAPS); |
648 |
||
52319
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
649 |
// Resolve well-known classes so they can be used like SystemDictionary::String_klass() |
625f6c742392
8212200: assert when shared java.lang.Object is redefined by JVMTI agent
iklam
parents:
52195
diff
changeset
|
650 |
static void resolve_well_known_classes(TRAPS); |
1 | 651 |
|
652 |
// Class loader constraints |
|
47774 | 653 |
static void check_constraints(unsigned int hash, |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
654 |
InstanceKlass* k, Handle loader, |
1 | 655 |
bool defining, TRAPS); |
47774 | 656 |
static void update_dictionary(unsigned int d_hash, |
1 | 657 |
int p_index, unsigned int p_hash, |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
46271
diff
changeset
|
658 |
InstanceKlass* k, Handle loader, |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13391
diff
changeset
|
659 |
TRAPS); |
1 | 660 |
|
33602 | 661 |
static InstanceKlass* _well_known_klasses[]; |
1 | 662 |
|
379
10767ca40189
6652736: well known classes in system dictionary are inefficiently processed
jrose
parents:
1
diff
changeset
|
663 |
// table of box klasses (int_klass, etc.) |
33602 | 664 |
static InstanceKlass* _box_klasses[T_VOID+1]; |
1 | 665 |
|
50152
b5023063346d
8189140: SystemDictionaryShared::initialize() should be renamed to be more meaningful
iklam
parents:
50063
diff
changeset
|
666 |
private: |
1 | 667 |
static oop _java_system_loader; |
47614
0ecfd6c951a6
8185694: Replace SystemDictionaryShared::_java_platform_loader with SystemDictionary::is_platform_class_loader()
ccheung
parents:
47216
diff
changeset
|
668 |
static oop _java_platform_loader; |
1 | 669 |
|
670 |
static bool _has_checkPackageAccess; |
|
54764 | 671 |
|
672 |
public: |
|
673 |
static TableStatistics placeholders_statistics(); |
|
674 |
static TableStatistics loader_constraints_statistics(); |
|
675 |
static TableStatistics protection_domain_cache_statistics(); |
|
1 | 676 |
}; |
2332
5c7b6f4ce0a1
6814659: separable cleanups and subroutines for 6655638
jrose
parents:
2105
diff
changeset
|
677 |
|
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52514
diff
changeset
|
678 |
#endif // SHARE_CLASSFILE_SYSTEMDICTIONARY_HPP |