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