author | jwilhelm |
Sun, 25 Feb 2018 04:59:43 +0100 | |
changeset 49067 | c153e9daadce |
parent 48884 | 7e17b00dc245 |
child 49364 | 601146c66cad |
permissions | -rw-r--r-- |
1 | 1 |
/* |
48884
7e17b00dc245
8196923: [REDO] NMT: Report array class count in NMT summary
zgu
parents:
48874
diff
changeset
|
2 |
* Copyright (c) 1997, 2018, 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:
4584
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
4584
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:
4584
diff
changeset
|
21 |
* questions. |
1 | 22 |
* |
23 |
*/ |
|
24 |
||
7397 | 25 |
#ifndef SHARE_VM_OOPS_INSTANCEKLASS_HPP |
26 |
#define SHARE_VM_OOPS_INSTANCEKLASS_HPP |
|
27 |
||
36508 | 28 |
#include "classfile/classLoader.hpp" |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
29 |
#include "classfile/classLoaderData.hpp" |
38094
46977cd73d86
8152844: JVM InstanceKlass Methods For Obtaining Package/Module Should Be Moved to Klass
rprotacio
parents:
38059
diff
changeset
|
30 |
#include "classfile/moduleEntry.hpp" |
36508 | 31 |
#include "classfile/packageEntry.hpp" |
30764 | 32 |
#include "gc/shared/specialized_oop_closures.hpp" |
18025 | 33 |
#include "memory/referenceType.hpp" |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
34 |
#include "oops/annotations.hpp" |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
35 |
#include "oops/constMethod.hpp" |
10546 | 36 |
#include "oops/fieldInfo.hpp" |
7397 | 37 |
#include "oops/instanceOop.hpp" |
38 |
#include "oops/klassVtable.hpp" |
|
39 |
#include "runtime/handles.hpp" |
|
40 |
#include "runtime/os.hpp" |
|
30764 | 41 |
#include "trace/traceMacros.hpp" |
7397 | 42 |
#include "utilities/accessFlags.hpp" |
46625 | 43 |
#include "utilities/align.hpp" |
15482
470d0b0c09f1
8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents:
15202
diff
changeset
|
44 |
#include "utilities/macros.hpp" |
7397 | 45 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
46 |
// An InstanceKlass is the VM level representation of a Java class. |
1 | 47 |
// It contains all information needed for at class at execution runtime. |
48 |
||
23515
f4872ef5df09
8031820: NPG: Fix remaining references to metadata as oops in comments
coleenp
parents:
22916
diff
changeset
|
49 |
// InstanceKlass embedded field layout (after declared fields): |
1 | 50 |
// [EMBEDDED Java vtable ] size in words = vtable_len |
51 |
// [EMBEDDED nonstatic oop-map blocks] size in words = nonstatic_oop_map_size |
|
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
52 |
// The embedded nonstatic oop-map blocks are short pairs (offset, length) |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
53 |
// indicating where oops are located in instances of this klass. |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
54 |
// [EMBEDDED implementor of the interface] only exist for interface |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
55 |
// [EMBEDDED host klass ] only exist for an anonymous class (JSR 292 enabled) |
42650 | 56 |
// [EMBEDDED fingerprint ] only if should_store_fingerprint()==true |
1 | 57 |
|
58 |
||
59 |
// forward declaration for class -- see below for definition |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
60 |
#if INCLUDE_JVMTI |
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
61 |
class BreakpointInfo; |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
62 |
#endif |
34666 | 63 |
class ClassFileParser; |
36300
5b47f168b948
7177745: JSR292: Many Callsite relinkages cause target method to always run in interpreter mode
vlivanov
parents:
35917
diff
changeset
|
64 |
class KlassDepChange; |
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
65 |
class DependencyContext; |
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
66 |
class fieldDescriptor; |
1 | 67 |
class jniIdMapBase; |
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
68 |
class JNIid; |
1 | 69 |
class JvmtiCachedClassFieldMap; |
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
70 |
class SuperTypeClosure; |
1 | 71 |
|
72 |
// This is used in iterators below. |
|
73 |
class FieldClosure: public StackObj { |
|
74 |
public: |
|
75 |
virtual void do_field(fieldDescriptor* fd) = 0; |
|
76 |
}; |
|
77 |
||
78 |
#ifndef PRODUCT |
|
79 |
// Print fields. |
|
80 |
// If "obj" argument to constructor is NULL, prints static fields, otherwise prints non-static fields. |
|
81 |
class FieldPrinter: public FieldClosure { |
|
82 |
oop _obj; |
|
83 |
outputStream* _st; |
|
84 |
public: |
|
85 |
FieldPrinter(outputStream* st, oop obj = NULL) : _obj(obj), _st(st) {} |
|
86 |
void do_field(fieldDescriptor* fd); |
|
87 |
}; |
|
88 |
#endif // !PRODUCT |
|
89 |
||
3693 | 90 |
// ValueObjs embedded in klass. Describes where oops are located in instances of |
91 |
// this klass. |
|
92 |
class OopMapBlock VALUE_OBJ_CLASS_SPEC { |
|
93 |
public: |
|
94 |
// Byte offset of the first oop mapped by this block. |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
95 |
int offset() const { return _offset; } |
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
96 |
void set_offset(int offset) { _offset = offset; } |
3693 | 97 |
|
98 |
// Number of oops in this block. |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
99 |
uint count() const { return _count; } |
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
100 |
void set_count(uint count) { _count = count; } |
3693 | 101 |
|
35898
ddc274f0052f
8145628: hotspot metadata classes shouldn't use HeapWordSize or heap related macros like align_object_size
coleenp
parents:
35877
diff
changeset
|
102 |
// sizeof(OopMapBlock) in words. |
3693 | 103 |
static const int size_in_words() { |
46619
a3919f5e8d2b
8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents:
46618
diff
changeset
|
104 |
return align_up((int)sizeof(OopMapBlock), wordSize) >> |
35898
ddc274f0052f
8145628: hotspot metadata classes shouldn't use HeapWordSize or heap related macros like align_object_size
coleenp
parents:
35877
diff
changeset
|
105 |
LogBytesPerWord; |
3693 | 106 |
} |
107 |
||
108 |
private: |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
109 |
int _offset; |
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
110 |
uint _count; |
3693 | 111 |
}; |
112 |
||
18940
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
113 |
struct JvmtiCachedClassFileData; |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
114 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
115 |
class InstanceKlass: public Klass { |
1 | 116 |
friend class VMStructs; |
35123
b0b89d83bcf5
8134994: use separate VMStructs databases for SA and JVMCI
twisti
parents:
34195
diff
changeset
|
117 |
friend class JVMCIVMStructs; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
118 |
friend class ClassFileParser; |
14477
95e66ea71f71
6830717: replay of compilations would help with debugging
minqi
parents:
14385
diff
changeset
|
119 |
friend class CompileReplay; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
120 |
|
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
121 |
protected: |
34666 | 122 |
InstanceKlass(const ClassFileParser& parser, unsigned kind); |
123 |
||
1 | 124 |
public: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
125 |
InstanceKlass() { assert(DumpSharedSpaces || UseSharedSpaces, "only for CDS"); } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
126 |
|
1 | 127 |
// See "The Java Virtual Machine Specification" section 2.16.2-5 for a detailed description |
128 |
// of the class loading & initialization procedure, and the use of the states. |
|
129 |
enum ClassState { |
|
130 |
allocated, // allocated (but not yet linked) |
|
131 |
loaded, // loaded and inserted in class hierarchy (but not linked yet) |
|
132 |
linked, // successfully linked/verified (but not initialized yet) |
|
133 |
being_initialized, // currently running class initializer |
|
134 |
fully_initialized, // initialized (successfull final state) |
|
135 |
initialization_error // error happened during initialization |
|
136 |
}; |
|
137 |
||
15104
f5d78994619f
8005048: NMT: #loaded classes needs to just show the # defined classes
zgu
parents:
14477
diff
changeset
|
138 |
private: |
34666 | 139 |
static InstanceKlass* allocate_instance_klass(const ClassFileParser& parser, TRAPS); |
15104
f5d78994619f
8005048: NMT: #loaded classes needs to just show the # defined classes
zgu
parents:
14477
diff
changeset
|
140 |
|
1 | 141 |
protected: |
46746
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
142 |
// If you add a new field that points to any metaspace object, you |
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
143 |
// must add this field to InstanceKlass::metaspace_pointers_do(). |
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
144 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
145 |
// Annotations for this class |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
146 |
Annotations* _annotations; |
36508 | 147 |
// Package this class is defined in |
148 |
PackageEntry* _package_entry; |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
149 |
// Array classes holding elements of this class. |
40887
8d35e19f5548
8158854: Ensure release_store is paired with load_acquire in lock-free code
dholmes
parents:
40102
diff
changeset
|
150 |
Klass* volatile _array_klasses; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
151 |
// Constant pool for this class. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
152 |
ConstantPool* _constants; |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
153 |
// The InnerClasses attribute and EnclosingMethod attribute. The |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
154 |
// _inner_classes is an array of shorts. If the class has InnerClasses |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
155 |
// attribute, then the _inner_classes array begins with 4-tuples of shorts |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
156 |
// [inner_class_info_index, outer_class_info_index, |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
157 |
// inner_name_index, inner_class_access_flags] for the InnerClasses |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
158 |
// attribute. If the EnclosingMethod attribute exists, it occupies the |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
159 |
// last two shorts [class_index, method_index] of the array. If only |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
160 |
// the InnerClasses attribute exists, the _inner_classes array length is |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
161 |
// number_of_inner_classes * 4. If the class has both InnerClasses |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
162 |
// and EnclosingMethod attributes the _inner_classes array length is |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
163 |
// number_of_inner_classes * 4 + enclosing_method_attribute_size. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
164 |
Array<jushort>* _inner_classes; |
1 | 165 |
|
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
166 |
// the source debug extension for this klass, NULL if not specified. |
13201
69f157caabcc
6294277: java -Xdebug crashes on SourceDebugExtension attribute larger than 64K
fparain
parents:
13195
diff
changeset
|
167 |
// Specified as UTF-8 string without terminating zero byte in the classfile, |
69f157caabcc
6294277: java -Xdebug crashes on SourceDebugExtension attribute larger than 64K
fparain
parents:
13195
diff
changeset
|
168 |
// it is stored in the instanceklass as a NULL-terminated UTF-8 string |
34666 | 169 |
const char* _source_debug_extension; |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
170 |
// Array name derived from this class which needs unreferencing |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
171 |
// if this class is unloaded. |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
172 |
Symbol* _array_name; |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
173 |
|
591
04d2e26e6d69
6703888: Compressed Oops: use the 32-bits gap after klass in a object
kvn
parents:
360
diff
changeset
|
174 |
// Number of heapOopSize words used by non-static fields in this klass |
04d2e26e6d69
6703888: Compressed Oops: use the 32-bits gap after klass in a object
kvn
parents:
360
diff
changeset
|
175 |
// (including inherited fields but after header_size()). |
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
176 |
int _nonstatic_field_size; |
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
177 |
int _static_field_size; // number words used by static fields (oop and non-oop) in this klass |
19326
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
178 |
// Constant pool index to the utf8 entry of the Generic signature, |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
179 |
// or 0 if none. |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
180 |
u2 _generic_signature_index; |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
181 |
// Constant pool index to the utf8 entry for the name of source file |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
182 |
// containing this klass, 0 if not specified. |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
183 |
u2 _source_file_name_index; |
11412
62fe312f32c5
7123315: instanceKlass::_static_oop_field_count and instanceKlass::_java_fields_count should be u2 type.
jiangli
parents:
11407
diff
changeset
|
184 |
u2 _static_oop_field_count;// number of static oop fields in this klass |
62fe312f32c5
7123315: instanceKlass::_static_oop_field_count and instanceKlass::_java_fields_count should be u2 type.
jiangli
parents:
11407
diff
changeset
|
185 |
u2 _java_fields_count; // The number of declared Java fields |
3693 | 186 |
int _nonstatic_oop_map_size;// size in words of nonstatic oop map blocks |
11405
ca38a49ef8c9
7102776: Pack instanceKlass boolean fields into single u1 field
coleenp
parents:
10547
diff
changeset
|
187 |
|
35899 | 188 |
int _itable_len; // length of Java itable (in words) |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
189 |
// _is_marked_dependent can be set concurrently, thus cannot be part of the |
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
190 |
// _misc_flags. |
11440
dea12ec80745
7129240: backout fix for 7102776 until 7128770 is resolved
dcubed
parents:
11439
diff
changeset
|
191 |
bool _is_marked_dependent; // used for marking during flushing and deoptimization |
38309
9b8e9c373740
8155951: VM crash in nsk/jvmti/RedefineClasses/StressRedefine: assert failed: Corrupted constant pool
coleenp
parents:
38192
diff
changeset
|
192 |
bool _is_being_redefined; // used for locking redefinition |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
193 |
|
33151
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
194 |
// The low two bits of _misc_flags contains the kind field. |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
195 |
// This can be used to quickly discriminate among the four kinds of |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
196 |
// InstanceKlass. |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
197 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
198 |
static const unsigned _misc_kind_field_size = 2; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
199 |
static const unsigned _misc_kind_field_pos = 0; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
200 |
static const unsigned _misc_kind_field_mask = (1u << _misc_kind_field_size) - 1u; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
201 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
202 |
static const unsigned _misc_kind_other = 0; // concrete InstanceKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
203 |
static const unsigned _misc_kind_reference = 1; // InstanceRefKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
204 |
static const unsigned _misc_kind_class_loader = 2; // InstanceClassLoaderKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
205 |
static const unsigned _misc_kind_mirror = 3; // InstanceMirrorKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
206 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
207 |
// Start after _misc_kind field. |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
208 |
enum { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
209 |
_misc_rewritten = 1 << 2, // methods rewritten. |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
210 |
_misc_has_nonstatic_fields = 1 << 3, // for sizing with UseCompressedOops |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
211 |
_misc_should_verify_class = 1 << 4, // allow caching of preverification |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
212 |
_misc_is_anonymous = 1 << 5, // has embedded _host_klass field |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
213 |
_misc_is_contended = 1 << 6, // marked with contended annotation |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
214 |
_misc_has_nonstatic_concrete_methods = 1 << 7, // class/superclass/implemented interfaces has non-static, concrete methods |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
215 |
_misc_declares_nonstatic_concrete_methods = 1 << 8, // directly declares non-static, concrete methods |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
216 |
_misc_has_been_redefined = 1 << 9, // class has been redefined |
42650 | 217 |
_misc_has_passed_fingerprint_check = 1 << 10, // when this class was loaded, the fingerprint computed from its |
218 |
// code source was found to be matching the value recorded by AOT. |
|
219 |
_misc_is_scratch_class = 1 << 11, // class is the redefined scratch class |
|
220 |
_misc_is_shared_boot_class = 1 << 12, // defining class loader is boot class loader |
|
221 |
_misc_is_shared_platform_class = 1 << 13, // defining class loader is platform class loader |
|
46505
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
222 |
_misc_is_shared_app_class = 1 << 14, // defining class loader is app class loader |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
223 |
_misc_has_resolved_methods = 1 << 15 // resolved methods table entries added for this class |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
224 |
}; |
36508 | 225 |
u2 loader_type_bits() { |
226 |
return _misc_is_shared_boot_class|_misc_is_shared_platform_class|_misc_is_shared_app_class; |
|
227 |
} |
|
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
228 |
u2 _misc_flags; |
1 | 229 |
u2 _minor_version; // minor version number of class file |
230 |
u2 _major_version; // major version number of class file |
|
231 |
Thread* _init_thread; // Pointer to current thread doing initialization (to handle recusive initialization) |
|
232 |
OopMapCache* volatile _oop_map_cache; // OopMapCache for all methods in the klass (allocated lazily) |
|
233 |
JNIid* _jni_ids; // First JNI identifier for static fields in this class |
|
40887
8d35e19f5548
8158854: Ensure release_store is paired with load_acquire in lock-free code
dholmes
parents:
40102
diff
changeset
|
234 |
jmethodID* volatile _methods_jmethod_ids; // jmethodIDs corresponding to method_idnum, or NULL if none |
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
235 |
intptr_t _dep_context; // packed DependencyContext structure |
1 | 236 |
nmethod* _osr_nmethods_head; // Head of list of on-stack replacement nmethods for this class |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
237 |
#if INCLUDE_JVMTI |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
238 |
BreakpointInfo* _breakpoints; // bpt lists, managed by Method* |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
239 |
// Linked instanceKlasses of previous versions |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
240 |
InstanceKlass* _previous_versions; |
1 | 241 |
// JVMTI fields can be moved to their own structure - see 6315920 |
18940
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
242 |
// JVMTI: cached class file, before retransformable agent modified it in CFLH |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
243 |
JvmtiCachedClassFileData* _cached_class_file; |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
244 |
#endif |
15449
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
245 |
|
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
246 |
volatile u2 _idnum_allocated_count; // JNI/JVMTI: increments with the addition of methods, old ids don't change |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
247 |
|
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
248 |
// Class states are defined as ClassState (see above). |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
249 |
// Place the _init_state here to utilize the unused 2-byte after |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
250 |
// _idnum_allocated_count. |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
251 |
u1 _init_state; // state of class |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
252 |
u1 _reference_type; // reference type |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
253 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
254 |
#if INCLUDE_JVMTI |
1 | 255 |
JvmtiCachedClassFieldMap* _jvmti_cached_class_field_map; // JVMTI: used during heap iteration |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
256 |
#endif |
14385 | 257 |
|
15928
f9d5c6e4107f
8003553: NPG: metaspace objects should be zeroed in constructors
coleenp
parents:
15601
diff
changeset
|
258 |
NOT_PRODUCT(int _verify_count;) // to avoid redundant verifies |
f9d5c6e4107f
8003553: NPG: metaspace objects should be zeroed in constructors
coleenp
parents:
15601
diff
changeset
|
259 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
260 |
// Method array. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
261 |
Array<Method*>* _methods; |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
262 |
// Default Method Array, concrete methods inherited from interfaces |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
263 |
Array<Method*>* _default_methods; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
264 |
// Interface (Klass*s) this class declares locally to implement. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
265 |
Array<Klass*>* _local_interfaces; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
266 |
// Interface (Klass*s) this class implements transitively. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
267 |
Array<Klass*>* _transitive_interfaces; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
268 |
// Int array containing the original order of method in the class file (for JVMTI). |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
269 |
Array<int>* _method_ordering; |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
270 |
// Int array containing the vtable_indices for default_methods |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
271 |
// offset matches _default_methods offset |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
272 |
Array<int>* _default_vtable_indices; |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
273 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
274 |
// Instance and static variable information, starts with 6-tuples of shorts |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
275 |
// [access, name index, sig index, initval index, low_offset, high_offset] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
276 |
// for all fields, followed by the generic signature data at the end of |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
277 |
// the array. Only fields with generic signature attributes have the generic |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
278 |
// signature data set in the array. The fields array looks like following: |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
279 |
// |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
280 |
// f1: [access, name index, sig index, initial value index, low_offset, high_offset] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
281 |
// f2: [access, name index, sig index, initial value index, low_offset, high_offset] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
282 |
// ... |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
283 |
// fn: [access, name index, sig index, initial value index, low_offset, high_offset] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
284 |
// [generic signature index] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
285 |
// [generic signature index] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
286 |
// ... |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
287 |
Array<u2>* _fields; |
1 | 288 |
|
289 |
// embedded Java vtable follows here |
|
290 |
// embedded Java itables follows here |
|
291 |
// embedded static fields follows here |
|
292 |
// embedded nonstatic oop-map blocks follows here |
|
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
293 |
// embedded implementor of this interface follows here |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
294 |
// The embedded implementor only exists if the current klass is an |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
295 |
// iterface. The possible values of the implementor fall into following |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
296 |
// three cases: |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
297 |
// NULL: no implementor. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
298 |
// A Klass* that's not itself: one implementor. |
22916
582da2ed4dfa
8031752: Failed speculative optimizations should be reattempted when root of compilation is different
roland
parents:
22794
diff
changeset
|
299 |
// Itself: more than one implementors. |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
300 |
// embedded host klass follows here |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
301 |
// The embedded host klass only exists in an anonymous class for |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
302 |
// dynamic language support (JSR 292 enabled). The host class grants |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
303 |
// its access privileges to this class also. The host class is either |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
304 |
// named, or a previously loaded anonymous class. A non-anonymous class |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
305 |
// or an anonymous class loaded through normal classloading does not |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
306 |
// have this embedded field. |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
307 |
// |
1 | 308 |
|
309 |
friend class SystemDictionary; |
|
310 |
||
311 |
public: |
|
36508 | 312 |
u2 loader_type() { |
313 |
return _misc_flags & loader_type_bits(); |
|
314 |
} |
|
315 |
||
316 |
bool is_shared_boot_class() const { |
|
317 |
return (_misc_flags & _misc_is_shared_boot_class) != 0; |
|
318 |
} |
|
319 |
bool is_shared_platform_class() const { |
|
320 |
return (_misc_flags & _misc_is_shared_platform_class) != 0; |
|
321 |
} |
|
322 |
bool is_shared_app_class() const { |
|
323 |
return (_misc_flags & _misc_is_shared_app_class) != 0; |
|
324 |
} |
|
325 |
||
38192
05ab1ee04bf2
8155678: ClassLoader::initialize_module_loader_map should only be called when dumping CDS archive.
jiangli
parents:
38094
diff
changeset
|
326 |
void set_class_loader_type(s2 loader_type) { |
36508 | 327 |
switch (loader_type) { |
328 |
case ClassLoader::BOOT_LOADER: |
|
329 |
_misc_flags |= _misc_is_shared_boot_class; |
|
330 |
break; |
|
331 |
case ClassLoader::PLATFORM_LOADER: |
|
332 |
_misc_flags |= _misc_is_shared_platform_class; |
|
333 |
break; |
|
334 |
case ClassLoader::APP_LOADER: |
|
335 |
_misc_flags |= _misc_is_shared_app_class; |
|
336 |
break; |
|
337 |
default: |
|
338 |
ShouldNotReachHere(); |
|
339 |
break; |
|
340 |
} |
|
341 |
} |
|
342 |
||
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
343 |
bool has_nonstatic_fields() const { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
344 |
return (_misc_flags & _misc_has_nonstatic_fields) != 0; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
345 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
346 |
void set_has_nonstatic_fields(bool b) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
347 |
if (b) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
348 |
_misc_flags |= _misc_has_nonstatic_fields; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
349 |
} else { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
350 |
_misc_flags &= ~_misc_has_nonstatic_fields; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
351 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
352 |
} |
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
353 |
|
1 | 354 |
// field sizes |
355 |
int nonstatic_field_size() const { return _nonstatic_field_size; } |
|
356 |
void set_nonstatic_field_size(int size) { _nonstatic_field_size = size; } |
|
357 |
||
358 |
int static_field_size() const { return _static_field_size; } |
|
359 |
void set_static_field_size(int size) { _static_field_size = size; } |
|
360 |
||
11412
62fe312f32c5
7123315: instanceKlass::_static_oop_field_count and instanceKlass::_java_fields_count should be u2 type.
jiangli
parents:
11407
diff
changeset
|
361 |
int static_oop_field_count() const { return (int)_static_oop_field_count; } |
62fe312f32c5
7123315: instanceKlass::_static_oop_field_count and instanceKlass::_java_fields_count should be u2 type.
jiangli
parents:
11407
diff
changeset
|
362 |
void set_static_oop_field_count(u2 size) { _static_oop_field_count = size; } |
1 | 363 |
|
364 |
// Java itable |
|
365 |
int itable_length() const { return _itable_len; } |
|
366 |
void set_itable_length(int len) { _itable_len = len; } |
|
367 |
||
368 |
// array klasses |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
369 |
Klass* array_klasses() const { return _array_klasses; } |
40887
8d35e19f5548
8158854: Ensure release_store is paired with load_acquire in lock-free code
dholmes
parents:
40102
diff
changeset
|
370 |
inline Klass* array_klasses_acquire() const; // load with acquire semantics |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
371 |
void set_array_klasses(Klass* k) { _array_klasses = k; } |
40887
8d35e19f5548
8158854: Ensure release_store is paired with load_acquire in lock-free code
dholmes
parents:
40102
diff
changeset
|
372 |
inline void release_set_array_klasses(Klass* k); // store with release semantics |
1 | 373 |
|
374 |
// methods |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
375 |
Array<Method*>* methods() const { return _methods; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
376 |
void set_methods(Array<Method*>* a) { _methods = a; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
377 |
Method* method_with_idnum(int idnum); |
30107
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
378 |
Method* method_with_orig_idnum(int idnum); |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
379 |
Method* method_with_orig_idnum(int idnum, int version); |
1 | 380 |
|
381 |
// method ordering |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
382 |
Array<int>* method_ordering() const { return _method_ordering; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
383 |
void set_method_ordering(Array<int>* m) { _method_ordering = m; } |
34666 | 384 |
void copy_method_ordering(const intArray* m, TRAPS); |
1 | 385 |
|
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
386 |
// default_methods |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
387 |
Array<Method*>* default_methods() const { return _default_methods; } |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
388 |
void set_default_methods(Array<Method*>* a) { _default_methods = a; } |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
389 |
|
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
390 |
// default method vtable_indices |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
391 |
Array<int>* default_vtable_indices() const { return _default_vtable_indices; } |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
392 |
void set_default_vtable_indices(Array<int>* v) { _default_vtable_indices = v; } |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
393 |
Array<int>* create_new_default_vtable_indices(int len, TRAPS); |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
394 |
|
1 | 395 |
// interfaces |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
396 |
Array<Klass*>* local_interfaces() const { return _local_interfaces; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
397 |
void set_local_interfaces(Array<Klass*>* a) { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
398 |
guarantee(_local_interfaces == NULL || a == NULL, "Just checking"); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
399 |
_local_interfaces = a; } |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
400 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
401 |
Array<Klass*>* transitive_interfaces() const { return _transitive_interfaces; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
402 |
void set_transitive_interfaces(Array<Klass*>* a) { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
403 |
guarantee(_transitive_interfaces == NULL || a == NULL, "Just checking"); |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
404 |
_transitive_interfaces = a; |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
405 |
} |
1 | 406 |
|
10546 | 407 |
private: |
408 |
friend class fieldDescriptor; |
|
409 |
FieldInfo* field(int index) const { return FieldInfo::from_field_array(_fields, index); } |
|
410 |
||
411 |
public: |
|
412 |
int field_offset (int index) const { return field(index)->offset(); } |
|
413 |
int field_access_flags(int index) const { return field(index)->access_flags(); } |
|
414 |
Symbol* field_name (int index) const { return field(index)->name(constants()); } |
|
415 |
Symbol* field_signature (int index) const { return field(index)->signature(constants()); } |
|
416 |
||
417 |
// Number of Java declared fields |
|
11412
62fe312f32c5
7123315: instanceKlass::_static_oop_field_count and instanceKlass::_java_fields_count should be u2 type.
jiangli
parents:
11407
diff
changeset
|
418 |
int java_fields_count() const { return (int)_java_fields_count; } |
10546 | 419 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
420 |
Array<u2>* fields() const { return _fields; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
421 |
void set_fields(Array<u2>* f, u2 java_fields_count) { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
422 |
guarantee(_fields == NULL || f == NULL, "Just checking"); |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
423 |
_fields = f; |
10546 | 424 |
_java_fields_count = java_fields_count; |
1 | 425 |
} |
426 |
||
427 |
// inner classes |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
428 |
Array<u2>* inner_classes() const { return _inner_classes; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
429 |
void set_inner_classes(Array<u2>* f) { _inner_classes = f; } |
1 | 430 |
|
431 |
enum InnerClassAttributeOffset { |
|
432 |
// From http://mirror.eng/products/jdk/1.1/docs/guide/innerclasses/spec/innerclasses.doc10.html#18814 |
|
433 |
inner_class_inner_class_info_offset = 0, |
|
434 |
inner_class_outer_class_info_offset = 1, |
|
435 |
inner_class_inner_name_offset = 2, |
|
436 |
inner_class_access_flags_offset = 3, |
|
437 |
inner_class_next_offset = 4 |
|
438 |
}; |
|
439 |
||
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
440 |
enum EnclosingMethodAttributeOffset { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
441 |
enclosing_method_class_index_offset = 0, |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
442 |
enclosing_method_method_index_offset = 1, |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
443 |
enclosing_method_attribute_size = 2 |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
444 |
}; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
445 |
|
2264
55d0115a54fe
4766230: Hotspot vtable inconsistencies cause core dumps. 6579515. 6582242.
acorn
parents:
1550
diff
changeset
|
446 |
// method override check |
33593
60764a78fa5c
8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents:
33576
diff
changeset
|
447 |
bool is_override(const methodHandle& super_method, Handle targetclassloader, Symbol* targetclassname, TRAPS); |
2264
55d0115a54fe
4766230: Hotspot vtable inconsistencies cause core dumps. 6579515. 6582242.
acorn
parents:
1550
diff
changeset
|
448 |
|
1 | 449 |
// package |
36508 | 450 |
PackageEntry* package() const { return _package_entry; } |
451 |
ModuleEntry* module() const; |
|
452 |
bool in_unnamed_package() const { return (_package_entry == NULL); } |
|
453 |
void set_package(PackageEntry* p) { _package_entry = p; } |
|
454 |
void set_package(ClassLoaderData* loader_data, TRAPS); |
|
34666 | 455 |
bool is_same_class_package(const Klass* class2) const; |
46697
2fdbdc5e0765
8077203: Avoid unnecessary stripping of package names from FQN's in is_same_class_package() methods
hseigel
parents:
46625
diff
changeset
|
456 |
bool is_same_class_package(oop other_class_loader, const Symbol* other_class_name) const; |
1 | 457 |
|
30222
bfe6be3c4ef8
8057919: Class.getSimpleName() should work for non-JLS compliant class names
vlivanov
parents:
29698
diff
changeset
|
458 |
// find an enclosing class |
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
459 |
InstanceKlass* compute_enclosing_class(bool* inner_is_member, TRAPS) const; |
30222
bfe6be3c4ef8
8057919: Class.getSimpleName() should work for non-JLS compliant class names
vlivanov
parents:
29698
diff
changeset
|
460 |
|
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
461 |
// Find InnerClasses attribute and return outer_class_info_index & inner_name_index. |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
462 |
bool find_inner_classes_attr(int* ooff, int* noff, TRAPS) const; |
2332
5c7b6f4ce0a1
6814659: separable cleanups and subroutines for 6655638
jrose
parents:
1550
diff
changeset
|
463 |
|
40016 | 464 |
private: |
465 |
// Check prohibited package ("java/" only loadable by boot or platform loaders) |
|
466 |
static void check_prohibited_package(Symbol* class_name, |
|
467 |
Handle class_loader, |
|
468 |
TRAPS); |
|
469 |
public: |
|
2332
5c7b6f4ce0a1
6814659: separable cleanups and subroutines for 6655638
jrose
parents:
1550
diff
changeset
|
470 |
// tell if two classes have the same enclosing class (at package level) |
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
471 |
bool is_same_package_member(const Klass* class2, TRAPS) const; |
2332
5c7b6f4ce0a1
6814659: separable cleanups and subroutines for 6655638
jrose
parents:
1550
diff
changeset
|
472 |
|
1 | 473 |
// initialization state |
474 |
bool is_loaded() const { return _init_state >= loaded; } |
|
475 |
bool is_linked() const { return _init_state >= linked; } |
|
476 |
bool is_initialized() const { return _init_state == fully_initialized; } |
|
477 |
bool is_not_initialized() const { return _init_state < being_initialized; } |
|
478 |
bool is_being_initialized() const { return _init_state == being_initialized; } |
|
479 |
bool is_in_error_state() const { return _init_state == initialization_error; } |
|
480 |
bool is_reentrant_initialization(Thread *thread) { return thread == _init_thread; } |
|
11407
5399831730cd
7117052: instanceKlass::_init_state can be u1 type
coleenp
parents:
11405
diff
changeset
|
481 |
ClassState init_state() { return (ClassState)_init_state; } |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
482 |
bool is_rewritten() const { return (_misc_flags & _misc_rewritten) != 0; } |
3820
0a8fbbe180db
6830542: Performance: JVM_DefineClass already verified.
acorn
parents:
2570
diff
changeset
|
483 |
|
0a8fbbe180db
6830542: Performance: JVM_DefineClass already verified.
acorn
parents:
2570
diff
changeset
|
484 |
// defineClass specified verification |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
485 |
bool should_verify_class() const { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
486 |
return (_misc_flags & _misc_should_verify_class) != 0; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
487 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
488 |
void set_should_verify_class(bool value) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
489 |
if (value) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
490 |
_misc_flags |= _misc_should_verify_class; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
491 |
} else { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
492 |
_misc_flags &= ~_misc_should_verify_class; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
493 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
494 |
} |
1 | 495 |
|
496 |
// marking |
|
11440
dea12ec80745
7129240: backout fix for 7102776 until 7128770 is resolved
dcubed
parents:
11439
diff
changeset
|
497 |
bool is_marked_dependent() const { return _is_marked_dependent; } |
dea12ec80745
7129240: backout fix for 7102776 until 7128770 is resolved
dcubed
parents:
11439
diff
changeset
|
498 |
void set_is_marked_dependent(bool value) { _is_marked_dependent = value; } |
1 | 499 |
|
500 |
// initialization (virtuals from Klass) |
|
501 |
bool should_be_initialized() const; // means that initialize should be called |
|
502 |
void initialize(TRAPS); |
|
503 |
void link_class(TRAPS); |
|
504 |
bool link_class_or_fail(TRAPS); // returns false on failure |
|
505 |
void unlink_class(); |
|
506 |
void rewrite_class(TRAPS); |
|
15099
b31d40895bbb
8005494: SIGSEGV in Rewriter::relocate_and_link() when testing Weblogic with CompressedOops and KlassPtrs
coleenp
parents:
15097
diff
changeset
|
507 |
void link_methods(TRAPS); |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43929
diff
changeset
|
508 |
Method* class_initializer() const; |
1 | 509 |
|
510 |
// set the class to initialized if no static initializer is present |
|
511 |
void eager_initialize(Thread *thread); |
|
512 |
||
513 |
// reference type |
|
11729
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
514 |
ReferenceType reference_type() const { return (ReferenceType)_reference_type; } |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
515 |
void set_reference_type(ReferenceType t) { |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
516 |
assert(t == (u1)t, "overflow"); |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
517 |
_reference_type = (u1)t; |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
518 |
} |
1 | 519 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
520 |
static ByteSize reference_type_offset() { return in_ByteSize(offset_of(InstanceKlass, _reference_type)); } |
9176
42d9d1010f38
7009266: G1: assert(obj->is_oop_or_null(true )) failed: Error
johnc
parents:
8725
diff
changeset
|
521 |
|
1 | 522 |
// find local field, returns true if found |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
523 |
bool find_local_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const; |
1 | 524 |
// find field in direct superinterfaces, returns the interface in which the field is defined |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
525 |
Klass* find_interface_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const; |
1 | 526 |
// find field according to JVM spec 5.4.3.2, returns the klass in which the field is defined |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
527 |
Klass* find_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const; |
1 | 528 |
// find instance or static fields according to JVM spec 5.4.3.2, returns the klass in which the field is defined |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
529 |
Klass* find_field(Symbol* name, Symbol* sig, bool is_static, fieldDescriptor* fd) const; |
1 | 530 |
|
531 |
// find a non-static or static field given its offset within the class. |
|
532 |
bool contains_field_offset(int offset) { |
|
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
533 |
return instanceOopDesc::contains_field_offset(offset, nonstatic_field_size()); |
1 | 534 |
} |
535 |
||
536 |
bool find_local_field_from_offset(int offset, bool is_static, fieldDescriptor* fd) const; |
|
537 |
bool find_field_from_offset(int offset, bool is_static, fieldDescriptor* fd) const; |
|
538 |
||
539 |
// find a local method (returns NULL if not found) |
|
34666 | 540 |
Method* find_method(const Symbol* name, const Symbol* signature) const; |
541 |
static Method* find_method(const Array<Method*>* methods, |
|
542 |
const Symbol* name, |
|
543 |
const Symbol* signature); |
|
28514 | 544 |
|
545 |
// find a local method, but skip static methods |
|
34666 | 546 |
Method* find_instance_method(const Symbol* name, const Symbol* signature) const; |
547 |
static Method* find_instance_method(const Array<Method*>* methods, |
|
548 |
const Symbol* name, |
|
549 |
const Symbol* signature); |
|
1 | 550 |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
551 |
// find a local method (returns NULL if not found) |
34666 | 552 |
Method* find_local_method(const Symbol* name, |
553 |
const Symbol* signature, |
|
554 |
OverpassLookupMode overpass_mode, |
|
555 |
StaticLookupMode static_mode, |
|
556 |
PrivateLookupMode private_mode) const; |
|
28514 | 557 |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
558 |
// find a local method from given methods array (returns NULL if not found) |
34666 | 559 |
static Method* find_local_method(const Array<Method*>* methods, |
560 |
const Symbol* name, |
|
561 |
const Symbol* signature, |
|
562 |
OverpassLookupMode overpass_mode, |
|
563 |
StaticLookupMode static_mode, |
|
564 |
PrivateLookupMode private_mode); |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
565 |
|
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
566 |
// find a local method index in methods or default_methods (returns -1 if not found) |
34666 | 567 |
static int find_method_index(const Array<Method*>* methods, |
568 |
const Symbol* name, |
|
569 |
const Symbol* signature, |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
570 |
OverpassLookupMode overpass_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
571 |
StaticLookupMode static_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
572 |
PrivateLookupMode private_mode); |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
573 |
|
1 | 574 |
// lookup operation (returns NULL if not found) |
34666 | 575 |
Method* uncached_lookup_method(const Symbol* name, |
576 |
const Symbol* signature, |
|
577 |
OverpassLookupMode overpass_mode) const; |
|
1 | 578 |
|
579 |
// lookup a method in all the interfaces that this class implements |
|
580 |
// (returns NULL if not found) |
|
28731
f7339cba0a6a
8067480: Crash in klassItable::initialize_itable_for_interface when running vm.runtime.defmeth.StaticMethodsTest.
lfoltan
parents:
27674
diff
changeset
|
581 |
Method* lookup_method_in_all_interfaces(Symbol* name, Symbol* signature, DefaultsLookupMode defaults_mode) const; |
22232
26acfad336c0
8027804: JCK resolveMethod test fails expecting AbstractMethodError
hseigel
parents:
21913
diff
changeset
|
582 |
|
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
583 |
// lookup a method in local defaults then in all interfaces |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
584 |
// (returns NULL if not found) |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
585 |
Method* lookup_method_in_ordered_interfaces(Symbol* name, Symbol* signature) const; |
1 | 586 |
|
14385 | 587 |
// Find method indices by name. If a method with the specified name is |
588 |
// found the index to the first method is returned, and 'end' is filled in |
|
589 |
// with the index of first non-name-matching method. If no method is found |
|
590 |
// -1 is returned. |
|
34666 | 591 |
int find_method_by_name(const Symbol* name, int* end) const; |
592 |
static int find_method_by_name(const Array<Method*>* methods, |
|
593 |
const Symbol* name, int* end); |
|
14385 | 594 |
|
1 | 595 |
// constant pool |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
596 |
ConstantPool* constants() const { return _constants; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
597 |
void set_constants(ConstantPool* c) { _constants = c; } |
1 | 598 |
|
599 |
// protection domain |
|
17826
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
600 |
oop protection_domain() const; |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
601 |
|
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
602 |
// signers |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
603 |
objArrayOop signers() const; |
1 | 604 |
|
1550
be2fc37a817f
6653858: dynamic languages need to be able to load anonymous classes
jrose
parents:
1388
diff
changeset
|
605 |
// host class |
40923
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
606 |
InstanceKlass* host_klass() const { |
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
607 |
InstanceKlass** hk = adr_host_klass(); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
608 |
if (hk == NULL) { |
48555 | 609 |
assert(!is_anonymous(), "Anonymous classes have host klasses"); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
610 |
return NULL; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
611 |
} else { |
22757
b2cbb3680b4f
8033792: AltHashing used jint for imprecise bit shifting
minqi
parents:
22232
diff
changeset
|
612 |
assert(*hk != NULL, "host klass should always be set if the address is not null"); |
48555 | 613 |
assert(is_anonymous(), "Only anonymous classes have host klasses"); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
614 |
return *hk; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
615 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
616 |
} |
40923
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
617 |
void set_host_klass(const InstanceKlass* host) { |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
618 |
assert(is_anonymous(), "not anonymous"); |
40923
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
619 |
const InstanceKlass** addr = (const InstanceKlass **)adr_host_klass(); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
620 |
assert(addr != NULL, "no reversed space"); |
15873
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
621 |
if (addr != NULL) { |
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
622 |
*addr = host; |
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
623 |
} |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
624 |
} |
48555 | 625 |
bool has_host_klass() const { |
626 |
return adr_host_klass() != NULL; |
|
627 |
} |
|
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
628 |
bool is_anonymous() const { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
629 |
return (_misc_flags & _misc_is_anonymous) != 0; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
630 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
631 |
void set_is_anonymous(bool value) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
632 |
if (value) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
633 |
_misc_flags |= _misc_is_anonymous; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
634 |
} else { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
635 |
_misc_flags &= ~_misc_is_anonymous; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
636 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
637 |
} |
1550
be2fc37a817f
6653858: dynamic languages need to be able to load anonymous classes
jrose
parents:
1388
diff
changeset
|
638 |
|
14816 | 639 |
// Oop that keeps the metadata for this class from being unloaded |
640 |
// in places where the metadata is stored in other places, like nmethods |
|
641 |
oop klass_holder() const { |
|
642 |
return is_anonymous() ? java_mirror() : class_loader(); |
|
643 |
} |
|
644 |
||
48614
c39ae979ca35
8191567: Refactor ciInstanceKlass G1 keep alive barrier to use Access API.
eosterlund
parents:
47668
diff
changeset
|
645 |
// Load the klass_holder as a phantom. This is useful when a weak Klass |
c39ae979ca35
8191567: Refactor ciInstanceKlass G1 keep alive barrier to use Access API.
eosterlund
parents:
47668
diff
changeset
|
646 |
// pointer has been "peeked" and then must be kept alive before it may |
c39ae979ca35
8191567: Refactor ciInstanceKlass G1 keep alive barrier to use Access API.
eosterlund
parents:
47668
diff
changeset
|
647 |
// be used safely. |
c39ae979ca35
8191567: Refactor ciInstanceKlass G1 keep alive barrier to use Access API.
eosterlund
parents:
47668
diff
changeset
|
648 |
oop klass_holder_phantom(); |
c39ae979ca35
8191567: Refactor ciInstanceKlass G1 keep alive barrier to use Access API.
eosterlund
parents:
47668
diff
changeset
|
649 |
|
15193
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
650 |
bool is_contended() const { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
651 |
return (_misc_flags & _misc_is_contended) != 0; |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
652 |
} |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
653 |
void set_is_contended(bool value) { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
654 |
if (value) { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
655 |
_misc_flags |= _misc_is_contended; |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
656 |
} else { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
657 |
_misc_flags &= ~_misc_is_contended; |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
658 |
} |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
659 |
} |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
660 |
|
1 | 661 |
// source file name |
19326
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
662 |
Symbol* source_file_name() const { |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
663 |
return (_source_file_name_index == 0) ? |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
664 |
(Symbol*)NULL : _constants->symbol_at(_source_file_name_index); |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
665 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
666 |
u2 source_file_name_index() const { |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
667 |
return _source_file_name_index; |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
668 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
669 |
void set_source_file_name_index(u2 sourcefile_index) { |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
670 |
_source_file_name_index = sourcefile_index; |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
671 |
} |
1 | 672 |
|
673 |
// minor and major version numbers of class file |
|
674 |
u2 minor_version() const { return _minor_version; } |
|
675 |
void set_minor_version(u2 minor_version) { _minor_version = minor_version; } |
|
676 |
u2 major_version() const { return _major_version; } |
|
677 |
void set_major_version(u2 major_version) { _major_version = major_version; } |
|
678 |
||
679 |
// source debug extension |
|
34666 | 680 |
const char* source_debug_extension() const { return _source_debug_extension; } |
681 |
void set_source_debug_extension(const char* array, int length); |
|
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
682 |
|
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
683 |
// symbol unloading support (refcount already added) |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
684 |
Symbol* array_name() { return _array_name; } |
15928
f9d5c6e4107f
8003553: NPG: metaspace objects should be zeroed in constructors
coleenp
parents:
15601
diff
changeset
|
685 |
void set_array_name(Symbol* name) { assert(_array_name == NULL || name == NULL, "name already created"); _array_name = name; } |
1 | 686 |
|
687 |
// nonstatic oop-map blocks |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
688 |
static int nonstatic_oop_map_size(unsigned int oop_map_count) { |
3693 | 689 |
return oop_map_count * OopMapBlock::size_in_words(); |
690 |
} |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
691 |
unsigned int nonstatic_oop_map_count() const { |
3693 | 692 |
return _nonstatic_oop_map_size / OopMapBlock::size_in_words(); |
693 |
} |
|
694 |
int nonstatic_oop_map_size() const { return _nonstatic_oop_map_size; } |
|
695 |
void set_nonstatic_oop_map_size(int words) { |
|
696 |
_nonstatic_oop_map_size = words; |
|
697 |
} |
|
1 | 698 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
699 |
#if INCLUDE_JVMTI |
38309
9b8e9c373740
8155951: VM crash in nsk/jvmti/RedefineClasses/StressRedefine: assert failed: Corrupted constant pool
coleenp
parents:
38192
diff
changeset
|
700 |
// Redefinition locking. Class can only be redefined by one thread at a time. |
9b8e9c373740
8155951: VM crash in nsk/jvmti/RedefineClasses/StressRedefine: assert failed: Corrupted constant pool
coleenp
parents:
38192
diff
changeset
|
701 |
bool is_being_redefined() const { return _is_being_redefined; } |
9b8e9c373740
8155951: VM crash in nsk/jvmti/RedefineClasses/StressRedefine: assert failed: Corrupted constant pool
coleenp
parents:
38192
diff
changeset
|
702 |
void set_is_being_redefined(bool value) { _is_being_redefined = value; } |
9b8e9c373740
8155951: VM crash in nsk/jvmti/RedefineClasses/StressRedefine: assert failed: Corrupted constant pool
coleenp
parents:
38192
diff
changeset
|
703 |
|
1 | 704 |
// RedefineClasses() support for previous versions: |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43929
diff
changeset
|
705 |
void add_previous_version(InstanceKlass* ik, int emcp_method_count); |
40927
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
706 |
void purge_previous_version_list(); |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
707 |
|
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
708 |
InstanceKlass* previous_versions() const { return _previous_versions; } |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
709 |
#else |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
710 |
InstanceKlass* previous_versions() const { return NULL; } |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
711 |
#endif |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
712 |
|
30107
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
713 |
InstanceKlass* get_klass_version(int version) { |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
714 |
for (InstanceKlass* ik = this; ik != NULL; ik = ik->previous_versions()) { |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
715 |
if (ik->constants()->version() == version) { |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
716 |
return ik; |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
717 |
} |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
718 |
} |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
719 |
return NULL; |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
720 |
} |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
721 |
|
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
722 |
bool has_been_redefined() const { |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
723 |
return (_misc_flags & _misc_has_been_redefined) != 0; |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
724 |
} |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
725 |
void set_has_been_redefined() { |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
726 |
_misc_flags |= _misc_has_been_redefined; |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
727 |
} |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
728 |
|
42650 | 729 |
bool has_passed_fingerprint_check() const { |
730 |
return (_misc_flags & _misc_has_passed_fingerprint_check) != 0; |
|
731 |
} |
|
732 |
void set_has_passed_fingerprint_check(bool b) { |
|
733 |
if (b) { |
|
734 |
_misc_flags |= _misc_has_passed_fingerprint_check; |
|
735 |
} else { |
|
736 |
_misc_flags &= ~_misc_has_passed_fingerprint_check; |
|
737 |
} |
|
738 |
} |
|
739 |
bool supers_have_passed_fingerprint_checks(); |
|
740 |
||
47668 | 741 |
static bool should_store_fingerprint(bool is_anonymous); |
742 |
bool should_store_fingerprint() const { return should_store_fingerprint(is_anonymous()); } |
|
42650 | 743 |
bool has_stored_fingerprint() const; |
744 |
uint64_t get_stored_fingerprint() const; |
|
745 |
void store_fingerprint(uint64_t fingerprint); |
|
746 |
||
29576
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
747 |
bool is_scratch_class() const { |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
748 |
return (_misc_flags & _misc_is_scratch_class) != 0; |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
749 |
} |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
750 |
|
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
751 |
void set_is_scratch_class() { |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
752 |
_misc_flags |= _misc_is_scratch_class; |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
753 |
} |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
754 |
|
46505
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
755 |
bool has_resolved_methods() const { |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
756 |
return (_misc_flags & _misc_has_resolved_methods) != 0; |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
757 |
} |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
758 |
|
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
759 |
void set_has_resolved_methods() { |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
760 |
_misc_flags |= _misc_has_resolved_methods; |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
761 |
} |
33151
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
762 |
private: |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
763 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
764 |
void set_kind(unsigned kind) { |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
765 |
assert(kind <= _misc_kind_field_mask, "Invalid InstanceKlass kind"); |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
766 |
unsigned fmask = _misc_kind_field_mask << _misc_kind_field_pos; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
767 |
unsigned flags = _misc_flags & ~fmask; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
768 |
_misc_flags = (flags | (kind << _misc_kind_field_pos)); |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
769 |
} |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
770 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
771 |
bool is_kind(unsigned desired) const { |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
772 |
unsigned kind = (_misc_flags >> _misc_kind_field_pos) & _misc_kind_field_mask; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
773 |
return kind == desired; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
774 |
} |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
775 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
776 |
public: |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
777 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
778 |
// Other is anything that is not one of the more specialized kinds of InstanceKlass. |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
779 |
bool is_other_instance_klass() const { return is_kind(_misc_kind_other); } |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
780 |
bool is_reference_instance_klass() const { return is_kind(_misc_kind_reference); } |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
781 |
bool is_mirror_instance_klass() const { return is_kind(_misc_kind_mirror); } |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
782 |
bool is_class_loader_instance_klass() const { return is_kind(_misc_kind_class_loader); } |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
783 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
784 |
#if INCLUDE_JVMTI |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
785 |
|
1 | 786 |
void init_previous_versions() { |
787 |
_previous_versions = NULL; |
|
788 |
} |
|
789 |
||
29576
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
790 |
private: |
40927
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
791 |
static bool _has_previous_versions; |
29576
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
792 |
public: |
40927
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
793 |
static void purge_previous_versions(InstanceKlass* ik) { |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
794 |
if (ik->has_been_redefined()) { |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
795 |
ik->purge_previous_version_list(); |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
796 |
} |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
797 |
} |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
798 |
|
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
799 |
static bool has_previous_versions_and_reset(); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
800 |
|
1 | 801 |
// JVMTI: Support for caching a class file before it is modified by an agent that can do retransformation |
18940
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
802 |
void set_cached_class_file(JvmtiCachedClassFileData *data) { |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
803 |
_cached_class_file = data; |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
804 |
} |
41182 | 805 |
JvmtiCachedClassFileData * get_cached_class_file(); |
18940
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
806 |
jint get_cached_class_file_len(); |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
807 |
unsigned char * get_cached_class_file_bytes(); |
1 | 808 |
|
809 |
// JVMTI: Support for caching of field indices, types, and offsets |
|
810 |
void set_jvmti_cached_class_field_map(JvmtiCachedClassFieldMap* descriptor) { |
|
811 |
_jvmti_cached_class_field_map = descriptor; |
|
812 |
} |
|
813 |
JvmtiCachedClassFieldMap* jvmti_cached_class_field_map() const { |
|
814 |
return _jvmti_cached_class_field_map; |
|
815 |
} |
|
816 |
||
41182 | 817 |
#if INCLUDE_CDS |
818 |
void set_archived_class_data(JvmtiCachedClassFileData* data) { |
|
819 |
_cached_class_file = data; |
|
820 |
} |
|
821 |
||
822 |
JvmtiCachedClassFileData * get_archived_class_data(); |
|
823 |
#endif // INCLUDE_CDS |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
824 |
#else // INCLUDE_JVMTI |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
825 |
|
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
826 |
static void purge_previous_versions(InstanceKlass* ik) { return; }; |
40927
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
827 |
static bool has_previous_versions_and_reset() { return false; } |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
828 |
|
39995 | 829 |
void set_cached_class_file(JvmtiCachedClassFileData *data) { |
830 |
assert(data == NULL, "unexpected call with JVMTI disabled"); |
|
831 |
} |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
832 |
JvmtiCachedClassFileData * get_cached_class_file() { return (JvmtiCachedClassFileData *)NULL; } |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
833 |
|
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
834 |
#endif // INCLUDE_JVMTI |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
835 |
|
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
836 |
bool has_nonstatic_concrete_methods() const { |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
837 |
return (_misc_flags & _misc_has_nonstatic_concrete_methods) != 0; |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
838 |
} |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
839 |
void set_has_nonstatic_concrete_methods(bool b) { |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
840 |
if (b) { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
841 |
_misc_flags |= _misc_has_nonstatic_concrete_methods; |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
842 |
} else { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
843 |
_misc_flags &= ~_misc_has_nonstatic_concrete_methods; |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
844 |
} |
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
845 |
} |
14385 | 846 |
|
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
847 |
bool declares_nonstatic_concrete_methods() const { |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
848 |
return (_misc_flags & _misc_declares_nonstatic_concrete_methods) != 0; |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
849 |
} |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
850 |
void set_declares_nonstatic_concrete_methods(bool b) { |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
851 |
if (b) { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
852 |
_misc_flags |= _misc_declares_nonstatic_concrete_methods; |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
853 |
} else { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
854 |
_misc_flags &= ~_misc_declares_nonstatic_concrete_methods; |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
855 |
} |
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
856 |
} |
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
857 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
858 |
// for adding methods, ConstMethod::UNSET_IDNUM means no more ids available |
1 | 859 |
inline u2 next_method_idnum(); |
860 |
void set_initial_method_idnum(u2 value) { _idnum_allocated_count = value; } |
|
861 |
||
862 |
// generics support |
|
19326
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
863 |
Symbol* generic_signature() const { |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
864 |
return (_generic_signature_index == 0) ? |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
865 |
(Symbol*)NULL : _constants->symbol_at(_generic_signature_index); |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
866 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
867 |
u2 generic_signature_index() const { |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
868 |
return _generic_signature_index; |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
869 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
870 |
void set_generic_signature_index(u2 sig_index) { |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
871 |
_generic_signature_index = sig_index; |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
872 |
} |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
873 |
|
34666 | 874 |
u2 enclosing_method_data(int offset) const; |
875 |
u2 enclosing_method_class_index() const { |
|
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
876 |
return enclosing_method_data(enclosing_method_class_index_offset); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
877 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
878 |
u2 enclosing_method_method_index() { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
879 |
return enclosing_method_data(enclosing_method_method_index_offset); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
880 |
} |
1 | 881 |
void set_enclosing_method_indices(u2 class_index, |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
882 |
u2 method_index); |
1 | 883 |
|
884 |
// jmethodID support |
|
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
885 |
jmethodID get_jmethod_id(const methodHandle& method_h); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
886 |
jmethodID get_jmethod_id_fetch_or_update(size_t idnum, |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
887 |
jmethodID new_id, jmethodID* new_jmeths, |
3824
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
888 |
jmethodID* to_dealloc_id_p, |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
889 |
jmethodID** to_dealloc_jmeths_p); |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
890 |
static void get_jmethod_id_length_value(jmethodID* cache, size_t idnum, |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
891 |
size_t *length_p, jmethodID* id_p); |
27478 | 892 |
void ensure_space_for_methodids(int start_offset = 0); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
893 |
jmethodID jmethod_id_or_null(Method* method); |
1 | 894 |
|
895 |
// annotations support |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
896 |
Annotations* annotations() const { return _annotations; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
897 |
void set_annotations(Annotations* anno) { _annotations = anno; } |
15601 | 898 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
899 |
AnnotationArray* class_annotations() const { |
15601 | 900 |
return (_annotations != NULL) ? _annotations->class_annotations() : NULL; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
901 |
} |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
902 |
Array<AnnotationArray*>* fields_annotations() const { |
15601 | 903 |
return (_annotations != NULL) ? _annotations->fields_annotations() : NULL; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
904 |
} |
15601 | 905 |
AnnotationArray* class_type_annotations() const { |
906 |
return (_annotations != NULL) ? _annotations->class_type_annotations() : NULL; |
|
15097
9db149412e0e
8004823: Add VM support for type annotation reflection
stefank
parents:
14816
diff
changeset
|
907 |
} |
15601 | 908 |
Array<AnnotationArray*>* fields_type_annotations() const { |
909 |
return (_annotations != NULL) ? _annotations->fields_type_annotations() : NULL; |
|
910 |
} |
|
1 | 911 |
// allocation |
912 |
instanceOop allocate_instance(TRAPS); |
|
913 |
||
914 |
// additional member function to return a handle |
|
915 |
instanceHandle allocate_instance_handle(TRAPS) { return instanceHandle(THREAD, allocate_instance(THREAD)); } |
|
916 |
||
917 |
objArrayOop allocate_objArray(int n, int length, TRAPS); |
|
918 |
// Helper function |
|
919 |
static instanceOop register_finalizer(instanceOop i, TRAPS); |
|
920 |
||
921 |
// Check whether reflection/jni/jvm code is allowed to instantiate this class; |
|
922 |
// if not, throw either an Error or an Exception. |
|
923 |
virtual void check_valid_for_instantiation(bool throwError, TRAPS); |
|
924 |
||
925 |
// initialization |
|
926 |
void call_class_initializer(TRAPS); |
|
927 |
void set_initialization_state_and_notify(ClassState state, TRAPS); |
|
928 |
||
929 |
// OopMapCache support |
|
930 |
OopMapCache* oop_map_cache() { return _oop_map_cache; } |
|
931 |
void set_oop_map_cache(OopMapCache *cache) { _oop_map_cache = cache; } |
|
33593
60764a78fa5c
8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents:
33576
diff
changeset
|
932 |
void mask_for(const methodHandle& method, int bci, InterpreterOopMap* entry); |
1 | 933 |
|
934 |
// JNI identifier support (for static fields - for jni performance) |
|
935 |
JNIid* jni_ids() { return _jni_ids; } |
|
936 |
void set_jni_ids(JNIid* ids) { _jni_ids = ids; } |
|
937 |
JNIid* jni_id_for(int offset); |
|
938 |
||
939 |
// maintenance of deoptimization dependencies |
|
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
940 |
inline DependencyContext dependencies(); |
36300
5b47f168b948
7177745: JSR292: Many Callsite relinkages cause target method to always run in interpreter mode
vlivanov
parents:
35917
diff
changeset
|
941 |
int mark_dependent_nmethods(KlassDepChange& changes); |
1 | 942 |
void add_dependent_nmethod(nmethod* nm); |
33576
6dbde58b08a6
8058563: InstanceKlass::_dependencies list isn't cleared from empty nmethodBucket entries
stefank
parents:
33151
diff
changeset
|
943 |
void remove_dependent_nmethod(nmethod* nm, bool delete_immediately); |
1 | 944 |
|
945 |
// On-stack replacement support |
|
946 |
nmethod* osr_nmethods_head() const { return _osr_nmethods_head; }; |
|
947 |
void set_osr_nmethods_head(nmethod* h) { _osr_nmethods_head = h; }; |
|
948 |
void add_osr_nmethod(nmethod* n); |
|
36802
18b1db5a7e70
8023191: OSR nmethods should be flushed to free space in CodeCache
thartmann
parents:
36404
diff
changeset
|
949 |
bool remove_osr_nmethod(nmethod* n); |
27434
b4b185d05bb5
8061817: Whitebox.deoptimizeMethod() does not deoptimize all OSR versions of method
thartmann
parents:
26558
diff
changeset
|
950 |
int mark_osr_nmethods(const Method* m); |
17370
59a0620561fa
8003557: NPG: Klass* const k should be const Klass* k.
minqi
parents:
17078
diff
changeset
|
951 |
nmethod* lookup_osr_nmethod(const Method* m, int bci, int level, bool match_level) const; |
1 | 952 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
953 |
#if INCLUDE_JVMTI |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
954 |
// Breakpoint support (see methods on Method* for details) |
1 | 955 |
BreakpointInfo* breakpoints() const { return _breakpoints; }; |
956 |
void set_breakpoints(BreakpointInfo* bps) { _breakpoints = bps; }; |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
957 |
#endif |
1 | 958 |
|
959 |
// support for stub routines |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
960 |
static ByteSize init_state_offset() { return in_ByteSize(offset_of(InstanceKlass, _init_state)); } |
36384 | 961 |
TRACE_DEFINE_KLASS_TRACE_ID_OFFSET; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
962 |
static ByteSize init_thread_offset() { return in_ByteSize(offset_of(InstanceKlass, _init_thread)); } |
1 | 963 |
|
964 |
// subclass/subinterface checks |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
965 |
bool implements_interface(Klass* k) const; |
21768
b7dba4cde1c6
8026065: InterfaceMethodref for invokespecial must name a direct superinterface
hseigel
parents:
21079
diff
changeset
|
966 |
bool is_same_or_direct_interface(Klass* k) const; |
1 | 967 |
|
24828
dd5406c950a1
6904403: assert(f == k->has_finalizer(),"inconsistent has_finalizer") with debug VM
dsamersoff
parents:
23999
diff
changeset
|
968 |
#ifdef ASSERT |
dd5406c950a1
6904403: assert(f == k->has_finalizer(),"inconsistent has_finalizer") with debug VM
dsamersoff
parents:
23999
diff
changeset
|
969 |
// check whether this class or one of its superclasses was redefined |
34666 | 970 |
bool has_redefined_this_or_super() const; |
24828
dd5406c950a1
6904403: assert(f == k->has_finalizer(),"inconsistent has_finalizer") with debug VM
dsamersoff
parents:
23999
diff
changeset
|
971 |
#endif |
dd5406c950a1
6904403: assert(f == k->has_finalizer(),"inconsistent has_finalizer") with debug VM
dsamersoff
parents:
23999
diff
changeset
|
972 |
|
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
973 |
// Access to the implementor of an interface. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
974 |
Klass* implementor() const |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
975 |
{ |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
976 |
Klass** k = adr_implementor(); |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
977 |
if (k == NULL) { |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
978 |
return NULL; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
979 |
} else { |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
980 |
return *k; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
981 |
} |
1 | 982 |
} |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
983 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
984 |
void set_implementor(Klass* k) { |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
985 |
assert(is_interface(), "not interface"); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
986 |
Klass** addr = adr_implementor(); |
15873
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
987 |
assert(addr != NULL, "null addr"); |
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
988 |
if (addr != NULL) { |
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
989 |
*addr = k; |
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
990 |
} |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
991 |
} |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
992 |
|
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
993 |
int nof_implementors() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
994 |
Klass* k = implementor(); |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
995 |
if (k == NULL) { |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
996 |
return 0; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
997 |
} else if (k != this) { |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
998 |
return 1; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
999 |
} else { |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1000 |
return 2; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1001 |
} |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1002 |
} |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1003 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1004 |
void add_implementor(Klass* k); // k is a new class that implements this interface |
1 | 1005 |
void init_implementor(); // initialize |
1006 |
||
1007 |
// link this class into the implementors list of every interface it implements |
|
1008 |
void process_interfaces(Thread *thread); |
|
1009 |
||
1010 |
// virtual operations from Klass |
|
1011 |
bool is_leaf_class() const { return _subklass == NULL; } |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1012 |
GrowableArray<Klass*>* compute_secondary_supers(int num_extra_slots); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1013 |
bool compute_is_subtype_of(Klass* k); |
1 | 1014 |
bool can_be_primary_super_slow() const; |
1015 |
int oop_size(oop obj) const { return size_helper(); } |
|
33611
9abd65805e19
8139203: Consistent naming for klass type predicates
coleenp
parents:
33602
diff
changeset
|
1016 |
// slow because it's a virtual call and used for verifying the layout_helper. |
9abd65805e19
8139203: Consistent naming for klass type predicates
coleenp
parents:
33602
diff
changeset
|
1017 |
// Using the layout_helper bits, we can call is_instance_klass without a virtual call. |
9abd65805e19
8139203: Consistent naming for klass type predicates
coleenp
parents:
33602
diff
changeset
|
1018 |
DEBUG_ONLY(bool is_instance_klass_slow() const { return true; }) |
1 | 1019 |
|
1020 |
// Iterators |
|
1021 |
void do_local_static_fields(FieldClosure* cl); |
|
1022 |
void do_nonstatic_fields(FieldClosure* cl); // including inherited fields |
|
23872
536c66fc43d3
8028497: SIGSEGV at ClassLoaderData::oops_do(OopClosure*, KlassClosure*, bool)
coleenp
parents:
23515
diff
changeset
|
1023 |
void do_local_static_fields(void f(fieldDescriptor*, Handle, TRAPS), Handle, TRAPS); |
1 | 1024 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1025 |
void methods_do(void f(Method* method)); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1026 |
void array_klasses_do(void f(Klass* k)); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1027 |
void array_klasses_do(void f(Klass* k, TRAPS), TRAPS); |
1 | 1028 |
bool super_types_do(SuperTypeClosure* blk); |
1029 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1030 |
static InstanceKlass* cast(Klass* k) { |
34666 | 1031 |
return const_cast<InstanceKlass*>(cast(const_cast<const Klass*>(k))); |
1032 |
} |
|
1033 |
||
1034 |
static const InstanceKlass* cast(const Klass* k) { |
|
33602 | 1035 |
assert(k != NULL, "k should not be null"); |
33611
9abd65805e19
8139203: Consistent naming for klass type predicates
coleenp
parents:
33602
diff
changeset
|
1036 |
assert(k->is_instance_klass(), "cast to InstanceKlass"); |
34666 | 1037 |
return static_cast<const InstanceKlass*>(k); |
1 | 1038 |
} |
1039 |
||
14385 | 1040 |
InstanceKlass* java_super() const { |
1041 |
return (super() == NULL) ? NULL : cast(super()); |
|
1042 |
} |
|
1043 |
||
1 | 1044 |
// Sizing (in words) |
35898
ddc274f0052f
8145628: hotspot metadata classes shouldn't use HeapWordSize or heap related macros like align_object_size
coleenp
parents:
35877
diff
changeset
|
1045 |
static int header_size() { return sizeof(InstanceKlass)/wordSize; } |
15601 | 1046 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1047 |
static int size(int vtable_length, int itable_length, |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1048 |
int nonstatic_oop_map_size, |
42650 | 1049 |
bool is_interface, bool is_anonymous, bool has_stored_fingerprint) { |
35898
ddc274f0052f
8145628: hotspot metadata classes shouldn't use HeapWordSize or heap related macros like align_object_size
coleenp
parents:
35877
diff
changeset
|
1050 |
return align_metadata_size(header_size() + |
35847
990c61a50f24
8143608: Don't 64-bit align start of InstanceKlass vtable, itable, and nonstatic_oopmap on 32-bit systems
cjplummer
parents:
35135
diff
changeset
|
1051 |
vtable_length + |
990c61a50f24
8143608: Don't 64-bit align start of InstanceKlass vtable, itable, and nonstatic_oopmap on 32-bit systems
cjplummer
parents:
35135
diff
changeset
|
1052 |
itable_length + |
990c61a50f24
8143608: Don't 64-bit align start of InstanceKlass vtable, itable, and nonstatic_oopmap on 32-bit systems
cjplummer
parents:
35135
diff
changeset
|
1053 |
nonstatic_oop_map_size + |
35898
ddc274f0052f
8145628: hotspot metadata classes shouldn't use HeapWordSize or heap related macros like align_object_size
coleenp
parents:
35877
diff
changeset
|
1054 |
(is_interface ? (int)sizeof(Klass*)/wordSize : 0) + |
42650 | 1055 |
(is_anonymous ? (int)sizeof(Klass*)/wordSize : 0) + |
1056 |
(has_stored_fingerprint ? (int)sizeof(uint64_t*)/wordSize : 0)); |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1057 |
} |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1058 |
int size() const { return size(vtable_length(), |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1059 |
itable_length(), |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1060 |
nonstatic_oop_map_size(), |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1061 |
is_interface(), |
42650 | 1062 |
is_anonymous(), |
1063 |
has_stored_fingerprint()); |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1064 |
} |
15437 | 1065 |
#if INCLUDE_SERVICES |
1066 |
virtual void collect_statistics(KlassSizeStats *sz) const; |
|
1067 |
#endif |
|
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1068 |
|
35900 | 1069 |
intptr_t* start_of_itable() const { return (intptr_t*)start_of_vtable() + vtable_length(); } |
1070 |
intptr_t* end_of_itable() const { return start_of_itable() + itable_length(); } |
|
1071 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1072 |
int itable_offset_in_words() const { return start_of_itable() - (intptr_t*)this; } |
1 | 1073 |
|
8725
8c1e3dd5fe1b
7017732: move static fields into Class to prepare for perm gen removal
never
parents:
8676
diff
changeset
|
1074 |
address static_field_addr(int offset); |
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
1075 |
|
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
1076 |
OopMapBlock* start_of_nonstatic_oop_maps() const { |
35847
990c61a50f24
8143608: Don't 64-bit align start of InstanceKlass vtable, itable, and nonstatic_oopmap on 32-bit systems
cjplummer
parents:
35135
diff
changeset
|
1077 |
return (OopMapBlock*)(start_of_itable() + itable_length()); |
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
1078 |
} |
1 | 1079 |
|
15601 | 1080 |
Klass** end_of_nonstatic_oop_maps() const { |
1081 |
return (Klass**)(start_of_nonstatic_oop_maps() + |
|
1082 |
nonstatic_oop_map_count()); |
|
1083 |
} |
|
1084 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1085 |
Klass** adr_implementor() const { |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1086 |
if (is_interface()) { |
15601 | 1087 |
return (Klass**)end_of_nonstatic_oop_maps(); |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1088 |
} else { |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1089 |
return NULL; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1090 |
} |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1091 |
}; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1092 |
|
40923
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
1093 |
InstanceKlass** adr_host_klass() const { |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1094 |
if (is_anonymous()) { |
40923
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
1095 |
InstanceKlass** adr_impl = (InstanceKlass **)adr_implementor(); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1096 |
if (adr_impl != NULL) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1097 |
return adr_impl + 1; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1098 |
} else { |
40923
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
1099 |
return (InstanceKlass **)end_of_nonstatic_oop_maps(); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1100 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1101 |
} else { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1102 |
return NULL; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1103 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1104 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1105 |
|
42650 | 1106 |
address adr_fingerprint() const { |
1107 |
if (has_stored_fingerprint()) { |
|
1108 |
InstanceKlass** adr_host = adr_host_klass(); |
|
1109 |
if (adr_host != NULL) { |
|
1110 |
return (address)(adr_host + 1); |
|
1111 |
} |
|
1112 |
||
1113 |
Klass** adr_impl = adr_implementor(); |
|
1114 |
if (adr_impl != NULL) { |
|
1115 |
return (address)(adr_impl + 1); |
|
1116 |
} |
|
1117 |
||
1118 |
return (address)end_of_nonstatic_oop_maps(); |
|
1119 |
} else { |
|
1120 |
return NULL; |
|
1121 |
} |
|
1122 |
} |
|
1123 |
||
1 | 1124 |
// Use this to return the size of an instance in heap words: |
1125 |
int size_helper() const { |
|
1126 |
return layout_helper_to_size_helper(layout_helper()); |
|
1127 |
} |
|
1128 |
||
1129 |
// This bit is initialized in classFileParser.cpp. |
|
1130 |
// It is false under any of the following conditions: |
|
1131 |
// - the class is abstract (including any interface) |
|
1132 |
// - the class has a finalizer (if !RegisterFinalizersAtInit) |
|
1133 |
// - the class size is larger than FastAllocateSizeLimit |
|
1134 |
// - the class is java/lang/Class, which cannot be allocated directly |
|
1135 |
bool can_be_fastpath_allocated() const { |
|
1136 |
return !layout_helper_needs_slow_path(layout_helper()); |
|
1137 |
} |
|
1138 |
||
35900 | 1139 |
// Java itable |
46408
70aab0c2ea8b
8178350: klassVtable and klassItable should be ValueObj
iklam
parents:
46341
diff
changeset
|
1140 |
klassItable itable() const; // return klassItable wrapper |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1141 |
Method* method_at_itable(Klass* holder, int index, TRAPS); |
1 | 1142 |
|
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
1143 |
#if INCLUDE_JVMTI |
29316
5287df8a8972
8046246: the constantPoolCacheOopDesc::adjust_method_entries() used in RedefineClasses does not scale
sspitsyn
parents:
28738
diff
changeset
|
1144 |
void adjust_default_methods(InstanceKlass* holder, bool* trace_name_printed); |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
1145 |
#endif // INCLUDE_JVMTI |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
1146 |
|
33576
6dbde58b08a6
8058563: InstanceKlass::_dependencies list isn't cleared from empty nmethodBucket entries
stefank
parents:
33151
diff
changeset
|
1147 |
void clean_weak_instanceklass_links(BoolObjectClosure* is_alive); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1148 |
void clean_implementors_list(BoolObjectClosure* is_alive); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1149 |
void clean_method_data(BoolObjectClosure* is_alive); |
1 | 1150 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1151 |
// Explicit metaspace deallocation of fields |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1152 |
// For RedefineClasses and class file parsing errors, we need to deallocate |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1153 |
// instanceKlasses and the metadata they point to. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1154 |
void deallocate_contents(ClassLoaderData* loader_data); |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1155 |
static void deallocate_methods(ClassLoaderData* loader_data, |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1156 |
Array<Method*>* methods); |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1157 |
void static deallocate_interfaces(ClassLoaderData* loader_data, |
34666 | 1158 |
const Klass* super_klass, |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1159 |
Array<Klass*>* local_interfaces, |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1160 |
Array<Klass*>* transitive_interfaces); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1161 |
|
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1162 |
// The constant pool is on stack if any of the methods are executing or |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1163 |
// referenced by handles. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1164 |
bool on_stack() const { return _constants->on_stack(); } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1165 |
|
17075
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1166 |
// callbacks for actions during class unloading |
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1167 |
static void notify_unload_class(InstanceKlass* ik); |
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1168 |
static void release_C_heap_structures(InstanceKlass* ik); |
1 | 1169 |
|
1170 |
// Naming |
|
4094
1f424b2b2171
6815692: method handle code needs some cleanup (post-6655638)
jrose
parents:
3824
diff
changeset
|
1171 |
const char* signature_name() const; |
39216
40c3d66352ae
8153858: Clean up needed when obtaining the package name from a fully qualified class name
rprotacio
parents:
38309
diff
changeset
|
1172 |
static Symbol* package_from_name(const Symbol* name, TRAPS); |
1 | 1173 |
|
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1174 |
// GC specific object visitors |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1175 |
// |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1176 |
#if INCLUDE_ALL_GCS |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1177 |
// Parallel Scavenge |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1178 |
void oop_ps_push_contents( oop obj, PSPromotionManager* pm); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1179 |
// Parallel Compact |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1180 |
void oop_pc_follow_contents(oop obj, ParCompactionManager* cm); |
35877
a2a62511d0f8
8146987: Improve Parallel GC Full GC by caching results of live_words_in_range()
tschatzl
parents:
35871
diff
changeset
|
1181 |
void oop_pc_update_pointers(oop obj, ParCompactionManager* cm); |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1182 |
#endif |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1183 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1184 |
// Oop fields (and metadata) iterators |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1185 |
// [nv = true] Use non-virtual calls to do_oop_nv. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1186 |
// [nv = false] Use virtual calls to do_oop. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1187 |
// |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1188 |
// The InstanceKlass iterators also visits the Object's klass. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1189 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1190 |
// Forward iteration |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1191 |
public: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1192 |
// Iterate over all oop fields in the oop maps. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1193 |
template <bool nv, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1194 |
inline void oop_oop_iterate_oop_maps(oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1195 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1196 |
protected: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1197 |
// Iterate over all oop fields and metadata. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1198 |
template <bool nv, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1199 |
inline int oop_oop_iterate(oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1200 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1201 |
private: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1202 |
// Iterate over all oop fields in the oop maps. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1203 |
// Specialized for [T = oop] or [T = narrowOop]. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1204 |
template <bool nv, typename T, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1205 |
inline void oop_oop_iterate_oop_maps_specialized(oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1206 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1207 |
// Iterate over all oop fields in one oop map. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1208 |
template <bool nv, typename T, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1209 |
inline void oop_oop_iterate_oop_map(OopMapBlock* map, oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1210 |
|
1 | 1211 |
|
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1212 |
// Reverse iteration |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1213 |
#if INCLUDE_ALL_GCS |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1214 |
public: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1215 |
// Iterate over all oop fields in the oop maps. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1216 |
template <bool nv, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1217 |
inline void oop_oop_iterate_oop_maps_reverse(oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1218 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1219 |
protected: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1220 |
// Iterate over all oop fields and metadata. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1221 |
template <bool nv, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1222 |
inline int oop_oop_iterate_reverse(oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1223 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1224 |
private: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1225 |
// Iterate over all oop fields in the oop maps. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1226 |
// Specialized for [T = oop] or [T = narrowOop]. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1227 |
template <bool nv, typename T, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1228 |
inline void oop_oop_iterate_oop_maps_specialized_reverse(oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1229 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1230 |
// Iterate over all oop fields in one oop map. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1231 |
template <bool nv, typename T, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1232 |
inline void oop_oop_iterate_oop_map_reverse(OopMapBlock* map, oop obj, OopClosureType* closure); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1233 |
#endif |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1234 |
|
1 | 1235 |
|
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1236 |
// Bounded range iteration |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1237 |
public: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1238 |
// Iterate over all oop fields in the oop maps. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1239 |
template <bool nv, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1240 |
inline void oop_oop_iterate_oop_maps_bounded(oop obj, OopClosureType* closure, MemRegion mr); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1241 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1242 |
protected: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1243 |
// Iterate over all oop fields and metadata. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1244 |
template <bool nv, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1245 |
inline int oop_oop_iterate_bounded(oop obj, OopClosureType* closure, MemRegion mr); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1246 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1247 |
private: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1248 |
// Iterate over all oop fields in the oop maps. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1249 |
// Specialized for [T = oop] or [T = narrowOop]. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1250 |
template <bool nv, typename T, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1251 |
inline void oop_oop_iterate_oop_maps_specialized_bounded(oop obj, OopClosureType* closure, MemRegion mr); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1252 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1253 |
// Iterate over all oop fields in one oop map. |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1254 |
template <bool nv, typename T, class OopClosureType> |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1255 |
inline void oop_oop_iterate_oop_map_bounded(OopMapBlock* map, oop obj, OopClosureType* closure, MemRegion mr); |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1256 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1257 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1258 |
public: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1259 |
|
30880
efe35e08179f
8080746: Refactor oop iteration macros to be more general
sjohanss
parents:
30764
diff
changeset
|
1260 |
ALL_OOP_OOP_ITERATE_CLOSURES_1(OOP_OOP_ITERATE_DECL) |
efe35e08179f
8080746: Refactor oop iteration macros to be more general
sjohanss
parents:
30764
diff
changeset
|
1261 |
ALL_OOP_OOP_ITERATE_CLOSURES_2(OOP_OOP_ITERATE_DECL) |
1374
4c24294029a9
6711316: Open source the Garbage-First garbage collector
ysr
parents:
360
diff
changeset
|
1262 |
|
15482
470d0b0c09f1
8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents:
15202
diff
changeset
|
1263 |
#if INCLUDE_ALL_GCS |
30880
efe35e08179f
8080746: Refactor oop iteration macros to be more general
sjohanss
parents:
30764
diff
changeset
|
1264 |
ALL_OOP_OOP_ITERATE_CLOSURES_1(OOP_OOP_ITERATE_DECL_BACKWARDS) |
efe35e08179f
8080746: Refactor oop iteration macros to be more general
sjohanss
parents:
30764
diff
changeset
|
1265 |
ALL_OOP_OOP_ITERATE_CLOSURES_2(OOP_OOP_ITERATE_DECL_BACKWARDS) |
15482
470d0b0c09f1
8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents:
15202
diff
changeset
|
1266 |
#endif // INCLUDE_ALL_GCS |
1 | 1267 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1268 |
u2 idnum_allocated_count() const { return _idnum_allocated_count; } |
17078
a37993c37937
8008962: NPG: Memory regression: One extra Monitor per ConstantPool
iklam
parents:
17075
diff
changeset
|
1269 |
|
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1270 |
public: |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1271 |
void set_in_error_state() { |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1272 |
assert(DumpSharedSpaces, "only call this when dumping archive"); |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1273 |
_init_state = initialization_error; |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1274 |
} |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1275 |
bool check_sharing_error_state(); |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1276 |
|
1 | 1277 |
private: |
1278 |
// initialization state |
|
1279 |
#ifdef ASSERT |
|
1280 |
void set_init_state(ClassState state); |
|
1281 |
#else |
|
11407
5399831730cd
7117052: instanceKlass::_init_state can be u1 type
coleenp
parents:
11405
diff
changeset
|
1282 |
void set_init_state(ClassState state) { _init_state = (u1)state; } |
1 | 1283 |
#endif |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1284 |
void set_rewritten() { _misc_flags |= _misc_rewritten; } |
1 | 1285 |
void set_init_thread(Thread *thread) { _init_thread = thread; } |
1286 |
||
3824
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
1287 |
// The RedefineClasses() API can cause new method idnums to be needed |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
1288 |
// which will cause the caches to grow. Safety requires different |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
1289 |
// cache management logic if the caches can grow instead of just |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
1290 |
// going from NULL to non-NULL. |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
1291 |
bool idnum_can_increment() const { return has_been_redefined(); } |
40887
8d35e19f5548
8158854: Ensure release_store is paired with load_acquire in lock-free code
dholmes
parents:
40102
diff
changeset
|
1292 |
inline jmethodID* methods_jmethod_ids_acquire() const; |
8d35e19f5548
8158854: Ensure release_store is paired with load_acquire in lock-free code
dholmes
parents:
40102
diff
changeset
|
1293 |
inline void release_set_methods_jmethod_ids(jmethodID* jmeths); |
1 | 1294 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1295 |
// Lock during initialization |
17078
a37993c37937
8008962: NPG: Memory regression: One extra Monitor per ConstantPool
iklam
parents:
17075
diff
changeset
|
1296 |
public: |
17826
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
1297 |
// Lock for (1) initialization; (2) access to the ConstantPool of this class. |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
1298 |
// Must be one per class and it has to be a VM internal object so java code |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
1299 |
// cannot lock it (like the mirror). |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
1300 |
// It has to be an object not a Mutex because it's held through java calls. |
20379
a4c59d30d67d
8025004: -XX:+CheckUnhandledOops asserts for JDK 8 Solaris fastdebug binaries
coleenp
parents:
20065
diff
changeset
|
1301 |
oop init_lock() const; |
17078
a37993c37937
8008962: NPG: Memory regression: One extra Monitor per ConstantPool
iklam
parents:
17075
diff
changeset
|
1302 |
private: |
21079
7028d0cb9b49
8014910: deadlock between JVM/TI ClassPrepare event handler and CompilerThread
iklam
parents:
20391
diff
changeset
|
1303 |
void fence_and_clear_init_lock(); |
1 | 1304 |
|
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1305 |
bool link_class_impl (bool throw_verifyerror, TRAPS); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1306 |
bool verify_code (bool throw_verifyerror, TRAPS); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1307 |
void initialize_impl (TRAPS); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1308 |
void initialize_super_interfaces (TRAPS); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1309 |
void eager_initialize_impl (); |
1 | 1310 |
/* jni_id_for_impl for jfieldID only */ |
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1311 |
JNIid* jni_id_for_impl (int offset); |
1 | 1312 |
|
1313 |
// Returns the array class for the n'th dimension |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1314 |
Klass* array_klass_impl(bool or_null, int n, TRAPS); |
1 | 1315 |
|
1316 |
// Returns the array class with this class as element type |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1317 |
Klass* array_klass_impl(bool or_null, TRAPS); |
1 | 1318 |
|
23999
22eb7be3d99d
8033150: invokestatic: IncompatibleClassChangeError trying to invoke static method from a parent in presence of conflicting defaults.
lfoltan
parents:
23872
diff
changeset
|
1319 |
// find a local method (returns NULL if not found) |
34666 | 1320 |
Method* find_method_impl(const Symbol* name, |
1321 |
const Symbol* signature, |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1322 |
OverpassLookupMode overpass_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1323 |
StaticLookupMode static_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1324 |
PrivateLookupMode private_mode) const; |
34666 | 1325 |
|
1326 |
static Method* find_method_impl(const Array<Method*>* methods, |
|
1327 |
const Symbol* name, |
|
1328 |
const Symbol* signature, |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1329 |
OverpassLookupMode overpass_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1330 |
StaticLookupMode static_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1331 |
PrivateLookupMode private_mode); |
23999
22eb7be3d99d
8033150: invokestatic: IncompatibleClassChangeError trying to invoke static method from a parent in presence of conflicting defaults.
lfoltan
parents:
23872
diff
changeset
|
1332 |
|
17075
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1333 |
// Free CHeap allocated fields. |
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1334 |
void release_C_heap_structures(); |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
1335 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
1336 |
#if INCLUDE_JVMTI |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
1337 |
// RedefineClasses support |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
1338 |
void link_previous_versions(InstanceKlass* pv) { _previous_versions = pv; } |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
1339 |
void mark_newly_obsolete_methods(Array<Method*>* old_methods, int emcp_method_count); |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
1340 |
#endif |
1 | 1341 |
public: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1342 |
// CDS support - remove and restore oops from metadata. Oops are not shared. |
1 | 1343 |
virtual void remove_unshareable_info(); |
47103
a993ec29ec75
8186842: Use Java class loaders for creating the CDS archive
ccheung
parents:
46746
diff
changeset
|
1344 |
virtual void remove_java_mirror(); |
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1345 |
virtual void restore_unshareable_info(ClassLoaderData* loader_data, Handle protection_domain, TRAPS); |
1 | 1346 |
|
1347 |
// jvm support |
|
1348 |
jint compute_modifier_flags(TRAPS) const; |
|
1349 |
||
1350 |
public: |
|
1351 |
// JVMTI support |
|
1352 |
jint jvmti_class_status() const; |
|
1353 |
||
46746
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
1354 |
virtual void metaspace_pointers_do(MetaspaceClosure* iter); |
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
1355 |
|
1 | 1356 |
public: |
1357 |
// Printing |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1358 |
#ifndef PRODUCT |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1359 |
void print_on(outputStream* st) const; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1360 |
#endif |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1361 |
void print_value_on(outputStream* st) const; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1362 |
|
4584
e2a449e8cc6f
6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents:
4496
diff
changeset
|
1363 |
void oop_print_value_on(oop obj, outputStream* st); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1364 |
|
4584
e2a449e8cc6f
6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents:
4496
diff
changeset
|
1365 |
#ifndef PRODUCT |
1 | 1366 |
void oop_print_on (oop obj, outputStream* st); |
1367 |
||
1368 |
void print_dependent_nmethods(bool verbose = false); |
|
1369 |
bool is_dependent_nmethod(nmethod* nm); |
|
1370 |
#endif |
|
1371 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1372 |
const char* internal_name() const; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1373 |
|
1 | 1374 |
// Verification |
22794
f1c014ad3754
8027146: Class loading verification failure if GC occurs in Universe::flush_dependents_on
coleenp
parents:
22757
diff
changeset
|
1375 |
void verify_on(outputStream* st); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1376 |
|
1 | 1377 |
void oop_verify_on(oop obj, outputStream* st); |
35917
463d67f86eaa
8079408: Reimplement TraceClassLoading, TraceClassUnloading, and TraceClassLoaderData with Unified Logging.
mockner
parents:
35900
diff
changeset
|
1378 |
|
463d67f86eaa
8079408: Reimplement TraceClassLoading, TraceClassUnloading, and TraceClassLoaderData with Unified Logging.
mockner
parents:
35900
diff
changeset
|
1379 |
// Logging |
46444
677be3444372
8154791: Xlog classload too redundant msgs info/debug
rprotacio
parents:
46415
diff
changeset
|
1380 |
void print_class_load_logging(ClassLoaderData* loader_data, |
677be3444372
8154791: Xlog classload too redundant msgs info/debug
rprotacio
parents:
46415
diff
changeset
|
1381 |
const char* module_name, |
677be3444372
8154791: Xlog classload too redundant msgs info/debug
rprotacio
parents:
46415
diff
changeset
|
1382 |
const ClassFileStream* cfs) const; |
1 | 1383 |
}; |
1384 |
||
1385 |
// for adding methods |
|
1386 |
// UNSET_IDNUM return means no more ids available |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1387 |
inline u2 InstanceKlass::next_method_idnum() { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1388 |
if (_idnum_allocated_count == ConstMethod::MAX_IDNUM) { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1389 |
return ConstMethod::UNSET_IDNUM; // no more ids available |
1 | 1390 |
} else { |
1391 |
return _idnum_allocated_count++; |
|
1392 |
} |
|
1393 |
} |
|
1394 |
||
1395 |
||
1396 |
/* JNIid class for jfieldIDs only */ |
|
13195 | 1397 |
class JNIid: public CHeapObj<mtClass> { |
1 | 1398 |
friend class VMStructs; |
1399 |
private: |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1400 |
Klass* _holder; |
1 | 1401 |
JNIid* _next; |
1402 |
int _offset; |
|
1403 |
#ifdef ASSERT |
|
1404 |
bool _is_static_field_id; |
|
1405 |
#endif |
|
1406 |
||
1407 |
public: |
|
1408 |
// Accessors |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1409 |
Klass* holder() const { return _holder; } |
1 | 1410 |
int offset() const { return _offset; } |
1411 |
JNIid* next() { return _next; } |
|
1412 |
// Constructor |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1413 |
JNIid(Klass* holder, int offset, JNIid* next); |
1 | 1414 |
// Identifier lookup |
1415 |
JNIid* find(int offset); |
|
1416 |
||
8725
8c1e3dd5fe1b
7017732: move static fields into Class to prepare for perm gen removal
never
parents:
8676
diff
changeset
|
1417 |
bool find_local_field(fieldDescriptor* fd) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1418 |
return InstanceKlass::cast(holder())->find_local_field_from_offset(offset(), true, fd); |
8725
8c1e3dd5fe1b
7017732: move static fields into Class to prepare for perm gen removal
never
parents:
8676
diff
changeset
|
1419 |
} |
8c1e3dd5fe1b
7017732: move static fields into Class to prepare for perm gen removal
never
parents:
8676
diff
changeset
|
1420 |
|
1 | 1421 |
static void deallocate(JNIid* id); |
1422 |
// Debugging |
|
1423 |
#ifdef ASSERT |
|
1424 |
bool is_static_field_id() const { return _is_static_field_id; } |
|
1425 |
void set_is_static_field_id() { _is_static_field_id = true; } |
|
1426 |
#endif |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1427 |
void verify(Klass* holder); |
1 | 1428 |
}; |
1429 |
||
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1430 |
// An iterator that's used to access the inner classes indices in the |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1431 |
// InstanceKlass::_inner_classes array. |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1432 |
class InnerClassesIterator : public StackObj { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1433 |
private: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1434 |
Array<jushort>* _inner_classes; |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1435 |
int _length; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1436 |
int _idx; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1437 |
public: |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1438 |
|
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43929
diff
changeset
|
1439 |
InnerClassesIterator(const InstanceKlass* k) { |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1440 |
_inner_classes = k->inner_classes(); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1441 |
if (k->inner_classes() != NULL) { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1442 |
_length = _inner_classes->length(); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1443 |
// The inner class array's length should be the multiple of |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1444 |
// inner_class_next_offset if it only contains the InnerClasses |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1445 |
// attribute data, or it should be |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1446 |
// n*inner_class_next_offset+enclosing_method_attribute_size |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1447 |
// if it also contains the EnclosingMethod data. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1448 |
assert((_length % InstanceKlass::inner_class_next_offset == 0 || |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1449 |
_length % InstanceKlass::inner_class_next_offset == InstanceKlass::enclosing_method_attribute_size), |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1450 |
"just checking"); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1451 |
// Remove the enclosing_method portion if exists. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1452 |
if (_length % InstanceKlass::inner_class_next_offset == InstanceKlass::enclosing_method_attribute_size) { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1453 |
_length -= InstanceKlass::enclosing_method_attribute_size; |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1454 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1455 |
} else { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1456 |
_length = 0; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1457 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1458 |
_idx = 0; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1459 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1460 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1461 |
int length() const { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1462 |
return _length; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1463 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1464 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1465 |
void next() { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1466 |
_idx += InstanceKlass::inner_class_next_offset; |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1467 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1468 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1469 |
bool done() const { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1470 |
return (_idx >= _length); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1471 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1472 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1473 |
u2 inner_class_info_index() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1474 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1475 |
_idx + InstanceKlass::inner_class_inner_class_info_offset); |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1476 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1477 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1478 |
void set_inner_class_info_index(u2 index) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1479 |
_inner_classes->at_put( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1480 |
_idx + InstanceKlass::inner_class_inner_class_info_offset, index); |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1481 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1482 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1483 |
u2 outer_class_info_index() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1484 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1485 |
_idx + InstanceKlass::inner_class_outer_class_info_offset); |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1486 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1487 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1488 |
void set_outer_class_info_index(u2 index) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1489 |
_inner_classes->at_put( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1490 |
_idx + InstanceKlass::inner_class_outer_class_info_offset, index); |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1491 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1492 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1493 |
u2 inner_name_index() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1494 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1495 |
_idx + InstanceKlass::inner_class_inner_name_offset); |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1496 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1497 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1498 |
void set_inner_name_index(u2 index) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1499 |
_inner_classes->at_put( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1500 |
_idx + InstanceKlass::inner_class_inner_name_offset, index); |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1501 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1502 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1503 |
u2 inner_access_flags() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1504 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1505 |
_idx + InstanceKlass::inner_class_access_flags_offset); |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1506 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1507 |
}; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1508 |
|
7397 | 1509 |
#endif // SHARE_VM_OOPS_INSTANCEKLASS_HPP |