author | iklam |
Wed, 13 Nov 2019 16:36:54 -0800 | |
changeset 59070 | 22ee476cc664 |
parent 58537 | 30a9612a657d |
permissions | -rw-r--r-- |
1 | 1 |
/* |
53225
b11483a74e5d
8215575: C2 crash: assert(get_instanceKlass()->is_loaded()) failed: must be at least loaded
coleenp
parents:
52907
diff
changeset
|
2 |
* Copyright (c) 1997, 2019, Oracle and/or its affiliates. All rights reserved. |
1 | 3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
* |
|
5 |
* This code is free software; you can redistribute it and/or modify it |
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
|
7 |
* published by the Free Software Foundation. |
|
8 |
* |
|
9 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
|
10 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
11 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
12 |
* version 2 for more details (a copy is included in the LICENSE file that |
|
13 |
* accompanied this code). |
|
14 |
* |
|
15 |
* You should have received a copy of the GNU General Public License version |
|
16 |
* 2 along with this work; if not, write to the Free Software Foundation, |
|
17 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
18 |
* |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
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 |
||
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
53232
diff
changeset
|
25 |
#ifndef SHARE_OOPS_INSTANCEKLASS_HPP |
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
53232
diff
changeset
|
26 |
#define SHARE_OOPS_INSTANCEKLASS_HPP |
7397 | 27 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
28 |
#include "classfile/classLoaderData.hpp" |
18025 | 29 |
#include "memory/referenceType.hpp" |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
30 |
#include "oops/annotations.hpp" |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
31 |
#include "oops/constMethod.hpp" |
10546 | 32 |
#include "oops/fieldInfo.hpp" |
7397 | 33 |
#include "oops/instanceOop.hpp" |
34 |
#include "oops/klassVtable.hpp" |
|
35 |
#include "runtime/handles.hpp" |
|
36 |
#include "runtime/os.hpp" |
|
37 |
#include "utilities/accessFlags.hpp" |
|
46625 | 38 |
#include "utilities/align.hpp" |
15482
470d0b0c09f1
8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents:
15202
diff
changeset
|
39 |
#include "utilities/macros.hpp" |
50113 | 40 |
#if INCLUDE_JFR |
41 |
#include "jfr/support/jfrKlassExtension.hpp" |
|
42 |
#endif |
|
43 |
||
7397 | 44 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
45 |
// An InstanceKlass is the VM level representation of a Java class. |
1 | 46 |
// It contains all information needed for at class at execution runtime. |
47 |
||
23515
f4872ef5df09
8031820: NPG: Fix remaining references to metadata as oops in comments
coleenp
parents:
22916
diff
changeset
|
48 |
// InstanceKlass embedded field layout (after declared fields): |
1 | 49 |
// [EMBEDDED Java vtable ] size in words = vtable_len |
50 |
// [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
|
51 |
// 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
|
52 |
// 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
|
53 |
// [EMBEDDED implementor of the interface] only exist for interface |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
54 |
// [EMBEDDED unsafe_anonymous_host klass] only exist for an unsafe anonymous class (JSR 292 enabled) |
42650 | 55 |
// [EMBEDDED fingerprint ] only if should_store_fingerprint()==true |
1 | 56 |
|
57 |
||
58 |
// 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
|
59 |
#if INCLUDE_JVMTI |
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
60 |
class BreakpointInfo; |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
61 |
#endif |
34666 | 62 |
class ClassFileParser; |
54347
235883996bc7
8221698: Remove redundant includes from popular header files
iklam
parents:
53904
diff
changeset
|
63 |
class ClassFileStream; |
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; |
52781
436097b038a1
8213565: Crash in DependencyContext::remove_dependent_nmethod
eosterlund
parents:
52356
diff
changeset
|
70 |
class nmethodBucket; |
53149
259c36ef27df
8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents:
52907
diff
changeset
|
71 |
class OopMapCache; |
259c36ef27df
8215731: Move forward class definitions out of globalDefinitions.hpp
coleenp
parents:
52907
diff
changeset
|
72 |
class InterpreterOopMap; |
54347
235883996bc7
8221698: Remove redundant includes from popular header files
iklam
parents:
53904
diff
changeset
|
73 |
class PackageEntry; |
235883996bc7
8221698: Remove redundant includes from popular header files
iklam
parents:
53904
diff
changeset
|
74 |
class ModuleEntry; |
1 | 75 |
|
76 |
// This is used in iterators below. |
|
77 |
class FieldClosure: public StackObj { |
|
78 |
public: |
|
79 |
virtual void do_field(fieldDescriptor* fd) = 0; |
|
80 |
}; |
|
81 |
||
82 |
#ifndef PRODUCT |
|
83 |
// Print fields. |
|
84 |
// If "obj" argument to constructor is NULL, prints static fields, otherwise prints non-static fields. |
|
85 |
class FieldPrinter: public FieldClosure { |
|
86 |
oop _obj; |
|
87 |
outputStream* _st; |
|
88 |
public: |
|
89 |
FieldPrinter(outputStream* st, oop obj = NULL) : _obj(obj), _st(st) {} |
|
90 |
void do_field(fieldDescriptor* fd); |
|
91 |
}; |
|
92 |
#endif // !PRODUCT |
|
93 |
||
49364
601146c66cad
8173070: Remove ValueObj class for allocation subclassing for runtime code
coleenp
parents:
48884
diff
changeset
|
94 |
// Describes where oops are located in instances of this klass. |
601146c66cad
8173070: Remove ValueObj class for allocation subclassing for runtime code
coleenp
parents:
48884
diff
changeset
|
95 |
class OopMapBlock { |
3693 | 96 |
public: |
97 |
// 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
|
98 |
int offset() const { return _offset; } |
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
99 |
void set_offset(int offset) { _offset = offset; } |
3693 | 100 |
|
101 |
// Number of oops in this block. |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
102 |
uint count() const { return _count; } |
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
103 |
void set_count(uint count) { _count = count; } |
3693 | 104 |
|
35898
ddc274f0052f
8145628: hotspot metadata classes shouldn't use HeapWordSize or heap related macros like align_object_size
coleenp
parents:
35877
diff
changeset
|
105 |
// sizeof(OopMapBlock) in words. |
3693 | 106 |
static const int size_in_words() { |
46619
a3919f5e8d2b
8178499: Remove _ptr_ and _size_ infixes from align functions
stefank
parents:
46618
diff
changeset
|
107 |
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
|
108 |
LogBytesPerWord; |
3693 | 109 |
} |
110 |
||
111 |
private: |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
112 |
int _offset; |
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
113 |
uint _count; |
3693 | 114 |
}; |
115 |
||
18940
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
116 |
struct JvmtiCachedClassFileData; |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
117 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
118 |
class InstanceKlass: public Klass { |
1 | 119 |
friend class VMStructs; |
35123
b0b89d83bcf5
8134994: use separate VMStructs databases for SA and JVMCI
twisti
parents:
34195
diff
changeset
|
120 |
friend class JVMCIVMStructs; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
121 |
friend class ClassFileParser; |
14477
95e66ea71f71
6830717: replay of compilations would help with debugging
minqi
parents:
14385
diff
changeset
|
122 |
friend class CompileReplay; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
123 |
|
50752 | 124 |
public: |
125 |
static const KlassID ID = InstanceKlassID; |
|
126 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
127 |
protected: |
50752 | 128 |
InstanceKlass(const ClassFileParser& parser, unsigned kind, KlassID id = ID); |
34666 | 129 |
|
1 | 130 |
public: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
131 |
InstanceKlass() { assert(DumpSharedSpaces || UseSharedSpaces, "only for CDS"); } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
132 |
|
1 | 133 |
// See "The Java Virtual Machine Specification" section 2.16.2-5 for a detailed description |
134 |
// of the class loading & initialization procedure, and the use of the states. |
|
135 |
enum ClassState { |
|
136 |
allocated, // allocated (but not yet linked) |
|
137 |
loaded, // loaded and inserted in class hierarchy (but not linked yet) |
|
138 |
linked, // successfully linked/verified (but not initialized yet) |
|
139 |
being_initialized, // currently running class initializer |
|
140 |
fully_initialized, // initialized (successfull final state) |
|
141 |
initialization_error // error happened during initialization |
|
142 |
}; |
|
143 |
||
15104
f5d78994619f
8005048: NMT: #loaded classes needs to just show the # defined classes
zgu
parents:
14477
diff
changeset
|
144 |
private: |
34666 | 145 |
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
|
146 |
|
1 | 147 |
protected: |
46746
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
148 |
// 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
|
149 |
// must add this field to InstanceKlass::metaspace_pointers_do(). |
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
150 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
151 |
// Annotations for this class |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
152 |
Annotations* _annotations; |
36508 | 153 |
// Package this class is defined in |
154 |
PackageEntry* _package_entry; |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
155 |
// 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
|
156 |
Klass* volatile _array_klasses; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
157 |
// Constant pool for this class. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
158 |
ConstantPool* _constants; |
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
159 |
// 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
|
160 |
// _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
|
161 |
// 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
|
162 |
// [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
|
163 |
// 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
|
164 |
// 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
|
165 |
// 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
|
166 |
// 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
|
167 |
// 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
|
168 |
// 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
|
169 |
// 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
|
170 |
Array<jushort>* _inner_classes; |
1 | 171 |
|
50735
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
172 |
// The NestMembers attribute. An array of shorts, where each is a |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
173 |
// class info index for the class that is a nest member. This data |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
174 |
// has not been validated. |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
175 |
Array<jushort>* _nest_members; |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
176 |
|
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
177 |
// The NestHost attribute. The class info index for the class |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
178 |
// that is the nest-host of this class. This data has not been validated. |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
179 |
jushort _nest_host_index; |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
180 |
|
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
181 |
// Resolved nest-host klass: either true nest-host or self if we are not nested. |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
182 |
// By always being set it makes nest-member access checks simpler. |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
183 |
InstanceKlass* _nest_host; |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
184 |
|
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
185 |
// 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
|
186 |
// 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
|
187 |
// it is stored in the instanceklass as a NULL-terminated UTF-8 string |
34666 | 188 |
const char* _source_debug_extension; |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
189 |
// 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
|
190 |
// if this class is unloaded. |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
191 |
Symbol* _array_name; |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
192 |
|
591
04d2e26e6d69
6703888: Compressed Oops: use the 32-bits gap after klass in a object
kvn
parents:
360
diff
changeset
|
193 |
// 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
|
194 |
// (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
|
195 |
int _nonstatic_field_size; |
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
196 |
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
|
197 |
// 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
|
198 |
// 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
|
199 |
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
|
200 |
// 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
|
201 |
// 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
|
202 |
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
|
203 |
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
|
204 |
u2 _java_fields_count; // The number of declared Java fields |
3693 | 205 |
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
|
206 |
|
35899 | 207 |
int _itable_len; // length of Java itable (in words) |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
208 |
// _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
|
209 |
// _misc_flags. |
11440
dea12ec80745
7129240: backout fix for 7102776 until 7128770 is resolved
dcubed
parents:
11439
diff
changeset
|
210 |
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
|
211 |
bool _is_being_redefined; // used for locking redefinition |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
212 |
|
33151
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
213 |
// The low two bits of _misc_flags contains the kind field. |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
214 |
// This can be used to quickly discriminate among the four kinds of |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
215 |
// InstanceKlass. |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
216 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
217 |
static const unsigned _misc_kind_field_size = 2; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
218 |
static const unsigned _misc_kind_field_pos = 0; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
219 |
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
|
220 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
221 |
static const unsigned _misc_kind_other = 0; // concrete InstanceKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
222 |
static const unsigned _misc_kind_reference = 1; // InstanceRefKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
223 |
static const unsigned _misc_kind_class_loader = 2; // InstanceClassLoaderKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
224 |
static const unsigned _misc_kind_mirror = 3; // InstanceMirrorKlass |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
225 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
226 |
// 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
|
227 |
enum { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
228 |
_misc_rewritten = 1 << 2, // methods rewritten. |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
229 |
_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
|
230 |
_misc_should_verify_class = 1 << 4, // allow caching of preverification |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
231 |
_misc_is_unsafe_anonymous = 1 << 5, // has embedded _unsafe_anonymous_host field |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
232 |
_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
|
233 |
_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
|
234 |
_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
|
235 |
_misc_has_been_redefined = 1 << 9, // class has been redefined |
42650 | 236 |
_misc_has_passed_fingerprint_check = 1 << 10, // when this class was loaded, the fingerprint computed from its |
237 |
// code source was found to be matching the value recorded by AOT. |
|
238 |
_misc_is_scratch_class = 1 << 11, // class is the redefined scratch class |
|
239 |
_misc_is_shared_boot_class = 1 << 12, // defining class loader is boot class loader |
|
240 |
_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
|
241 |
_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
|
242 |
_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
|
243 |
}; |
36508 | 244 |
u2 loader_type_bits() { |
245 |
return _misc_is_shared_boot_class|_misc_is_shared_platform_class|_misc_is_shared_app_class; |
|
246 |
} |
|
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
247 |
u2 _misc_flags; |
1 | 248 |
u2 _minor_version; // minor version number of class file |
249 |
u2 _major_version; // major version number of class file |
|
55254
36cb654a690f
8225141: Better handling of classes in error state in fast class initialization checks
vlivanov
parents:
54347
diff
changeset
|
250 |
Thread* _init_thread; // Pointer to current thread doing initialization (to handle recursive initialization) |
1 | 251 |
OopMapCache* volatile _oop_map_cache; // OopMapCache for all methods in the klass (allocated lazily) |
252 |
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
|
253 |
jmethodID* volatile _methods_jmethod_ids; // jmethodIDs corresponding to method_idnum, or NULL if none |
52781
436097b038a1
8213565: Crash in DependencyContext::remove_dependent_nmethod
eosterlund
parents:
52356
diff
changeset
|
254 |
nmethodBucket* volatile _dep_context; // packed DependencyContext structure |
436097b038a1
8213565: Crash in DependencyContext::remove_dependent_nmethod
eosterlund
parents:
52356
diff
changeset
|
255 |
uint64_t volatile _dep_context_last_cleaned; |
1 | 256 |
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
|
257 |
#if INCLUDE_JVMTI |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
258 |
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
|
259 |
// Linked instanceKlasses of previous versions |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
260 |
InstanceKlass* _previous_versions; |
1 | 261 |
// 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
|
262 |
// JVMTI: cached class file, before retransformable agent modified it in CFLH |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
263 |
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
|
264 |
#endif |
15449
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
265 |
|
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
266 |
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
|
267 |
|
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
268 |
// 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
|
269 |
// 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
|
270 |
// _idnum_allocated_count. |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
271 |
u1 _init_state; // state of class |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
272 |
u1 _reference_type; // reference type |
262003a04c6f
8006280: Need to reorder metadata structures to reduce size (64-bit)
iklam
parents:
15202
diff
changeset
|
273 |
|
49677 | 274 |
u2 _this_class_index; // constant pool entry |
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
275 |
#if INCLUDE_JVMTI |
1 | 276 |
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
|
277 |
#endif |
14385 | 278 |
|
15928
f9d5c6e4107f
8003553: NPG: metaspace objects should be zeroed in constructors
coleenp
parents:
15601
diff
changeset
|
279 |
NOT_PRODUCT(int _verify_count;) // to avoid redundant verifies |
f9d5c6e4107f
8003553: NPG: metaspace objects should be zeroed in constructors
coleenp
parents:
15601
diff
changeset
|
280 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
281 |
// Method array. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
282 |
Array<Method*>* _methods; |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
283 |
// Default Method Array, concrete methods inherited from interfaces |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
284 |
Array<Method*>* _default_methods; |
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
285 |
// Interfaces (InstanceKlass*s) this class declares locally to implement. |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
286 |
Array<InstanceKlass*>* _local_interfaces; |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
287 |
// Interfaces (InstanceKlass*s) this class implements transitively. |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
288 |
Array<InstanceKlass*>* _transitive_interfaces; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
289 |
// 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
|
290 |
Array<int>* _method_ordering; |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
291 |
// Int array containing the vtable_indices for default_methods |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
292 |
// offset matches _default_methods offset |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
293 |
Array<int>* _default_vtable_indices; |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
294 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
295 |
// 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
|
296 |
// [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
|
297 |
// 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
|
298 |
// 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
|
299 |
// 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
|
300 |
// |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
301 |
// 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
|
302 |
// 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
|
303 |
// ... |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
304 |
// 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
|
305 |
// [generic signature index] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
306 |
// [generic signature index] |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
307 |
// ... |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
308 |
Array<u2>* _fields; |
1 | 309 |
|
310 |
// embedded Java vtable follows here |
|
311 |
// embedded Java itables follows here |
|
312 |
// embedded static fields follows here |
|
313 |
// 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
|
314 |
// 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
|
315 |
// 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
|
316 |
// 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
|
317 |
// three cases: |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
318 |
// NULL: no implementor. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
319 |
// 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
|
320 |
// Itself: more than one implementors. |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
321 |
// embedded unsafe_anonymous_host klass follows here |
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
322 |
// The embedded host klass only exists in an unsafe anonymous class for |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
323 |
// 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
|
324 |
// its access privileges to this class also. The host class is either |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
325 |
// named, or a previously loaded unsafe anonymous class. A non-anonymous class |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
326 |
// 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
|
327 |
// 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
|
328 |
// |
1 | 329 |
|
330 |
friend class SystemDictionary; |
|
331 |
||
59070
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
332 |
static bool _disable_method_binary_search; |
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
333 |
|
1 | 334 |
public: |
36508 | 335 |
u2 loader_type() { |
336 |
return _misc_flags & loader_type_bits(); |
|
337 |
} |
|
338 |
||
339 |
bool is_shared_boot_class() const { |
|
340 |
return (_misc_flags & _misc_is_shared_boot_class) != 0; |
|
341 |
} |
|
342 |
bool is_shared_platform_class() const { |
|
343 |
return (_misc_flags & _misc_is_shared_platform_class) != 0; |
|
344 |
} |
|
345 |
bool is_shared_app_class() const { |
|
346 |
return (_misc_flags & _misc_is_shared_app_class) != 0; |
|
347 |
} |
|
348 |
||
50206
adec398d9051
8193332: MetaspaceShared::check_shared_class_loader_type is not used during archive creation
iklam
parents:
50113
diff
changeset
|
349 |
void clear_class_loader_type() { |
adec398d9051
8193332: MetaspaceShared::check_shared_class_loader_type is not used during archive creation
iklam
parents:
50113
diff
changeset
|
350 |
_misc_flags &= ~loader_type_bits(); |
adec398d9051
8193332: MetaspaceShared::check_shared_class_loader_type is not used during archive creation
iklam
parents:
50113
diff
changeset
|
351 |
} |
adec398d9051
8193332: MetaspaceShared::check_shared_class_loader_type is not used during archive creation
iklam
parents:
50113
diff
changeset
|
352 |
|
54347
235883996bc7
8221698: Remove redundant includes from popular header files
iklam
parents:
53904
diff
changeset
|
353 |
void set_class_loader_type(s2 loader_type); |
36508 | 354 |
|
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
355 |
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
|
356 |
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
|
357 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
358 |
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
|
359 |
if (b) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
360 |
_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
|
361 |
} else { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
362 |
_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
|
363 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
364 |
} |
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
365 |
|
1 | 366 |
// field sizes |
367 |
int nonstatic_field_size() const { return _nonstatic_field_size; } |
|
368 |
void set_nonstatic_field_size(int size) { _nonstatic_field_size = size; } |
|
369 |
||
370 |
int static_field_size() const { return _static_field_size; } |
|
371 |
void set_static_field_size(int size) { _static_field_size = size; } |
|
372 |
||
11412
62fe312f32c5
7123315: instanceKlass::_static_oop_field_count and instanceKlass::_java_fields_count should be u2 type.
jiangli
parents:
11407
diff
changeset
|
373 |
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
|
374 |
void set_static_oop_field_count(u2 size) { _static_oop_field_count = size; } |
1 | 375 |
|
376 |
// Java itable |
|
377 |
int itable_length() const { return _itable_len; } |
|
378 |
void set_itable_length(int len) { _itable_len = len; } |
|
379 |
||
380 |
// array klasses |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
381 |
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
|
382 |
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
|
383 |
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
|
384 |
inline void release_set_array_klasses(Klass* k); // store with release semantics |
1 | 385 |
|
386 |
// methods |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
387 |
Array<Method*>* methods() const { return _methods; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
388 |
void set_methods(Array<Method*>* a) { _methods = a; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
389 |
Method* method_with_idnum(int idnum); |
30107
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
390 |
Method* method_with_orig_idnum(int idnum); |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
391 |
Method* method_with_orig_idnum(int idnum, int version); |
1 | 392 |
|
393 |
// method ordering |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
394 |
Array<int>* method_ordering() const { return _method_ordering; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
395 |
void set_method_ordering(Array<int>* m) { _method_ordering = m; } |
34666 | 396 |
void copy_method_ordering(const intArray* m, TRAPS); |
1 | 397 |
|
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
398 |
// default_methods |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
399 |
Array<Method*>* default_methods() const { return _default_methods; } |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
400 |
void set_default_methods(Array<Method*>* a) { _default_methods = a; } |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
401 |
|
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
402 |
// default method vtable_indices |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
403 |
Array<int>* default_vtable_indices() const { return _default_vtable_indices; } |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
404 |
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
|
405 |
Array<int>* create_new_default_vtable_indices(int len, TRAPS); |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
406 |
|
1 | 407 |
// interfaces |
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
408 |
Array<InstanceKlass*>* local_interfaces() const { return _local_interfaces; } |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
409 |
void set_local_interfaces(Array<InstanceKlass*>* a) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
410 |
guarantee(_local_interfaces == NULL || a == NULL, "Just checking"); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
411 |
_local_interfaces = a; } |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
412 |
|
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
413 |
Array<InstanceKlass*>* transitive_interfaces() const { return _transitive_interfaces; } |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
414 |
void set_transitive_interfaces(Array<InstanceKlass*>* a) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
415 |
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
|
416 |
_transitive_interfaces = a; |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
417 |
} |
1 | 418 |
|
10546 | 419 |
private: |
420 |
friend class fieldDescriptor; |
|
421 |
FieldInfo* field(int index) const { return FieldInfo::from_field_array(_fields, index); } |
|
422 |
||
423 |
public: |
|
424 |
int field_offset (int index) const { return field(index)->offset(); } |
|
425 |
int field_access_flags(int index) const { return field(index)->access_flags(); } |
|
426 |
Symbol* field_name (int index) const { return field(index)->name(constants()); } |
|
427 |
Symbol* field_signature (int index) const { return field(index)->signature(constants()); } |
|
428 |
||
429 |
// 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
|
430 |
int java_fields_count() const { return (int)_java_fields_count; } |
10546 | 431 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
432 |
Array<u2>* fields() const { return _fields; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
433 |
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
|
434 |
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
|
435 |
_fields = f; |
10546 | 436 |
_java_fields_count = java_fields_count; |
1 | 437 |
} |
438 |
||
439 |
// inner classes |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
440 |
Array<u2>* inner_classes() const { return _inner_classes; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
441 |
void set_inner_classes(Array<u2>* f) { _inner_classes = f; } |
1 | 442 |
|
50735
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
443 |
// nest members |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
444 |
Array<u2>* nest_members() const { return _nest_members; } |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
445 |
void set_nest_members(Array<u2>* m) { _nest_members = m; } |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
446 |
|
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
447 |
// nest-host index |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
448 |
jushort nest_host_index() const { return _nest_host_index; } |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
449 |
void set_nest_host_index(u2 i) { _nest_host_index = i; } |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
450 |
|
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
451 |
private: |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
452 |
// Called to verify that k is a member of this nest - does not look at k's nest-host |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
453 |
bool has_nest_member(InstanceKlass* k, TRAPS) const; |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
454 |
public: |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
455 |
// Returns nest-host class, resolving and validating it if needed |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
456 |
// Returns NULL if an exception occurs during loading, or validation fails |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
457 |
InstanceKlass* nest_host(Symbol* validationException, TRAPS); |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
458 |
// Check if this klass is a nestmate of k - resolves this nest-host and k's |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
459 |
bool has_nestmate_access_to(InstanceKlass* k, TRAPS); |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
460 |
|
1 | 461 |
enum InnerClassAttributeOffset { |
462 |
// From http://mirror.eng/products/jdk/1.1/docs/guide/innerclasses/spec/innerclasses.doc10.html#18814 |
|
463 |
inner_class_inner_class_info_offset = 0, |
|
464 |
inner_class_outer_class_info_offset = 1, |
|
465 |
inner_class_inner_name_offset = 2, |
|
466 |
inner_class_access_flags_offset = 3, |
|
467 |
inner_class_next_offset = 4 |
|
468 |
}; |
|
469 |
||
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
470 |
enum EnclosingMethodAttributeOffset { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
471 |
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
|
472 |
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
|
473 |
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
|
474 |
}; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
475 |
|
2264
55d0115a54fe
4766230: Hotspot vtable inconsistencies cause core dumps. 6579515. 6582242.
acorn
parents:
1550
diff
changeset
|
476 |
// method override check |
33593
60764a78fa5c
8140274: methodHandles and constantPoolHandles should be passed as const references
coleenp
parents:
33576
diff
changeset
|
477 |
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
|
478 |
|
1 | 479 |
// package |
36508 | 480 |
PackageEntry* package() const { return _package_entry; } |
481 |
ModuleEntry* module() const; |
|
482 |
bool in_unnamed_package() const { return (_package_entry == NULL); } |
|
483 |
void set_package(PackageEntry* p) { _package_entry = p; } |
|
484 |
void set_package(ClassLoaderData* loader_data, TRAPS); |
|
34666 | 485 |
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
|
486 |
bool is_same_class_package(oop other_class_loader, const Symbol* other_class_name) const; |
1 | 487 |
|
30222
bfe6be3c4ef8
8057919: Class.getSimpleName() should work for non-JLS compliant class names
vlivanov
parents:
29698
diff
changeset
|
488 |
// find an enclosing class |
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
489 |
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
|
490 |
|
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
491 |
// Find InnerClasses attribute and return outer_class_info_index & inner_name_index. |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
492 |
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
|
493 |
|
40016 | 494 |
private: |
495 |
// Check prohibited package ("java/" only loadable by boot or platform loaders) |
|
496 |
static void check_prohibited_package(Symbol* class_name, |
|
50634
c349d409262a
8202605: Standardize on ClassLoaderData::loader_name() throughout the VM to obtain a class loader's name
lfoltan
parents:
50206
diff
changeset
|
497 |
ClassLoaderData* loader_data, |
40016 | 498 |
TRAPS); |
499 |
public: |
|
1 | 500 |
// initialization state |
501 |
bool is_loaded() const { return _init_state >= loaded; } |
|
502 |
bool is_linked() const { return _init_state >= linked; } |
|
503 |
bool is_initialized() const { return _init_state == fully_initialized; } |
|
504 |
bool is_not_initialized() const { return _init_state < being_initialized; } |
|
505 |
bool is_being_initialized() const { return _init_state == being_initialized; } |
|
506 |
bool is_in_error_state() const { return _init_state == initialization_error; } |
|
507 |
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
|
508 |
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
|
509 |
bool is_rewritten() const { return (_misc_flags & _misc_rewritten) != 0; } |
3820
0a8fbbe180db
6830542: Performance: JVM_DefineClass already verified.
acorn
parents:
2570
diff
changeset
|
510 |
|
0a8fbbe180db
6830542: Performance: JVM_DefineClass already verified.
acorn
parents:
2570
diff
changeset
|
511 |
// 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
|
512 |
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
|
513 |
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
|
514 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
515 |
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
|
516 |
if (value) { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
517 |
_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
|
518 |
} else { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
519 |
_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
|
520 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
521 |
} |
1 | 522 |
|
523 |
// marking |
|
11440
dea12ec80745
7129240: backout fix for 7102776 until 7128770 is resolved
dcubed
parents:
11439
diff
changeset
|
524 |
bool is_marked_dependent() const { return _is_marked_dependent; } |
dea12ec80745
7129240: backout fix for 7102776 until 7128770 is resolved
dcubed
parents:
11439
diff
changeset
|
525 |
void set_is_marked_dependent(bool value) { _is_marked_dependent = value; } |
1 | 526 |
|
527 |
// initialization (virtuals from Klass) |
|
528 |
bool should_be_initialized() const; // means that initialize should be called |
|
529 |
void initialize(TRAPS); |
|
530 |
void link_class(TRAPS); |
|
531 |
bool link_class_or_fail(TRAPS); // returns false on failure |
|
532 |
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
|
533 |
void link_methods(TRAPS); |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43929
diff
changeset
|
534 |
Method* class_initializer() const; |
1 | 535 |
|
536 |
// set the class to initialized if no static initializer is present |
|
537 |
void eager_initialize(Thread *thread); |
|
538 |
||
539 |
// reference type |
|
11729
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
540 |
ReferenceType reference_type() const { return (ReferenceType)_reference_type; } |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
541 |
void set_reference_type(ReferenceType t) { |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
542 |
assert(t == (u1)t, "overflow"); |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
543 |
_reference_type = (u1)t; |
77f7d412d0a1
7132690: InstanceKlass:_reference_type should be u1 type
jiangli
parents:
11440
diff
changeset
|
544 |
} |
1 | 545 |
|
49677 | 546 |
// this class cp index |
547 |
u2 this_class_index() const { return _this_class_index; } |
|
548 |
void set_this_class_index(u2 index) { _this_class_index = index; } |
|
549 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
550 |
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
|
551 |
|
1 | 552 |
// find local field, returns true if found |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
553 |
bool find_local_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const; |
1 | 554 |
// 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
|
555 |
Klass* find_interface_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const; |
1 | 556 |
// 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
|
557 |
Klass* find_field(Symbol* name, Symbol* sig, fieldDescriptor* fd) const; |
1 | 558 |
// 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
|
559 |
Klass* find_field(Symbol* name, Symbol* sig, bool is_static, fieldDescriptor* fd) const; |
1 | 560 |
|
561 |
// find a non-static or static field given its offset within the class. |
|
562 |
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
|
563 |
return instanceOopDesc::contains_field_offset(offset, nonstatic_field_size()); |
1 | 564 |
} |
565 |
||
566 |
bool find_local_field_from_offset(int offset, bool is_static, fieldDescriptor* fd) const; |
|
567 |
bool find_field_from_offset(int offset, bool is_static, fieldDescriptor* fd) const; |
|
568 |
||
59070
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
569 |
private: |
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
570 |
static int quick_search(const Array<Method*>* methods, const Symbol* name); |
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
571 |
|
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
572 |
public: |
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
573 |
static void disable_method_binary_search() { |
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
574 |
_disable_method_binary_search = true; |
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
575 |
} |
22ee476cc664
8231610: Relocate the CDS archive if it cannot be mapped to the requested address
iklam
parents:
58537
diff
changeset
|
576 |
|
1 | 577 |
// find a local method (returns NULL if not found) |
34666 | 578 |
Method* find_method(const Symbol* name, const Symbol* signature) const; |
579 |
static Method* find_method(const Array<Method*>* methods, |
|
580 |
const Symbol* name, |
|
581 |
const Symbol* signature); |
|
28514 | 582 |
|
583 |
// find a local method, but skip static methods |
|
50735
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
584 |
Method* find_instance_method(const Symbol* name, const Symbol* signature, |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
585 |
PrivateLookupMode private_mode = find_private) const; |
34666 | 586 |
static Method* find_instance_method(const Array<Method*>* methods, |
587 |
const Symbol* name, |
|
50735
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
588 |
const Symbol* signature, |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
589 |
PrivateLookupMode private_mode = find_private); |
1 | 590 |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
591 |
// find a local method (returns NULL if not found) |
34666 | 592 |
Method* find_local_method(const Symbol* name, |
593 |
const Symbol* signature, |
|
594 |
OverpassLookupMode overpass_mode, |
|
595 |
StaticLookupMode static_mode, |
|
596 |
PrivateLookupMode private_mode) const; |
|
28514 | 597 |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
598 |
// find a local method from given methods array (returns NULL if not found) |
34666 | 599 |
static Method* find_local_method(const Array<Method*>* methods, |
600 |
const Symbol* name, |
|
601 |
const Symbol* signature, |
|
602 |
OverpassLookupMode overpass_mode, |
|
603 |
StaticLookupMode static_mode, |
|
604 |
PrivateLookupMode private_mode); |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
605 |
|
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
606 |
// find a local method index in methods or default_methods (returns -1 if not found) |
34666 | 607 |
static int find_method_index(const Array<Method*>* methods, |
608 |
const Symbol* name, |
|
609 |
const Symbol* signature, |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
610 |
OverpassLookupMode overpass_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
611 |
StaticLookupMode static_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
612 |
PrivateLookupMode private_mode); |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
613 |
|
1 | 614 |
// lookup operation (returns NULL if not found) |
34666 | 615 |
Method* uncached_lookup_method(const Symbol* name, |
616 |
const Symbol* signature, |
|
50735
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
617 |
OverpassLookupMode overpass_mode, |
2f2af62dfac7
8010319: Implementation of JEP 181: Nest-Based Access Control
dholmes
parents:
50634
diff
changeset
|
618 |
PrivateLookupMode private_mode = find_private) const; |
1 | 619 |
|
620 |
// lookup a method in all the interfaces that this class implements |
|
621 |
// (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
|
622 |
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
|
623 |
|
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
624 |
// lookup a method in local defaults then in all interfaces |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
625 |
// (returns NULL if not found) |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
626 |
Method* lookup_method_in_ordered_interfaces(Symbol* name, Symbol* signature) const; |
1 | 627 |
|
14385 | 628 |
// Find method indices by name. If a method with the specified name is |
629 |
// found the index to the first method is returned, and 'end' is filled in |
|
630 |
// with the index of first non-name-matching method. If no method is found |
|
631 |
// -1 is returned. |
|
34666 | 632 |
int find_method_by_name(const Symbol* name, int* end) const; |
633 |
static int find_method_by_name(const Array<Method*>* methods, |
|
634 |
const Symbol* name, int* end); |
|
14385 | 635 |
|
1 | 636 |
// constant pool |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
637 |
ConstantPool* constants() const { return _constants; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
638 |
void set_constants(ConstantPool* c) { _constants = c; } |
1 | 639 |
|
640 |
// protection domain |
|
17826
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
641 |
oop protection_domain() const; |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
642 |
|
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
643 |
// signers |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
644 |
objArrayOop signers() const; |
1 | 645 |
|
1550
be2fc37a817f
6653858: dynamic languages need to be able to load anonymous classes
jrose
parents:
1388
diff
changeset
|
646 |
// host class |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
647 |
InstanceKlass* unsafe_anonymous_host() const { |
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
648 |
InstanceKlass** hk = adr_unsafe_anonymous_host(); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
649 |
if (hk == NULL) { |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
650 |
assert(!is_unsafe_anonymous(), "Unsafe 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
|
651 |
return NULL; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
652 |
} else { |
22757
b2cbb3680b4f
8033792: AltHashing used jint for imprecise bit shifting
minqi
parents:
22232
diff
changeset
|
653 |
assert(*hk != NULL, "host klass should always be set if the address is not null"); |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
654 |
assert(is_unsafe_anonymous(), "Only unsafe 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
|
655 |
return *hk; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
656 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
657 |
} |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
658 |
void set_unsafe_anonymous_host(const InstanceKlass* host) { |
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
659 |
assert(is_unsafe_anonymous(), "not unsafe anonymous"); |
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
660 |
const InstanceKlass** addr = (const InstanceKlass **)adr_unsafe_anonymous_host(); |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
661 |
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
|
662 |
if (addr != NULL) { |
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
663 |
*addr = host; |
5ce4f526e0ba
8008750: [partfait] Null pointer deference in hotspot/src/share/vm/oops/instanceKlass.hpp
morris
parents:
15601
diff
changeset
|
664 |
} |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
665 |
} |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
666 |
bool is_unsafe_anonymous() const { |
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
667 |
return (_misc_flags & _misc_is_unsafe_anonymous) != 0; |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
668 |
} |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
669 |
void set_is_unsafe_anonymous(bool value) { |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
670 |
if (value) { |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
671 |
_misc_flags |= _misc_is_unsafe_anonymous; |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
672 |
} else { |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
673 |
_misc_flags &= ~_misc_is_unsafe_anonymous; |
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
674 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
675 |
} |
1550
be2fc37a817f
6653858: dynamic languages need to be able to load anonymous classes
jrose
parents:
1388
diff
changeset
|
676 |
|
15193
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
677 |
bool is_contended() const { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
678 |
return (_misc_flags & _misc_is_contended) != 0; |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
679 |
} |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
680 |
void set_is_contended(bool value) { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
681 |
if (value) { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
682 |
_misc_flags |= _misc_is_contended; |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
683 |
} else { |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
684 |
_misc_flags &= ~_misc_is_contended; |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
685 |
} |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
686 |
} |
8e6b5694267f
8003985: Support @Contended Annotation - JEP 142
jwilhelm
parents:
15105
diff
changeset
|
687 |
|
1 | 688 |
// 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
|
689 |
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
|
690 |
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
|
691 |
(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
|
692 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
693 |
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
|
694 |
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
|
695 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
696 |
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
|
697 |
_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
|
698 |
} |
1 | 699 |
|
700 |
// minor and major version numbers of class file |
|
701 |
u2 minor_version() const { return _minor_version; } |
|
702 |
void set_minor_version(u2 minor_version) { _minor_version = minor_version; } |
|
703 |
u2 major_version() const { return _major_version; } |
|
704 |
void set_major_version(u2 major_version) { _major_version = major_version; } |
|
705 |
||
706 |
// source debug extension |
|
34666 | 707 |
const char* source_debug_extension() const { return _source_debug_extension; } |
708 |
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
|
709 |
|
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
710 |
// symbol unloading support (refcount already added) |
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
711 |
Symbol* array_name() { return _array_name; } |
15928
f9d5c6e4107f
8003553: NPG: metaspace objects should be zeroed in constructors
coleenp
parents:
15601
diff
changeset
|
712 |
void set_array_name(Symbol* name) { assert(_array_name == NULL || name == NULL, "name already created"); _array_name = name; } |
1 | 713 |
|
714 |
// nonstatic oop-map blocks |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
715 |
static int nonstatic_oop_map_size(unsigned int oop_map_count) { |
3693 | 716 |
return oop_map_count * OopMapBlock::size_in_words(); |
717 |
} |
|
3694
942b7bc7f28c
6845368: large objects cause a crash or unexpected exception
jcoomes
parents:
3693
diff
changeset
|
718 |
unsigned int nonstatic_oop_map_count() const { |
3693 | 719 |
return _nonstatic_oop_map_size / OopMapBlock::size_in_words(); |
720 |
} |
|
721 |
int nonstatic_oop_map_size() const { return _nonstatic_oop_map_size; } |
|
722 |
void set_nonstatic_oop_map_size(int words) { |
|
723 |
_nonstatic_oop_map_size = words; |
|
724 |
} |
|
1 | 725 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
726 |
#if INCLUDE_JVMTI |
38309
9b8e9c373740
8155951: VM crash in nsk/jvmti/RedefineClasses/StressRedefine: assert failed: Corrupted constant pool
coleenp
parents:
38192
diff
changeset
|
727 |
// 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
|
728 |
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
|
729 |
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
|
730 |
|
1 | 731 |
// RedefineClasses() support for previous versions: |
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43929
diff
changeset
|
732 |
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
|
733 |
void purge_previous_version_list(); |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
734 |
|
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
735 |
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
|
736 |
#else |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
737 |
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
|
738 |
#endif |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
739 |
|
30107
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
740 |
InstanceKlass* get_klass_version(int version) { |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
741 |
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
|
742 |
if (ik->constants()->version() == version) { |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
743 |
return ik; |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
744 |
} |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
745 |
} |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
746 |
return NULL; |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
747 |
} |
e3d259b825a1
8067662: "java.lang.NullPointerException: Method name is null" from StackTraceElement.<init>
sspitsyn
parents:
29576
diff
changeset
|
748 |
|
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
749 |
bool has_been_redefined() const { |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
750 |
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
|
751 |
} |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
752 |
void set_has_been_redefined() { |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
753 |
_misc_flags |= _misc_has_been_redefined; |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
754 |
} |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
755 |
|
42650 | 756 |
bool has_passed_fingerprint_check() const { |
757 |
return (_misc_flags & _misc_has_passed_fingerprint_check) != 0; |
|
758 |
} |
|
759 |
void set_has_passed_fingerprint_check(bool b) { |
|
760 |
if (b) { |
|
761 |
_misc_flags |= _misc_has_passed_fingerprint_check; |
|
762 |
} else { |
|
763 |
_misc_flags &= ~_misc_has_passed_fingerprint_check; |
|
764 |
} |
|
765 |
} |
|
766 |
bool supers_have_passed_fingerprint_checks(); |
|
767 |
||
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
768 |
static bool should_store_fingerprint(bool is_unsafe_anonymous); |
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
769 |
bool should_store_fingerprint() const { return should_store_fingerprint(is_unsafe_anonymous()); } |
42650 | 770 |
bool has_stored_fingerprint() const; |
771 |
uint64_t get_stored_fingerprint() const; |
|
772 |
void store_fingerprint(uint64_t fingerprint); |
|
773 |
||
29576
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
774 |
bool is_scratch_class() const { |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
775 |
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
|
776 |
} |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
777 |
|
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
778 |
void set_is_scratch_class() { |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
779 |
_misc_flags |= _misc_is_scratch_class; |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
780 |
} |
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
781 |
|
46505
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
782 |
bool has_resolved_methods() const { |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
783 |
return (_misc_flags & _misc_has_resolved_methods) != 0; |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
784 |
} |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
785 |
|
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
786 |
void set_has_resolved_methods() { |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
787 |
_misc_flags |= _misc_has_resolved_methods; |
fd4bc78630b1
8174749: Use hash table/oops for MemberName table
coleenp
parents:
46502
diff
changeset
|
788 |
} |
33151
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
789 |
private: |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
790 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
791 |
void set_kind(unsigned kind) { |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
792 |
assert(kind <= _misc_kind_field_mask, "Invalid InstanceKlass kind"); |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
793 |
unsigned fmask = _misc_kind_field_mask << _misc_kind_field_pos; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
794 |
unsigned flags = _misc_flags & ~fmask; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
795 |
_misc_flags = (flags | (kind << _misc_kind_field_pos)); |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
796 |
} |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
797 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
798 |
bool is_kind(unsigned desired) const { |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
799 |
unsigned kind = (_misc_flags >> _misc_kind_field_pos) & _misc_kind_field_mask; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
800 |
return kind == desired; |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
801 |
} |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
802 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
803 |
public: |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
804 |
|
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
805 |
// 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
|
806 |
bool is_other_instance_klass() const { return is_kind(_misc_kind_other); } |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
807 |
bool is_reference_instance_klass() const { return is_kind(_misc_kind_reference); } |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
808 |
bool is_mirror_instance_klass() const { return is_kind(_misc_kind_mirror); } |
686d694f5c6a
8138659: Speed up InstanceKlass subclass discrimination
kbarrett
parents:
32606
diff
changeset
|
809 |
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
|
810 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
811 |
#if INCLUDE_JVMTI |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
812 |
|
1 | 813 |
void init_previous_versions() { |
814 |
_previous_versions = NULL; |
|
815 |
} |
|
816 |
||
29576
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
817 |
private: |
40927
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
818 |
static bool _has_previous_versions; |
29576
c223b0a9872e
8061205: MetadataOnStackMark only needs to walk code cache during class redefinition
coleenp
parents:
29316
diff
changeset
|
819 |
public: |
40927
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
820 |
static void purge_previous_versions(InstanceKlass* ik) { |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
821 |
if (ik->has_been_redefined()) { |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
822 |
ik->purge_previous_version_list(); |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
823 |
} |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
824 |
} |
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
825 |
|
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
826 |
static bool has_previous_versions_and_reset(); |
51338
aa3bfacc912c
8208677: Move inner metaspace cleaning out of class unloading
coleenp
parents:
51329
diff
changeset
|
827 |
static bool has_previous_versions() { return _has_previous_versions; } |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
828 |
|
1 | 829 |
// 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
|
830 |
void set_cached_class_file(JvmtiCachedClassFileData *data) { |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
831 |
_cached_class_file = data; |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
832 |
} |
41182 | 833 |
JvmtiCachedClassFileData * get_cached_class_file(); |
18940
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
834 |
jint get_cached_class_file_len(); |
d39d4765e6cb
8020309: Eliminate InstanceKlass::_cached_class_file_len.
jiangli
parents:
18687
diff
changeset
|
835 |
unsigned char * get_cached_class_file_bytes(); |
1 | 836 |
|
837 |
// JVMTI: Support for caching of field indices, types, and offsets |
|
838 |
void set_jvmti_cached_class_field_map(JvmtiCachedClassFieldMap* descriptor) { |
|
839 |
_jvmti_cached_class_field_map = descriptor; |
|
840 |
} |
|
841 |
JvmtiCachedClassFieldMap* jvmti_cached_class_field_map() const { |
|
842 |
return _jvmti_cached_class_field_map; |
|
843 |
} |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
844 |
#else // INCLUDE_JVMTI |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
845 |
|
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
846 |
static void purge_previous_versions(InstanceKlass* ik) { return; }; |
40927
59f3c8a69541
8165246: [REDO] InstanceKlass::_previous_version_count goes negative
coleenp
parents:
40923
diff
changeset
|
847 |
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
|
848 |
|
39995 | 849 |
void set_cached_class_file(JvmtiCachedClassFileData *data) { |
850 |
assert(data == NULL, "unexpected call with JVMTI disabled"); |
|
851 |
} |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
852 |
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
|
853 |
|
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
854 |
#endif // INCLUDE_JVMTI |
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
855 |
|
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
856 |
bool has_nonstatic_concrete_methods() const { |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
857 |
return (_misc_flags & _misc_has_nonstatic_concrete_methods) != 0; |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
858 |
} |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
859 |
void set_has_nonstatic_concrete_methods(bool b) { |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
860 |
if (b) { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
861 |
_misc_flags |= _misc_has_nonstatic_concrete_methods; |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
862 |
} else { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
863 |
_misc_flags &= ~_misc_has_nonstatic_concrete_methods; |
15199
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
864 |
} |
f6ca17e14c5f
8005895: Inefficient InstanceKlass field packing wasts memory.
jiangli
parents:
15105
diff
changeset
|
865 |
} |
14385 | 866 |
|
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
867 |
bool declares_nonstatic_concrete_methods() const { |
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
868 |
return (_misc_flags & _misc_declares_nonstatic_concrete_methods) != 0; |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
869 |
} |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
870 |
void set_declares_nonstatic_concrete_methods(bool b) { |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
871 |
if (b) { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
872 |
_misc_flags |= _misc_declares_nonstatic_concrete_methods; |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
873 |
} else { |
41669
2091069b6851
8081800: AbstractMethodError when evaluating a private method in an interface via debugger
dholmes
parents:
41182
diff
changeset
|
874 |
_misc_flags &= ~_misc_declares_nonstatic_concrete_methods; |
27402
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
875 |
} |
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
876 |
} |
5c4675ddc00c
8043275: Fix interface initialization for default methods.
acorn
parents:
26558
diff
changeset
|
877 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
878 |
// for adding methods, ConstMethod::UNSET_IDNUM means no more ids available |
1 | 879 |
inline u2 next_method_idnum(); |
880 |
void set_initial_method_idnum(u2 value) { _idnum_allocated_count = value; } |
|
881 |
||
882 |
// generics support |
|
19326
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
883 |
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
|
884 |
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
|
885 |
(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
|
886 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
887 |
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
|
888 |
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
|
889 |
} |
14cb6cf26a96
8021948: Change InstanceKlass::_source_file_name and _generic_signature from Symbol* to constant pool indexes.
jiangli
parents:
18940
diff
changeset
|
890 |
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
|
891 |
_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
|
892 |
} |
8076
96d498ec7ae1
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
7397
diff
changeset
|
893 |
|
34666 | 894 |
u2 enclosing_method_data(int offset) const; |
895 |
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
|
896 |
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
|
897 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
898 |
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
|
899 |
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
|
900 |
} |
1 | 901 |
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
|
902 |
u2 method_index); |
1 | 903 |
|
904 |
// jmethodID support |
|
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
905 |
jmethodID get_jmethod_id(const methodHandle& method_h); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
906 |
jmethodID get_jmethod_id_fetch_or_update(size_t idnum, |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
907 |
jmethodID new_id, jmethodID* new_jmeths, |
3824
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
908 |
jmethodID* to_dealloc_id_p, |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
909 |
jmethodID** to_dealloc_jmeths_p); |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
910 |
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
|
911 |
size_t *length_p, jmethodID* id_p); |
27478 | 912 |
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
|
913 |
jmethodID jmethod_id_or_null(Method* method); |
1 | 914 |
|
915 |
// annotations support |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
916 |
Annotations* annotations() const { return _annotations; } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
917 |
void set_annotations(Annotations* anno) { _annotations = anno; } |
15601 | 918 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
919 |
AnnotationArray* class_annotations() const { |
15601 | 920 |
return (_annotations != NULL) ? _annotations->class_annotations() : NULL; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
921 |
} |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
922 |
Array<AnnotationArray*>* fields_annotations() const { |
15601 | 923 |
return (_annotations != NULL) ? _annotations->fields_annotations() : NULL; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
924 |
} |
15601 | 925 |
AnnotationArray* class_type_annotations() const { |
926 |
return (_annotations != NULL) ? _annotations->class_type_annotations() : NULL; |
|
15097
9db149412e0e
8004823: Add VM support for type annotation reflection
stefank
parents:
14816
diff
changeset
|
927 |
} |
15601 | 928 |
Array<AnnotationArray*>* fields_type_annotations() const { |
929 |
return (_annotations != NULL) ? _annotations->fields_type_annotations() : NULL; |
|
930 |
} |
|
1 | 931 |
// allocation |
932 |
instanceOop allocate_instance(TRAPS); |
|
933 |
||
934 |
// additional member function to return a handle |
|
49393 | 935 |
instanceHandle allocate_instance_handle(TRAPS); |
1 | 936 |
|
937 |
objArrayOop allocate_objArray(int n, int length, TRAPS); |
|
938 |
// Helper function |
|
939 |
static instanceOop register_finalizer(instanceOop i, TRAPS); |
|
940 |
||
941 |
// Check whether reflection/jni/jvm code is allowed to instantiate this class; |
|
942 |
// if not, throw either an Error or an Exception. |
|
943 |
virtual void check_valid_for_instantiation(bool throwError, TRAPS); |
|
944 |
||
945 |
// initialization |
|
946 |
void call_class_initializer(TRAPS); |
|
947 |
void set_initialization_state_and_notify(ClassState state, TRAPS); |
|
948 |
||
949 |
// OopMapCache support |
|
950 |
OopMapCache* oop_map_cache() { return _oop_map_cache; } |
|
951 |
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
|
952 |
void mask_for(const methodHandle& method, int bci, InterpreterOopMap* entry); |
1 | 953 |
|
954 |
// JNI identifier support (for static fields - for jni performance) |
|
955 |
JNIid* jni_ids() { return _jni_ids; } |
|
956 |
void set_jni_ids(JNIid* ids) { _jni_ids = ids; } |
|
957 |
JNIid* jni_id_for(int offset); |
|
958 |
||
959 |
// maintenance of deoptimization dependencies |
|
34195
89011d12ebd3
8139595: MethodHandles::remove_dependent_nmethod is not MT safe
vlivanov
parents:
33611
diff
changeset
|
960 |
inline DependencyContext dependencies(); |
36300
5b47f168b948
7177745: JSR292: Many Callsite relinkages cause target method to always run in interpreter mode
vlivanov
parents:
35917
diff
changeset
|
961 |
int mark_dependent_nmethods(KlassDepChange& changes); |
1 | 962 |
void add_dependent_nmethod(nmethod* nm); |
52781
436097b038a1
8213565: Crash in DependencyContext::remove_dependent_nmethod
eosterlund
parents:
52356
diff
changeset
|
963 |
void remove_dependent_nmethod(nmethod* nm); |
436097b038a1
8213565: Crash in DependencyContext::remove_dependent_nmethod
eosterlund
parents:
52356
diff
changeset
|
964 |
void clean_dependency_context(); |
1 | 965 |
|
966 |
// On-stack replacement support |
|
967 |
nmethod* osr_nmethods_head() const { return _osr_nmethods_head; }; |
|
968 |
void set_osr_nmethods_head(nmethod* h) { _osr_nmethods_head = h; }; |
|
969 |
void add_osr_nmethod(nmethod* n); |
|
36802
18b1db5a7e70
8023191: OSR nmethods should be flushed to free space in CodeCache
thartmann
parents:
36404
diff
changeset
|
970 |
bool remove_osr_nmethod(nmethod* n); |
27434
b4b185d05bb5
8061817: Whitebox.deoptimizeMethod() does not deoptimize all OSR versions of method
thartmann
parents:
26558
diff
changeset
|
971 |
int mark_osr_nmethods(const Method* m); |
17370
59a0620561fa
8003557: NPG: Klass* const k should be const Klass* k.
minqi
parents:
17078
diff
changeset
|
972 |
nmethod* lookup_osr_nmethod(const Method* m, int bci, int level, bool match_level) const; |
1 | 973 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
974 |
#if INCLUDE_JVMTI |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
975 |
// Breakpoint support (see methods on Method* for details) |
1 | 976 |
BreakpointInfo* breakpoints() const { return _breakpoints; }; |
977 |
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
|
978 |
#endif |
1 | 979 |
|
980 |
// support for stub routines |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
981 |
static ByteSize init_state_offset() { return in_ByteSize(offset_of(InstanceKlass, _init_state)); } |
50113 | 982 |
JFR_ONLY(DEFINE_KLASS_TRACE_ID_OFFSET;) |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
983 |
static ByteSize init_thread_offset() { return in_ByteSize(offset_of(InstanceKlass, _init_thread)); } |
1 | 984 |
|
985 |
// subclass/subinterface checks |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
986 |
bool implements_interface(Klass* k) const; |
21768
b7dba4cde1c6
8026065: InterfaceMethodref for invokespecial must name a direct superinterface
hseigel
parents:
21079
diff
changeset
|
987 |
bool is_same_or_direct_interface(Klass* k) const; |
1 | 988 |
|
24828
dd5406c950a1
6904403: assert(f == k->has_finalizer(),"inconsistent has_finalizer") with debug VM
dsamersoff
parents:
23999
diff
changeset
|
989 |
#ifdef ASSERT |
dd5406c950a1
6904403: assert(f == k->has_finalizer(),"inconsistent has_finalizer") with debug VM
dsamersoff
parents:
23999
diff
changeset
|
990 |
// check whether this class or one of its superclasses was redefined |
34666 | 991 |
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
|
992 |
#endif |
dd5406c950a1
6904403: assert(f == k->has_finalizer(),"inconsistent has_finalizer") with debug VM
dsamersoff
parents:
23999
diff
changeset
|
993 |
|
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
994 |
// Access to the implementor of an interface. |
52356
19c4a3eec4d7
8213211: [BACKOUT] Allow Klass::_subklass and _next_sibling to have unloaded classes
coleenp
parents:
52311
diff
changeset
|
995 |
Klass* implementor() const; |
51379
802f7e5e7e6b
8207924: serviceability/sa/TestUniverse.java#id0 intermittently fails with assert(get_instanceKlass()->is_loaded()) failed: must be at least loaded
coleenp
parents:
51338
diff
changeset
|
996 |
void set_implementor(Klass* k); |
802f7e5e7e6b
8207924: serviceability/sa/TestUniverse.java#id0 intermittently fails with assert(get_instanceKlass()->is_loaded()) failed: must be at least loaded
coleenp
parents:
51338
diff
changeset
|
997 |
int nof_implementors() const; |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
998 |
void add_implementor(Klass* k); // k is a new class that implements this interface |
1 | 999 |
void init_implementor(); // initialize |
1000 |
||
1001 |
// link this class into the implementors list of every interface it implements |
|
1002 |
void process_interfaces(Thread *thread); |
|
1003 |
||
1004 |
// virtual operations from Klass |
|
49948
ff8dbb56740a
8200466: Revisit the setting of _transitive_interfaces in InstanceKlass
ccheung
parents:
49821
diff
changeset
|
1005 |
GrowableArray<Klass*>* compute_secondary_supers(int num_extra_slots, |
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
1006 |
Array<InstanceKlass*>* transitive_interfaces); |
1 | 1007 |
bool can_be_primary_super_slow() const; |
1008 |
int oop_size(oop obj) const { return size_helper(); } |
|
33611
9abd65805e19
8139203: Consistent naming for klass type predicates
coleenp
parents:
33602
diff
changeset
|
1009 |
// 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
|
1010 |
// 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
|
1011 |
DEBUG_ONLY(bool is_instance_klass_slow() const { return true; }) |
1 | 1012 |
|
1013 |
// Iterators |
|
1014 |
void do_local_static_fields(FieldClosure* cl); |
|
1015 |
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
|
1016 |
void do_local_static_fields(void f(fieldDescriptor*, Handle, TRAPS), Handle, TRAPS); |
1 | 1017 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1018 |
void methods_do(void f(Method* method)); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1019 |
void array_klasses_do(void f(Klass* k)); |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1020 |
void array_klasses_do(void f(Klass* k, TRAPS), TRAPS); |
1 | 1021 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1022 |
static InstanceKlass* cast(Klass* k) { |
34666 | 1023 |
return const_cast<InstanceKlass*>(cast(const_cast<const Klass*>(k))); |
1024 |
} |
|
1025 |
||
1026 |
static const InstanceKlass* cast(const Klass* k) { |
|
33602 | 1027 |
assert(k != NULL, "k should not be null"); |
33611
9abd65805e19
8139203: Consistent naming for klass type predicates
coleenp
parents:
33602
diff
changeset
|
1028 |
assert(k->is_instance_klass(), "cast to InstanceKlass"); |
34666 | 1029 |
return static_cast<const InstanceKlass*>(k); |
1 | 1030 |
} |
1031 |
||
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
1032 |
virtual InstanceKlass* java_super() const { |
14385 | 1033 |
return (super() == NULL) ? NULL : cast(super()); |
1034 |
} |
|
1035 |
||
1 | 1036 |
// 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
|
1037 |
static int header_size() { return sizeof(InstanceKlass)/wordSize; } |
15601 | 1038 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1039 |
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
|
1040 |
int nonstatic_oop_map_size, |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
1041 |
bool is_interface, bool is_unsafe_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
|
1042 |
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
|
1043 |
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
|
1044 |
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
|
1045 |
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
|
1046 |
(is_interface ? (int)sizeof(Klass*)/wordSize : 0) + |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
1047 |
(is_unsafe_anonymous ? (int)sizeof(Klass*)/wordSize : 0) + |
42650 | 1048 |
(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
|
1049 |
} |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1050 |
int size() const { return size(vtable_length(), |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1051 |
itable_length(), |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1052 |
nonstatic_oop_map_size(), |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1053 |
is_interface(), |
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
1054 |
is_unsafe_anonymous(), |
42650 | 1055 |
has_stored_fingerprint()); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1056 |
} |
15437 | 1057 |
#if INCLUDE_SERVICES |
1058 |
virtual void collect_statistics(KlassSizeStats *sz) const; |
|
1059 |
#endif |
|
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1060 |
|
35900 | 1061 |
intptr_t* start_of_itable() const { return (intptr_t*)start_of_vtable() + vtable_length(); } |
1062 |
intptr_t* end_of_itable() const { return start_of_itable() + itable_length(); } |
|
1063 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1064 |
int itable_offset_in_words() const { return start_of_itable() - (intptr_t*)this; } |
1 | 1065 |
|
49473
26958d06b585
8199739: Use HeapAccess when loading oops from static fields in javaClasses.cpp
rkennke
parents:
49393
diff
changeset
|
1066 |
oop static_field_base_raw() { return java_mirror(); } |
360
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
1067 |
|
21d113ecbf6a
6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents:
222
diff
changeset
|
1068 |
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
|
1069 |
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
|
1070 |
} |
1 | 1071 |
|
15601 | 1072 |
Klass** end_of_nonstatic_oop_maps() const { |
1073 |
return (Klass**)(start_of_nonstatic_oop_maps() + |
|
1074 |
nonstatic_oop_map_count()); |
|
1075 |
} |
|
1076 |
||
52784
621efe32eb0b
8213209: [REDO] Allow Klass::_subklass and _next_sibling to have unloaded classes
eosterlund
parents:
52781
diff
changeset
|
1077 |
Klass* volatile* adr_implementor() const { |
12369
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1078 |
if (is_interface()) { |
52784
621efe32eb0b
8213209: [REDO] Allow Klass::_subklass and _next_sibling to have unloaded classes
eosterlund
parents:
52781
diff
changeset
|
1079 |
return (Klass* volatile*)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
|
1080 |
} else { |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1081 |
return NULL; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1082 |
} |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1083 |
}; |
48fd3da4025c
7154670: The instanceKlass _implementors[] and _nof_implementors are not needed for non-interface klass.
jiangli
parents:
12231
diff
changeset
|
1084 |
|
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
1085 |
InstanceKlass** adr_unsafe_anonymous_host() const { |
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
1086 |
if (is_unsafe_anonymous()) { |
52784
621efe32eb0b
8213209: [REDO] Allow Klass::_subklass and _next_sibling to have unloaded classes
eosterlund
parents:
52781
diff
changeset
|
1087 |
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
|
1088 |
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
|
1089 |
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
|
1090 |
} else { |
40923
10fe1c28b9f6
8058575: IllegalAccessError trying to access package-private class from VM anonymous class
hseigel
parents:
40909
diff
changeset
|
1091 |
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
|
1092 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1093 |
} else { |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1094 |
return NULL; |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1095 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1096 |
} |
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1097 |
|
42650 | 1098 |
address adr_fingerprint() const { |
1099 |
if (has_stored_fingerprint()) { |
|
51444
3e5d28e6de32
8209301: JVM rename is_anonymous, host_klass to unsafe specific terminology ahead of Unsafe.defineAnonymousClass deprecation
lfoltan
parents:
51379
diff
changeset
|
1100 |
InstanceKlass** adr_host = adr_unsafe_anonymous_host(); |
42650 | 1101 |
if (adr_host != NULL) { |
1102 |
return (address)(adr_host + 1); |
|
1103 |
} |
|
1104 |
||
52784
621efe32eb0b
8213209: [REDO] Allow Klass::_subklass and _next_sibling to have unloaded classes
eosterlund
parents:
52781
diff
changeset
|
1105 |
Klass* volatile* adr_impl = adr_implementor(); |
42650 | 1106 |
if (adr_impl != NULL) { |
1107 |
return (address)(adr_impl + 1); |
|
1108 |
} |
|
1109 |
||
1110 |
return (address)end_of_nonstatic_oop_maps(); |
|
1111 |
} else { |
|
1112 |
return NULL; |
|
1113 |
} |
|
1114 |
} |
|
1115 |
||
1 | 1116 |
// Use this to return the size of an instance in heap words: |
1117 |
int size_helper() const { |
|
1118 |
return layout_helper_to_size_helper(layout_helper()); |
|
1119 |
} |
|
1120 |
||
1121 |
// This bit is initialized in classFileParser.cpp. |
|
1122 |
// It is false under any of the following conditions: |
|
1123 |
// - the class is abstract (including any interface) |
|
1124 |
// - the class has a finalizer (if !RegisterFinalizersAtInit) |
|
1125 |
// - the class size is larger than FastAllocateSizeLimit |
|
1126 |
// - the class is java/lang/Class, which cannot be allocated directly |
|
1127 |
bool can_be_fastpath_allocated() const { |
|
1128 |
return !layout_helper_needs_slow_path(layout_helper()); |
|
1129 |
} |
|
1130 |
||
35900 | 1131 |
// Java itable |
46408
70aab0c2ea8b
8178350: klassVtable and klassItable should be ValueObj
iklam
parents:
46341
diff
changeset
|
1132 |
klassItable itable() const; // return klassItable wrapper |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1133 |
Method* method_at_itable(Klass* holder, int index, TRAPS); |
1 | 1134 |
|
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
1135 |
#if INCLUDE_JVMTI |
53904
9c3fe09f69bc
8078725: method adjustments can be done just once for all classes involved into redefinition
coleenp
parents:
53884
diff
changeset
|
1136 |
void adjust_default_methods(bool* trace_name_printed); |
20391
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
1137 |
#endif // INCLUDE_JVMTI |
7b146c5ebb18
8009130: Lambda: Fix access controls, loader constraints.
acorn
parents:
20379
diff
changeset
|
1138 |
|
49821
02c08e20d66c
8201537: Remove is_alive closure from Klass::is_loader_alive()
coleenp
parents:
49738
diff
changeset
|
1139 |
void clean_weak_instanceklass_links(); |
49969
8624981f1ffa
8202447: Fix unloading_occurred to mean unloading_occurred
coleenp
parents:
49948
diff
changeset
|
1140 |
private: |
49821
02c08e20d66c
8201537: Remove is_alive closure from Klass::is_loader_alive()
coleenp
parents:
49738
diff
changeset
|
1141 |
void clean_implementors_list(); |
02c08e20d66c
8201537: Remove is_alive closure from Klass::is_loader_alive()
coleenp
parents:
49738
diff
changeset
|
1142 |
void clean_method_data(); |
1 | 1143 |
|
49969
8624981f1ffa
8202447: Fix unloading_occurred to mean unloading_occurred
coleenp
parents:
49948
diff
changeset
|
1144 |
public: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1145 |
// Explicit metaspace deallocation of fields |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1146 |
// 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
|
1147 |
// instanceKlasses and the metadata they point to. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1148 |
void deallocate_contents(ClassLoaderData* loader_data); |
15935
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1149 |
static void deallocate_methods(ClassLoaderData* loader_data, |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1150 |
Array<Method*>* methods); |
50da9e5eb858
8003419: NPG: Clean up metadata created during class loading if failure
coleenp
parents:
15930
diff
changeset
|
1151 |
void static deallocate_interfaces(ClassLoaderData* loader_data, |
34666 | 1152 |
const Klass* super_klass, |
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
1153 |
Array<InstanceKlass*>* local_interfaces, |
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
1154 |
Array<InstanceKlass*>* transitive_interfaces); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1155 |
|
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1156 |
// 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
|
1157 |
// referenced by handles. |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1158 |
bool on_stack() const { return _constants->on_stack(); } |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1159 |
|
17075
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1160 |
// callbacks for actions during class unloading |
51887
32161fbea3fe
8210856: Move InstanceKlass DependencyContext cleaning to SystemDictionary::do_unloading()
coleenp
parents:
51697
diff
changeset
|
1161 |
static void unload_class(InstanceKlass* ik); |
17075
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1162 |
static void release_C_heap_structures(InstanceKlass* ik); |
1 | 1163 |
|
1164 |
// Naming |
|
4094
1f424b2b2171
6815692: method handle code needs some cleanup (post-6655638)
jrose
parents:
3824
diff
changeset
|
1165 |
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
|
1166 |
static Symbol* package_from_name(const Symbol* name, TRAPS); |
1 | 1167 |
|
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1168 |
// 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
|
1169 |
// |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1170 |
// 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
|
1171 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1172 |
// Forward iteration |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1173 |
public: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1174 |
// Iterate over all oop fields in the oop maps. |
50752 | 1175 |
template <typename T, class OopClosureType> |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1176 |
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
|
1177 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1178 |
// Iterate over all oop fields and metadata. |
50752 | 1179 |
template <typename T, class OopClosureType> |
52188
0fcd1285435e
8212595: Remove unused size_helper() in oop_oop_iterate* in instanceKlass.inline.hpp
lkorinth
parents:
52119
diff
changeset
|
1180 |
inline void oop_oop_iterate(oop obj, OopClosureType* closure); |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1181 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1182 |
// Iterate over all oop fields in one oop map. |
50752 | 1183 |
template <typename T, class OopClosureType> |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1184 |
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
|
1185 |
|
1 | 1186 |
|
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1187 |
// Reverse iteration |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1188 |
// Iterate over all oop fields and metadata. |
50752 | 1189 |
template <typename T, class OopClosureType> |
52188
0fcd1285435e
8212595: Remove unused size_helper() in oop_oop_iterate* in instanceKlass.inline.hpp
lkorinth
parents:
52119
diff
changeset
|
1190 |
inline void oop_oop_iterate_reverse(oop obj, OopClosureType* closure); |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1191 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1192 |
private: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1193 |
// Iterate over all oop fields in the oop maps. |
50752 | 1194 |
template <typename T, class OopClosureType> |
1195 |
inline void oop_oop_iterate_oop_maps_reverse(oop obj, OopClosureType* closure); |
|
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1196 |
|
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 in one oop map. |
50752 | 1198 |
template <typename T, class OopClosureType> |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1199 |
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
|
1200 |
|
1 | 1201 |
|
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1202 |
// Bounded range iteration |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1203 |
public: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1204 |
// Iterate over all oop fields in the oop maps. |
50752 | 1205 |
template <typename T, class OopClosureType> |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1206 |
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
|
1207 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1208 |
// Iterate over all oop fields and metadata. |
50752 | 1209 |
template <typename T, class OopClosureType> |
52188
0fcd1285435e
8212595: Remove unused size_helper() in oop_oop_iterate* in instanceKlass.inline.hpp
lkorinth
parents:
52119
diff
changeset
|
1210 |
inline void oop_oop_iterate_bounded(oop obj, OopClosureType* closure, MemRegion mr); |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1211 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1212 |
private: |
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1213 |
// Iterate over all oop fields in one oop map. |
50752 | 1214 |
template <typename T, class OopClosureType> |
30150
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1215 |
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
|
1216 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1217 |
|
d9c940aa42ef
8075955: Replace the macro based implementation of oop_oop_iterate with a template based solution
stefank
parents:
29698
diff
changeset
|
1218 |
public: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1219 |
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
|
1220 |
|
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1221 |
public: |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1222 |
void set_in_error_state() { |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1223 |
assert(DumpSharedSpaces, "only call this when dumping archive"); |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1224 |
_init_state = initialization_error; |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1225 |
} |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1226 |
bool check_sharing_error_state(); |
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1227 |
|
1 | 1228 |
private: |
1229 |
// initialization state |
|
1230 |
void set_init_state(ClassState state); |
|
12587
8f819769ca1b
7158552: The instanceKlsss::_host_klass is only needed for anonymous class for JSR 292 support.
jiangli
parents:
12377
diff
changeset
|
1231 |
void set_rewritten() { _misc_flags |= _misc_rewritten; } |
1 | 1232 |
void set_init_thread(Thread *thread) { _init_thread = thread; } |
1233 |
||
3824
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
1234 |
// 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
|
1235 |
// 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
|
1236 |
// 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
|
1237 |
// going from NULL to non-NULL. |
86e9e4b25bdf
6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents:
3822
diff
changeset
|
1238 |
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
|
1239 |
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
|
1240 |
inline void release_set_methods_jmethod_ids(jmethodID* jmeths); |
1 | 1241 |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1242 |
// Lock during initialization |
17078
a37993c37937
8008962: NPG: Memory regression: One extra Monitor per ConstantPool
iklam
parents:
17075
diff
changeset
|
1243 |
public: |
17826
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
1244 |
// 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
|
1245 |
// 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
|
1246 |
// cannot lock it (like the mirror). |
9ad5cd464a75
8003421: NPG: Move oops out of InstanceKlass into mirror
coleenp
parents:
17370
diff
changeset
|
1247 |
// 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
|
1248 |
oop init_lock() const; |
17078
a37993c37937
8008962: NPG: Memory regression: One extra Monitor per ConstantPool
iklam
parents:
17075
diff
changeset
|
1249 |
private: |
21079
7028d0cb9b49
8014910: deadlock between JVM/TI ClassPrepare event handler and CompilerThread
iklam
parents:
20391
diff
changeset
|
1250 |
void fence_and_clear_init_lock(); |
1 | 1251 |
|
51697
49e1b21d9878
8210470: Remove unused Verifier::verify() Verifier::Mode argument
hseigel
parents:
51444
diff
changeset
|
1252 |
bool link_class_impl (TRAPS); |
49e1b21d9878
8210470: Remove unused Verifier::verify() Verifier::Mode argument
hseigel
parents:
51444
diff
changeset
|
1253 |
bool verify_code (TRAPS); |
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1254 |
void initialize_impl (TRAPS); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1255 |
void initialize_super_interfaces (TRAPS); |
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1256 |
void eager_initialize_impl (); |
1 | 1257 |
/* jni_id_for_impl for jfieldID only */ |
46341
4c676683bdb9
8176705: Remove static functions in InstanceKlass
hseigel
parents:
46329
diff
changeset
|
1258 |
JNIid* jni_id_for_impl (int offset); |
1 | 1259 |
|
1260 |
// 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
|
1261 |
Klass* array_klass_impl(bool or_null, int n, TRAPS); |
1 | 1262 |
|
1263 |
// 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
|
1264 |
Klass* array_klass_impl(bool or_null, TRAPS); |
1 | 1265 |
|
23999
22eb7be3d99d
8033150: invokestatic: IncompatibleClassChangeError trying to invoke static method from a parent in presence of conflicting defaults.
lfoltan
parents:
23872
diff
changeset
|
1266 |
// find a local method (returns NULL if not found) |
34666 | 1267 |
Method* find_method_impl(const Symbol* name, |
1268 |
const Symbol* signature, |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1269 |
OverpassLookupMode overpass_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1270 |
StaticLookupMode static_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1271 |
PrivateLookupMode private_mode) const; |
34666 | 1272 |
|
1273 |
static Method* find_method_impl(const Array<Method*>* methods, |
|
1274 |
const Symbol* name, |
|
1275 |
const Symbol* signature, |
|
32189
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1276 |
OverpassLookupMode overpass_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1277 |
StaticLookupMode static_mode, |
5264b560ab1b
8087342: Crash in klassItable::initialize_itable_for_interface
acorn
parents:
31046
diff
changeset
|
1278 |
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
|
1279 |
|
17075
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1280 |
// Free CHeap allocated fields. |
b53332c50aba
8011803: release_C_heap_structures is never called for anonymous classes.
coleenp
parents:
17029
diff
changeset
|
1281 |
void release_C_heap_structures(); |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
1282 |
|
38059
86ab3f0a9f87
8148195: Some InstanceKlass and MethodCounters fields can be excluded when JVMTI is not supported
cjplummer
parents:
36812
diff
changeset
|
1283 |
#if INCLUDE_JVMTI |
26558
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
1284 |
// RedefineClasses support |
b7df27df6384
8055008: Clean up code that saves the previous versions of redefined classes
coleenp
parents:
26135
diff
changeset
|
1285 |
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
|
1286 |
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
|
1287 |
#endif |
1 | 1288 |
public: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1289 |
// CDS support - remove and restore oops from metadata. Oops are not shared. |
1 | 1290 |
virtual void remove_unshareable_info(); |
47103
a993ec29ec75
8186842: Use Java class loaders for creating the CDS archive
ccheung
parents:
46746
diff
changeset
|
1291 |
virtual void remove_java_mirror(); |
26135
82b516c550f7
8046070: Class Data Sharing clean up and refactoring
iklam
parents:
25492
diff
changeset
|
1292 |
virtual void restore_unshareable_info(ClassLoaderData* loader_data, Handle protection_domain, TRAPS); |
1 | 1293 |
|
1294 |
// jvm support |
|
1295 |
jint compute_modifier_flags(TRAPS) const; |
|
1296 |
||
1297 |
public: |
|
1298 |
// JVMTI support |
|
1299 |
jint jvmti_class_status() const; |
|
1300 |
||
46746
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
1301 |
virtual void metaspace_pointers_do(MetaspaceClosure* iter); |
ea379ebb9447
8072061: Automatically determine optimal sizes for the CDS regions
iklam
parents:
46697
diff
changeset
|
1302 |
|
1 | 1303 |
public: |
1304 |
// Printing |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1305 |
#ifndef PRODUCT |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1306 |
void print_on(outputStream* st) const; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1307 |
#endif |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1308 |
void print_value_on(outputStream* st) const; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1309 |
|
4584
e2a449e8cc6f
6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents:
4496
diff
changeset
|
1310 |
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
|
1311 |
|
4584
e2a449e8cc6f
6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents:
4496
diff
changeset
|
1312 |
#ifndef PRODUCT |
1 | 1313 |
void oop_print_on (oop obj, outputStream* st); |
1314 |
||
1315 |
void print_dependent_nmethods(bool verbose = false); |
|
1316 |
bool is_dependent_nmethod(nmethod* nm); |
|
51329
9c68699bebe5
8208999: Some use of Klass* should be replaced by InstanceKlass*
iklam
parents:
50752
diff
changeset
|
1317 |
bool verify_itable_index(int index); |
1 | 1318 |
#endif |
1319 |
||
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1320 |
const char* internal_name() const; |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1321 |
|
1 | 1322 |
// Verification |
22794
f1c014ad3754
8027146: Class loading verification failure if GC occurs in Universe::flush_dependents_on
coleenp
parents:
22757
diff
changeset
|
1323 |
void verify_on(outputStream* st); |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1324 |
|
1 | 1325 |
void oop_verify_on(oop obj, outputStream* st); |
35917
463d67f86eaa
8079408: Reimplement TraceClassLoading, TraceClassUnloading, and TraceClassLoaderData with Unified Logging.
mockner
parents:
35900
diff
changeset
|
1326 |
|
463d67f86eaa
8079408: Reimplement TraceClassLoading, TraceClassUnloading, and TraceClassLoaderData with Unified Logging.
mockner
parents:
35900
diff
changeset
|
1327 |
// Logging |
46444
677be3444372
8154791: Xlog classload too redundant msgs info/debug
rprotacio
parents:
46415
diff
changeset
|
1328 |
void print_class_load_logging(ClassLoaderData* loader_data, |
677be3444372
8154791: Xlog classload too redundant msgs info/debug
rprotacio
parents:
46415
diff
changeset
|
1329 |
const char* module_name, |
677be3444372
8154791: Xlog classload too redundant msgs info/debug
rprotacio
parents:
46415
diff
changeset
|
1330 |
const ClassFileStream* cfs) const; |
1 | 1331 |
}; |
1332 |
||
1333 |
// for adding methods |
|
1334 |
// 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
|
1335 |
inline u2 InstanceKlass::next_method_idnum() { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1336 |
if (_idnum_allocated_count == ConstMethod::MAX_IDNUM) { |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1337 |
return ConstMethod::UNSET_IDNUM; // no more ids available |
1 | 1338 |
} else { |
1339 |
return _idnum_allocated_count++; |
|
1340 |
} |
|
1341 |
} |
|
1342 |
||
1343 |
||
1344 |
/* JNIid class for jfieldIDs only */ |
|
13195 | 1345 |
class JNIid: public CHeapObj<mtClass> { |
1 | 1346 |
friend class VMStructs; |
1347 |
private: |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1348 |
Klass* _holder; |
1 | 1349 |
JNIid* _next; |
1350 |
int _offset; |
|
1351 |
#ifdef ASSERT |
|
1352 |
bool _is_static_field_id; |
|
1353 |
#endif |
|
1354 |
||
1355 |
public: |
|
1356 |
// Accessors |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1357 |
Klass* holder() const { return _holder; } |
1 | 1358 |
int offset() const { return _offset; } |
1359 |
JNIid* next() { return _next; } |
|
1360 |
// Constructor |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1361 |
JNIid(Klass* holder, int offset, JNIid* next); |
1 | 1362 |
// Identifier lookup |
1363 |
JNIid* find(int offset); |
|
1364 |
||
8725
8c1e3dd5fe1b
7017732: move static fields into Class to prepare for perm gen removal
never
parents:
8676
diff
changeset
|
1365 |
bool find_local_field(fieldDescriptor* fd) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1366 |
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
|
1367 |
} |
8c1e3dd5fe1b
7017732: move static fields into Class to prepare for perm gen removal
never
parents:
8676
diff
changeset
|
1368 |
|
1 | 1369 |
static void deallocate(JNIid* id); |
1370 |
// Debugging |
|
1371 |
#ifdef ASSERT |
|
1372 |
bool is_static_field_id() const { return _is_static_field_id; } |
|
1373 |
void set_is_static_field_id() { _is_static_field_id = true; } |
|
1374 |
#endif |
|
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1375 |
void verify(Klass* holder); |
1 | 1376 |
}; |
1377 |
||
12231
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1378 |
// 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
|
1379 |
// 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
|
1380 |
class InnerClassesIterator : public StackObj { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1381 |
private: |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1382 |
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
|
1383 |
int _length; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1384 |
int _idx; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1385 |
public: |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1386 |
|
46329
53ccc37bda19
8155672: Remove instanceKlassHandles and KlassHandles
coleenp
parents:
43929
diff
changeset
|
1387 |
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
|
1388 |
_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
|
1389 |
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
|
1390 |
_length = _inner_classes->length(); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1391 |
// 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
|
1392 |
// 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
|
1393 |
// 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
|
1394 |
// 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
|
1395 |
// if it also contains the EnclosingMethod data. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1396 |
assert((_length % InstanceKlass::inner_class_next_offset == 0 || |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1397 |
_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
|
1398 |
"just checking"); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1399 |
// Remove the enclosing_method portion if exists. |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1400 |
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
|
1401 |
_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
|
1402 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1403 |
} else { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1404 |
_length = 0; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1405 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1406 |
_idx = 0; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1407 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1408 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1409 |
int length() const { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1410 |
return _length; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1411 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1412 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1413 |
void next() { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1414 |
_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
|
1415 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1416 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1417 |
bool done() const { |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1418 |
return (_idx >= _length); |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1419 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1420 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1421 |
u2 inner_class_info_index() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1422 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1423 |
_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
|
1424 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1425 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1426 |
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
|
1427 |
_inner_classes->at_put( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1428 |
_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
|
1429 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1430 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1431 |
u2 outer_class_info_index() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1432 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1433 |
_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
|
1434 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1435 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1436 |
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
|
1437 |
_inner_classes->at_put( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1438 |
_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
|
1439 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1440 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1441 |
u2 inner_name_index() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1442 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1443 |
_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
|
1444 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1445 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1446 |
void set_inner_name_index(u2 index) { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1447 |
_inner_classes->at_put( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1448 |
_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
|
1449 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1450 |
|
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1451 |
u2 inner_access_flags() const { |
13728
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1452 |
return _inner_classes->at( |
882756847a04
6964458: Reimplement class meta-data storage to use native memory
coleenp
parents:
13201
diff
changeset
|
1453 |
_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
|
1454 |
} |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1455 |
}; |
6a9cfc59a18a
7109878: The instanceKlass EnclosingMethhod attribute fields can be folded into the _inner_class field.
jiangli
parents:
11731
diff
changeset
|
1456 |
|
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
53232
diff
changeset
|
1457 |
#endif // SHARE_OOPS_INSTANCEKLASS_HPP |