annotate src/share/vm/oops/klass.hpp @ 1941:79d04223b8a5

Added caching for resolved types and resolved fields. This is crucial, because the local load elimination will lead to wrong results, if field equality (of two RiField objects with the same object and the same RiType) is not given. The caching makes sure that the default equals implementation is sufficient.
author Thomas Wuerthinger <wuerthinger@ssw.jku.at>
date Tue, 28 Dec 2010 18:33:26 +0100
parents 126ea7725993
children 06f017f7daa7
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1155
diff changeset
2 * Copyright (c) 1997, 2009, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1155
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1155
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1155
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
a61af66fc99e Initial load
duke
parents:
diff changeset
25 // A Klass is the part of the klassOop that provides:
a61af66fc99e Initial load
duke
parents:
diff changeset
26 // 1: language level class object (method dictionary etc.)
a61af66fc99e Initial load
duke
parents:
diff changeset
27 // 2: provide vm dispatch behavior for the object
a61af66fc99e Initial load
duke
parents:
diff changeset
28 // Both functions are combined into one C++ class. The toplevel class "Klass"
a61af66fc99e Initial load
duke
parents:
diff changeset
29 // implements purpose 1 whereas all subclasses provide extra virtual functions
a61af66fc99e Initial load
duke
parents:
diff changeset
30 // for purpose 2.
a61af66fc99e Initial load
duke
parents:
diff changeset
31
a61af66fc99e Initial load
duke
parents:
diff changeset
32 // One reason for the oop/klass dichotomy in the implementation is
a61af66fc99e Initial load
duke
parents:
diff changeset
33 // that we don't want a C++ vtbl pointer in every object. Thus,
a61af66fc99e Initial load
duke
parents:
diff changeset
34 // normal oops don't have any virtual functions. Instead, they
a61af66fc99e Initial load
duke
parents:
diff changeset
35 // forward all "virtual" functions to their klass, which does have
a61af66fc99e Initial load
duke
parents:
diff changeset
36 // a vtbl and does the C++ dispatch depending on the object's
a61af66fc99e Initial load
duke
parents:
diff changeset
37 // actual type. (See oop.inline.hpp for some of the forwarding code.)
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // ALL FUNCTIONS IMPLEMENTING THIS DISPATCH ARE PREFIXED WITH "oop_"!
a61af66fc99e Initial load
duke
parents:
diff changeset
39
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // Klass layout:
a61af66fc99e Initial load
duke
parents:
diff changeset
41 // [header ] klassOop
a61af66fc99e Initial load
duke
parents:
diff changeset
42 // [klass pointer ] klassOop
a61af66fc99e Initial load
duke
parents:
diff changeset
43 // [C++ vtbl ptr ] (contained in Klass_vtbl)
a61af66fc99e Initial load
duke
parents:
diff changeset
44 // [layout_helper ]
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // [super_check_offset ] for fast subtype checks
a61af66fc99e Initial load
duke
parents:
diff changeset
46 // [secondary_super_cache] for fast subtype checks
a61af66fc99e Initial load
duke
parents:
diff changeset
47 // [secondary_supers ] array of 2ndary supertypes
a61af66fc99e Initial load
duke
parents:
diff changeset
48 // [primary_supers 0]
a61af66fc99e Initial load
duke
parents:
diff changeset
49 // [primary_supers 1]
a61af66fc99e Initial load
duke
parents:
diff changeset
50 // [primary_supers 2]
a61af66fc99e Initial load
duke
parents:
diff changeset
51 // ...
a61af66fc99e Initial load
duke
parents:
diff changeset
52 // [primary_supers 7]
a61af66fc99e Initial load
duke
parents:
diff changeset
53 // [java_mirror ]
a61af66fc99e Initial load
duke
parents:
diff changeset
54 // [super ]
a61af66fc99e Initial load
duke
parents:
diff changeset
55 // [name ]
a61af66fc99e Initial load
duke
parents:
diff changeset
56 // [first subklass]
a61af66fc99e Initial load
duke
parents:
diff changeset
57 // [next_sibling ] link to chain additional subklasses
a61af66fc99e Initial load
duke
parents:
diff changeset
58 // [modifier_flags]
a61af66fc99e Initial load
duke
parents:
diff changeset
59 // [access_flags ]
a61af66fc99e Initial load
duke
parents:
diff changeset
60 // [verify_count ] - not in product
a61af66fc99e Initial load
duke
parents:
diff changeset
61 // [alloc_count ]
a61af66fc99e Initial load
duke
parents:
diff changeset
62 // [last_biased_lock_bulk_revocation_time] (64 bits)
a61af66fc99e Initial load
duke
parents:
diff changeset
63 // [prototype_header]
a61af66fc99e Initial load
duke
parents:
diff changeset
64 // [biased_lock_revocation_count]
a61af66fc99e Initial load
duke
parents:
diff changeset
65
a61af66fc99e Initial load
duke
parents:
diff changeset
66
a61af66fc99e Initial load
duke
parents:
diff changeset
67 // Forward declarations.
a61af66fc99e Initial load
duke
parents:
diff changeset
68 class klassVtable;
a61af66fc99e Initial load
duke
parents:
diff changeset
69 class KlassHandle;
a61af66fc99e Initial load
duke
parents:
diff changeset
70 class OrderAccess;
a61af66fc99e Initial load
duke
parents:
diff changeset
71
a61af66fc99e Initial load
duke
parents:
diff changeset
72 // Holder (or cage) for the C++ vtable of each kind of Klass.
a61af66fc99e Initial load
duke
parents:
diff changeset
73 // We want to tightly constrain the location of the C++ vtable in the overall layout.
a61af66fc99e Initial load
duke
parents:
diff changeset
74 class Klass_vtbl {
a61af66fc99e Initial load
duke
parents:
diff changeset
75 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
76 // The following virtual exists only to force creation of a C++ vtable,
a61af66fc99e Initial load
duke
parents:
diff changeset
77 // so that this class truly is the location of the vtable of all Klasses.
a61af66fc99e Initial load
duke
parents:
diff changeset
78 virtual void unused_initial_virtual() { }
a61af66fc99e Initial load
duke
parents:
diff changeset
79
a61af66fc99e Initial load
duke
parents:
diff changeset
80 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
81 // The following virtual makes Klass_vtbl play a second role as a
a61af66fc99e Initial load
duke
parents:
diff changeset
82 // factory protocol for subclasses of Klass ("sub-Klasses").
a61af66fc99e Initial load
duke
parents:
diff changeset
83 // Here's how it works....
a61af66fc99e Initial load
duke
parents:
diff changeset
84 //
a61af66fc99e Initial load
duke
parents:
diff changeset
85 // This VM uses metaobjects as factories for their instances.
a61af66fc99e Initial load
duke
parents:
diff changeset
86 //
a61af66fc99e Initial load
duke
parents:
diff changeset
87 // In order to initialize the C++ vtable of a new instance, its
a61af66fc99e Initial load
duke
parents:
diff changeset
88 // metaobject is forced to use the C++ placed new operator to
a61af66fc99e Initial load
duke
parents:
diff changeset
89 // allocate the instance. In a typical C++-based system, each
a61af66fc99e Initial load
duke
parents:
diff changeset
90 // sub-class would have its own factory routine which
a61af66fc99e Initial load
duke
parents:
diff changeset
91 // directly uses the placed new operator on the desired class,
a61af66fc99e Initial load
duke
parents:
diff changeset
92 // and then calls the appropriate chain of C++ constructors.
a61af66fc99e Initial load
duke
parents:
diff changeset
93 //
a61af66fc99e Initial load
duke
parents:
diff changeset
94 // However, this system uses shared code to performs the first
a61af66fc99e Initial load
duke
parents:
diff changeset
95 // allocation and initialization steps for all sub-Klasses.
a61af66fc99e Initial load
duke
parents:
diff changeset
96 // (See base_create_klass() and base_create_array_klass().)
a61af66fc99e Initial load
duke
parents:
diff changeset
97 // This does not factor neatly into a hierarchy of C++ constructors.
a61af66fc99e Initial load
duke
parents:
diff changeset
98 // Each caller of these shared "base_create" routines knows
a61af66fc99e Initial load
duke
parents:
diff changeset
99 // exactly which sub-Klass it is creating, but the shared routine
a61af66fc99e Initial load
duke
parents:
diff changeset
100 // does not, even though it must perform the actual allocation.
a61af66fc99e Initial load
duke
parents:
diff changeset
101 //
a61af66fc99e Initial load
duke
parents:
diff changeset
102 // Therefore, the caller of the shared "base_create" must wrap
a61af66fc99e Initial load
duke
parents:
diff changeset
103 // the specific placed new call in a virtual function which
a61af66fc99e Initial load
duke
parents:
diff changeset
104 // performs the actual allocation and vtable set-up. That
a61af66fc99e Initial load
duke
parents:
diff changeset
105 // virtual function is here, Klass_vtbl::allocate_permanent.
a61af66fc99e Initial load
duke
parents:
diff changeset
106 //
a61af66fc99e Initial load
duke
parents:
diff changeset
107 // The arguments to Universe::allocate_permanent() are passed
a61af66fc99e Initial load
duke
parents:
diff changeset
108 // straight through the placed new operator, which in turn
a61af66fc99e Initial load
duke
parents:
diff changeset
109 // obtains them directly from this virtual call.
a61af66fc99e Initial load
duke
parents:
diff changeset
110 //
a61af66fc99e Initial load
duke
parents:
diff changeset
111 // This virtual is called on a temporary "example instance" of the
a61af66fc99e Initial load
duke
parents:
diff changeset
112 // sub-Klass being instantiated, a C++ auto variable. The "real"
a61af66fc99e Initial load
duke
parents:
diff changeset
113 // instance created by this virtual is on the VM heap, where it is
a61af66fc99e Initial load
duke
parents:
diff changeset
114 // equipped with a klassOopDesc header.
a61af66fc99e Initial load
duke
parents:
diff changeset
115 //
a61af66fc99e Initial load
duke
parents:
diff changeset
116 // It is merely an accident of implementation that we use "example
a61af66fc99e Initial load
duke
parents:
diff changeset
117 // instances", but that is why the virtual function which implements
a61af66fc99e Initial load
duke
parents:
diff changeset
118 // each sub-Klass factory happens to be defined by the same sub-Klass
a61af66fc99e Initial load
duke
parents:
diff changeset
119 // for which it creates instances.
a61af66fc99e Initial load
duke
parents:
diff changeset
120 //
a61af66fc99e Initial load
duke
parents:
diff changeset
121 // The vtbl_value() call (see below) is used to strip away the
a61af66fc99e Initial load
duke
parents:
diff changeset
122 // accidental Klass-ness from an "example instance" and present it as
a61af66fc99e Initial load
duke
parents:
diff changeset
123 // a factory. Think of each factory object as a mere container of the
a61af66fc99e Initial load
duke
parents:
diff changeset
124 // C++ vtable for the desired sub-Klass. Since C++ does not allow
a61af66fc99e Initial load
duke
parents:
diff changeset
125 // direct references to vtables, the factory must also be delegated
a61af66fc99e Initial load
duke
parents:
diff changeset
126 // the task of allocating the instance, but the essential point is
a61af66fc99e Initial load
duke
parents:
diff changeset
127 // that the factory knows how to initialize the C++ vtable with the
a61af66fc99e Initial load
duke
parents:
diff changeset
128 // right pointer value. All other common initializations are handled
a61af66fc99e Initial load
duke
parents:
diff changeset
129 // by the shared "base_create" subroutines.
a61af66fc99e Initial load
duke
parents:
diff changeset
130 //
a61af66fc99e Initial load
duke
parents:
diff changeset
131 virtual void* allocate_permanent(KlassHandle& klass, int size, TRAPS) const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
132 void post_new_init_klass(KlassHandle& klass, klassOop obj, int size) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
133
a61af66fc99e Initial load
duke
parents:
diff changeset
134 // Every subclass on which vtbl_value is called must include this macro.
a61af66fc99e Initial load
duke
parents:
diff changeset
135 // Delay the installation of the klassKlass pointer until after the
a61af66fc99e Initial load
duke
parents:
diff changeset
136 // the vtable for a new klass has been installed (after the call to new()).
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
137 #define DEFINE_ALLOCATE_PERMANENT(thisKlass) \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
138 void* allocate_permanent(KlassHandle& klass_klass, int size, TRAPS) const { \
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
139 void* result = new(klass_klass, size, THREAD) thisKlass(); \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
140 if (HAS_PENDING_EXCEPTION) return NULL; \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
141 klassOop new_klass = ((Klass*) result)->as_klassOop(); \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
142 OrderAccess::storestore(); \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
143 post_new_init_klass(klass_klass, new_klass, size); \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
144 return result; \
0
a61af66fc99e Initial load
duke
parents:
diff changeset
145 }
a61af66fc99e Initial load
duke
parents:
diff changeset
146
a61af66fc99e Initial load
duke
parents:
diff changeset
147 bool null_vtbl() { return *(intptr_t*)this == 0; }
a61af66fc99e Initial load
duke
parents:
diff changeset
148
a61af66fc99e Initial load
duke
parents:
diff changeset
149 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
150 void* operator new(size_t ignored, KlassHandle& klass, int size, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
151 };
a61af66fc99e Initial load
duke
parents:
diff changeset
152
a61af66fc99e Initial load
duke
parents:
diff changeset
153
a61af66fc99e Initial load
duke
parents:
diff changeset
154 class Klass : public Klass_vtbl {
a61af66fc99e Initial load
duke
parents:
diff changeset
155 friend class VMStructs;
a61af66fc99e Initial load
duke
parents:
diff changeset
156 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
157 // note: put frequently-used fields together at start of klass structure
a61af66fc99e Initial load
duke
parents:
diff changeset
158 // for better cache behavior (may not make much of a difference but sure won't hurt)
a61af66fc99e Initial load
duke
parents:
diff changeset
159 enum { _primary_super_limit = 8 };
a61af66fc99e Initial load
duke
parents:
diff changeset
160
a61af66fc99e Initial load
duke
parents:
diff changeset
161 // The "layout helper" is a combined descriptor of object layout.
a61af66fc99e Initial load
duke
parents:
diff changeset
162 // For klasses which are neither instance nor array, the value is zero.
a61af66fc99e Initial load
duke
parents:
diff changeset
163 //
a61af66fc99e Initial load
duke
parents:
diff changeset
164 // For instances, layout helper is a positive number, the instance size.
a61af66fc99e Initial load
duke
parents:
diff changeset
165 // This size is already passed through align_object_size and scaled to bytes.
a61af66fc99e Initial load
duke
parents:
diff changeset
166 // The low order bit is set if instances of this class cannot be
a61af66fc99e Initial load
duke
parents:
diff changeset
167 // allocated using the fastpath.
a61af66fc99e Initial load
duke
parents:
diff changeset
168 //
a61af66fc99e Initial load
duke
parents:
diff changeset
169 // For arrays, layout helper is a negative number, containing four
a61af66fc99e Initial load
duke
parents:
diff changeset
170 // distinct bytes, as follows:
a61af66fc99e Initial load
duke
parents:
diff changeset
171 // MSB:[tag, hsz, ebt, log2(esz)]:LSB
a61af66fc99e Initial load
duke
parents:
diff changeset
172 // where:
a61af66fc99e Initial load
duke
parents:
diff changeset
173 // tag is 0x80 if the elements are oops, 0xC0 if non-oops
a61af66fc99e Initial load
duke
parents:
diff changeset
174 // hsz is array header size in bytes (i.e., offset of first element)
a61af66fc99e Initial load
duke
parents:
diff changeset
175 // ebt is the BasicType of the elements
a61af66fc99e Initial load
duke
parents:
diff changeset
176 // esz is the element size in bytes
a61af66fc99e Initial load
duke
parents:
diff changeset
177 // This packed word is arranged so as to be quickly unpacked by the
a61af66fc99e Initial load
duke
parents:
diff changeset
178 // various fast paths that use the various subfields.
a61af66fc99e Initial load
duke
parents:
diff changeset
179 //
a61af66fc99e Initial load
duke
parents:
diff changeset
180 // The esz bits can be used directly by a SLL instruction, without masking.
a61af66fc99e Initial load
duke
parents:
diff changeset
181 //
a61af66fc99e Initial load
duke
parents:
diff changeset
182 // Note that the array-kind tag looks like 0x00 for instance klasses,
a61af66fc99e Initial load
duke
parents:
diff changeset
183 // since their length in bytes is always less than 24Mb.
a61af66fc99e Initial load
duke
parents:
diff changeset
184 //
a61af66fc99e Initial load
duke
parents:
diff changeset
185 // Final note: This comes first, immediately after Klass_vtbl,
a61af66fc99e Initial load
duke
parents:
diff changeset
186 // because it is frequently queried.
a61af66fc99e Initial load
duke
parents:
diff changeset
187 jint _layout_helper;
a61af66fc99e Initial load
duke
parents:
diff changeset
188
a61af66fc99e Initial load
duke
parents:
diff changeset
189 // The fields _super_check_offset, _secondary_super_cache, _secondary_supers
a61af66fc99e Initial load
duke
parents:
diff changeset
190 // and _primary_supers all help make fast subtype checks. See big discussion
a61af66fc99e Initial load
duke
parents:
diff changeset
191 // in doc/server_compiler/checktype.txt
a61af66fc99e Initial load
duke
parents:
diff changeset
192 //
a61af66fc99e Initial load
duke
parents:
diff changeset
193 // Where to look to observe a supertype (it is &_secondary_super_cache for
a61af66fc99e Initial load
duke
parents:
diff changeset
194 // secondary supers, else is &_primary_supers[depth()].
a61af66fc99e Initial load
duke
parents:
diff changeset
195 juint _super_check_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
196
a61af66fc99e Initial load
duke
parents:
diff changeset
197 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
198 oop* oop_block_beg() const { return adr_secondary_super_cache(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
199 oop* oop_block_end() const { return adr_next_sibling() + 1; }
a61af66fc99e Initial load
duke
parents:
diff changeset
200
a61af66fc99e Initial load
duke
parents:
diff changeset
201 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
202 //
a61af66fc99e Initial load
duke
parents:
diff changeset
203 // The oop block. All oop fields must be declared here and only oop fields
a61af66fc99e Initial load
duke
parents:
diff changeset
204 // may be declared here. In addition, the first and last fields in this block
a61af66fc99e Initial load
duke
parents:
diff changeset
205 // must remain first and last, unless oop_block_beg() and/or oop_block_end()
a61af66fc99e Initial load
duke
parents:
diff changeset
206 // are updated. Grouping the oop fields in a single block simplifies oop
a61af66fc99e Initial load
duke
parents:
diff changeset
207 // iteration.
a61af66fc99e Initial load
duke
parents:
diff changeset
208 //
a61af66fc99e Initial load
duke
parents:
diff changeset
209
a61af66fc99e Initial load
duke
parents:
diff changeset
210 // Cache of last observed secondary supertype
a61af66fc99e Initial load
duke
parents:
diff changeset
211 klassOop _secondary_super_cache;
a61af66fc99e Initial load
duke
parents:
diff changeset
212 // Array of all secondary supertypes
a61af66fc99e Initial load
duke
parents:
diff changeset
213 objArrayOop _secondary_supers;
a61af66fc99e Initial load
duke
parents:
diff changeset
214 // Ordered list of all primary supertypes
a61af66fc99e Initial load
duke
parents:
diff changeset
215 klassOop _primary_supers[_primary_super_limit];
a61af66fc99e Initial load
duke
parents:
diff changeset
216 // java/lang/Class instance mirroring this class
a61af66fc99e Initial load
duke
parents:
diff changeset
217 oop _java_mirror;
1941
79d04223b8a5 Added caching for resolved types and resolved fields.
Thomas Wuerthinger <wuerthinger@ssw.jku.at>
parents: 1681
diff changeset
218 // com/sun/hotspot/c1x/HotSpotTypeResolved mirroring this class
79d04223b8a5 Added caching for resolved types and resolved fields.
Thomas Wuerthinger <wuerthinger@ssw.jku.at>
parents: 1681
diff changeset
219 oop _c1x_mirror;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
220 // Superclass
a61af66fc99e Initial load
duke
parents:
diff changeset
221 klassOop _super;
a61af66fc99e Initial load
duke
parents:
diff changeset
222 // Class name. Instance classes: java/lang/String, etc. Array classes: [I,
a61af66fc99e Initial load
duke
parents:
diff changeset
223 // [Ljava/lang/String;, etc. Set to zero for all other kinds of classes.
a61af66fc99e Initial load
duke
parents:
diff changeset
224 symbolOop _name;
a61af66fc99e Initial load
duke
parents:
diff changeset
225 // First subclass (NULL if none); _subklass->next_sibling() is next one
a61af66fc99e Initial load
duke
parents:
diff changeset
226 klassOop _subklass;
a61af66fc99e Initial load
duke
parents:
diff changeset
227 // Sibling link (or NULL); links all subklasses of a klass
a61af66fc99e Initial load
duke
parents:
diff changeset
228 klassOop _next_sibling;
a61af66fc99e Initial load
duke
parents:
diff changeset
229
a61af66fc99e Initial load
duke
parents:
diff changeset
230 //
a61af66fc99e Initial load
duke
parents:
diff changeset
231 // End of the oop block.
a61af66fc99e Initial load
duke
parents:
diff changeset
232 //
a61af66fc99e Initial load
duke
parents:
diff changeset
233
a61af66fc99e Initial load
duke
parents:
diff changeset
234 jint _modifier_flags; // Processed access flags, for use by Class.getModifiers.
a61af66fc99e Initial load
duke
parents:
diff changeset
235 AccessFlags _access_flags; // Access flags. The class/interface distinction is stored here.
a61af66fc99e Initial load
duke
parents:
diff changeset
236
a61af66fc99e Initial load
duke
parents:
diff changeset
237 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
238 int _verify_count; // to avoid redundant verifies
a61af66fc99e Initial load
duke
parents:
diff changeset
239 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
240
a61af66fc99e Initial load
duke
parents:
diff changeset
241 juint _alloc_count; // allocation profiling support - update klass_size_in_bytes() if moved/deleted
a61af66fc99e Initial load
duke
parents:
diff changeset
242
a61af66fc99e Initial load
duke
parents:
diff changeset
243 // Biased locking implementation and statistics
a61af66fc99e Initial load
duke
parents:
diff changeset
244 // (the 64-bit chunk goes first, to avoid some fragmentation)
a61af66fc99e Initial load
duke
parents:
diff changeset
245 jlong _last_biased_lock_bulk_revocation_time;
a61af66fc99e Initial load
duke
parents:
diff changeset
246 markOop _prototype_header; // Used when biased locking is both enabled and disabled for this type
a61af66fc99e Initial load
duke
parents:
diff changeset
247 jint _biased_lock_revocation_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
248
a61af66fc99e Initial load
duke
parents:
diff changeset
249 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
250
a61af66fc99e Initial load
duke
parents:
diff changeset
251 // returns the enclosing klassOop
a61af66fc99e Initial load
duke
parents:
diff changeset
252 klassOop as_klassOop() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
253 // see klassOop.hpp for layout.
a61af66fc99e Initial load
duke
parents:
diff changeset
254 return (klassOop) (((char*) this) - sizeof(klassOopDesc));
a61af66fc99e Initial load
duke
parents:
diff changeset
255 }
a61af66fc99e Initial load
duke
parents:
diff changeset
256
a61af66fc99e Initial load
duke
parents:
diff changeset
257 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
258 // Allocation
a61af66fc99e Initial load
duke
parents:
diff changeset
259 const Klass_vtbl& vtbl_value() const { return *this; } // used only on "example instances"
a61af66fc99e Initial load
duke
parents:
diff changeset
260 static KlassHandle base_create_klass(KlassHandle& klass, int size, const Klass_vtbl& vtbl, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
261 static klassOop base_create_klass_oop(KlassHandle& klass, int size, const Klass_vtbl& vtbl, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
262
a61af66fc99e Initial load
duke
parents:
diff changeset
263 // super
a61af66fc99e Initial load
duke
parents:
diff changeset
264 klassOop super() const { return _super; }
a61af66fc99e Initial load
duke
parents:
diff changeset
265 void set_super(klassOop k) { oop_store_without_check((oop*) &_super, (oop) k); }
a61af66fc99e Initial load
duke
parents:
diff changeset
266
a61af66fc99e Initial load
duke
parents:
diff changeset
267 // initializes _super link, _primary_supers & _secondary_supers arrays
a61af66fc99e Initial load
duke
parents:
diff changeset
268 void initialize_supers(klassOop k, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
269 void initialize_supers_impl1(klassOop k);
a61af66fc99e Initial load
duke
parents:
diff changeset
270 void initialize_supers_impl2(klassOop k);
a61af66fc99e Initial load
duke
parents:
diff changeset
271
a61af66fc99e Initial load
duke
parents:
diff changeset
272 // klass-specific helper for initializing _secondary_supers
a61af66fc99e Initial load
duke
parents:
diff changeset
273 virtual objArrayOop compute_secondary_supers(int num_extra_slots, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
274
a61af66fc99e Initial load
duke
parents:
diff changeset
275 // java_super is the Java-level super type as specified by Class.getSuperClass.
a61af66fc99e Initial load
duke
parents:
diff changeset
276 virtual klassOop java_super() const { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
277
a61af66fc99e Initial load
duke
parents:
diff changeset
278 juint super_check_offset() const { return _super_check_offset; }
a61af66fc99e Initial load
duke
parents:
diff changeset
279 void set_super_check_offset(juint o) { _super_check_offset = o; }
a61af66fc99e Initial load
duke
parents:
diff changeset
280
a61af66fc99e Initial load
duke
parents:
diff changeset
281 klassOop secondary_super_cache() const { return _secondary_super_cache; }
a61af66fc99e Initial load
duke
parents:
diff changeset
282 void set_secondary_super_cache(klassOop k) { oop_store_without_check((oop*) &_secondary_super_cache, (oop) k); }
a61af66fc99e Initial load
duke
parents:
diff changeset
283
a61af66fc99e Initial load
duke
parents:
diff changeset
284 objArrayOop secondary_supers() const { return _secondary_supers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
285 void set_secondary_supers(objArrayOop k) { oop_store_without_check((oop*) &_secondary_supers, (oop) k); }
a61af66fc99e Initial load
duke
parents:
diff changeset
286
a61af66fc99e Initial load
duke
parents:
diff changeset
287 // Return the element of the _super chain of the given depth.
a61af66fc99e Initial load
duke
parents:
diff changeset
288 // If there is no such element, return either NULL or this.
a61af66fc99e Initial load
duke
parents:
diff changeset
289 klassOop primary_super_of_depth(juint i) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
290 assert(i < primary_super_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
291 klassOop super = _primary_supers[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
292 assert(super == NULL || super->klass_part()->super_depth() == i, "correct display");
a61af66fc99e Initial load
duke
parents:
diff changeset
293 return super;
a61af66fc99e Initial load
duke
parents:
diff changeset
294 }
a61af66fc99e Initial load
duke
parents:
diff changeset
295
a61af66fc99e Initial load
duke
parents:
diff changeset
296 // Can this klass be a primary super? False for interfaces and arrays of
a61af66fc99e Initial load
duke
parents:
diff changeset
297 // interfaces. False also for arrays or classes with long super chains.
a61af66fc99e Initial load
duke
parents:
diff changeset
298 bool can_be_primary_super() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
299 const juint secondary_offset = secondary_super_cache_offset_in_bytes() + sizeof(oopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
300 return super_check_offset() != secondary_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
301 }
a61af66fc99e Initial load
duke
parents:
diff changeset
302 virtual bool can_be_primary_super_slow() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
303
a61af66fc99e Initial load
duke
parents:
diff changeset
304 // Returns number of primary supers; may be a number in the inclusive range [0, primary_super_limit].
a61af66fc99e Initial load
duke
parents:
diff changeset
305 juint super_depth() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
306 if (!can_be_primary_super()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
307 return primary_super_limit();
a61af66fc99e Initial load
duke
parents:
diff changeset
308 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
309 juint d = (super_check_offset() - (primary_supers_offset_in_bytes() + sizeof(oopDesc))) / sizeof(klassOop);
a61af66fc99e Initial load
duke
parents:
diff changeset
310 assert(d < primary_super_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
311 assert(_primary_supers[d] == as_klassOop(), "proper init");
a61af66fc99e Initial load
duke
parents:
diff changeset
312 return d;
a61af66fc99e Initial load
duke
parents:
diff changeset
313 }
a61af66fc99e Initial load
duke
parents:
diff changeset
314 }
a61af66fc99e Initial load
duke
parents:
diff changeset
315
a61af66fc99e Initial load
duke
parents:
diff changeset
316 // java mirror
a61af66fc99e Initial load
duke
parents:
diff changeset
317 oop java_mirror() const { return _java_mirror; }
a61af66fc99e Initial load
duke
parents:
diff changeset
318 void set_java_mirror(oop m) { oop_store((oop*) &_java_mirror, m); }
a61af66fc99e Initial load
duke
parents:
diff changeset
319
1941
79d04223b8a5 Added caching for resolved types and resolved fields.
Thomas Wuerthinger <wuerthinger@ssw.jku.at>
parents: 1681
diff changeset
320 // c1x mirror
79d04223b8a5 Added caching for resolved types and resolved fields.
Thomas Wuerthinger <wuerthinger@ssw.jku.at>
parents: 1681
diff changeset
321 oop c1x_mirror() const { return _c1x_mirror; }
79d04223b8a5 Added caching for resolved types and resolved fields.
Thomas Wuerthinger <wuerthinger@ssw.jku.at>
parents: 1681
diff changeset
322 void set_c1x_mirror(oop m) { oop_store((oop*) &_c1x_mirror, m); }
79d04223b8a5 Added caching for resolved types and resolved fields.
Thomas Wuerthinger <wuerthinger@ssw.jku.at>
parents: 1681
diff changeset
323
0
a61af66fc99e Initial load
duke
parents:
diff changeset
324 // modifier flags
a61af66fc99e Initial load
duke
parents:
diff changeset
325 jint modifier_flags() const { return _modifier_flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
326 void set_modifier_flags(jint flags) { _modifier_flags = flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
327
a61af66fc99e Initial load
duke
parents:
diff changeset
328 // size helper
a61af66fc99e Initial load
duke
parents:
diff changeset
329 int layout_helper() const { return _layout_helper; }
a61af66fc99e Initial load
duke
parents:
diff changeset
330 void set_layout_helper(int lh) { _layout_helper = lh; }
a61af66fc99e Initial load
duke
parents:
diff changeset
331
a61af66fc99e Initial load
duke
parents:
diff changeset
332 // Note: for instances layout_helper() may include padding.
a61af66fc99e Initial load
duke
parents:
diff changeset
333 // Use instanceKlass::contains_field_offset to classify field offsets.
a61af66fc99e Initial load
duke
parents:
diff changeset
334
a61af66fc99e Initial load
duke
parents:
diff changeset
335 // sub/superklass links
a61af66fc99e Initial load
duke
parents:
diff changeset
336 instanceKlass* superklass() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
337 Klass* subklass() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
338 Klass* next_sibling() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
339 void append_to_sibling_list(); // add newly created receiver to superklass' subklass list
a61af66fc99e Initial load
duke
parents:
diff changeset
340 void remove_from_sibling_list(); // remove receiver from sibling list
a61af66fc99e Initial load
duke
parents:
diff changeset
341 protected: // internal accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
342 klassOop subklass_oop() const { return _subklass; }
a61af66fc99e Initial load
duke
parents:
diff changeset
343 klassOop next_sibling_oop() const { return _next_sibling; }
a61af66fc99e Initial load
duke
parents:
diff changeset
344 void set_subklass(klassOop s);
a61af66fc99e Initial load
duke
parents:
diff changeset
345 void set_next_sibling(klassOop s);
a61af66fc99e Initial load
duke
parents:
diff changeset
346
a61af66fc99e Initial load
duke
parents:
diff changeset
347 oop* adr_super() const { return (oop*)&_super; }
a61af66fc99e Initial load
duke
parents:
diff changeset
348 oop* adr_primary_supers() const { return (oop*)&_primary_supers[0]; }
a61af66fc99e Initial load
duke
parents:
diff changeset
349 oop* adr_secondary_super_cache() const { return (oop*)&_secondary_super_cache; }
a61af66fc99e Initial load
duke
parents:
diff changeset
350 oop* adr_secondary_supers()const { return (oop*)&_secondary_supers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
351 oop* adr_java_mirror() const { return (oop*)&_java_mirror; }
1941
79d04223b8a5 Added caching for resolved types and resolved fields.
Thomas Wuerthinger <wuerthinger@ssw.jku.at>
parents: 1681
diff changeset
352 oop* adr_c1x_mirror() const { return (oop*)&_c1x_mirror; }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
353 oop* adr_name() const { return (oop*)&_name; }
a61af66fc99e Initial load
duke
parents:
diff changeset
354 oop* adr_subklass() const { return (oop*)&_subklass; }
a61af66fc99e Initial load
duke
parents:
diff changeset
355 oop* adr_next_sibling() const { return (oop*)&_next_sibling; }
a61af66fc99e Initial load
duke
parents:
diff changeset
356
a61af66fc99e Initial load
duke
parents:
diff changeset
357 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
358 // Allocation profiling support
a61af66fc99e Initial load
duke
parents:
diff changeset
359 juint alloc_count() const { return _alloc_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
360 void set_alloc_count(juint n) { _alloc_count = n; }
a61af66fc99e Initial load
duke
parents:
diff changeset
361 virtual juint alloc_size() const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
362 virtual void set_alloc_size(juint n) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
363
a61af66fc99e Initial load
duke
parents:
diff changeset
364 // Compiler support
a61af66fc99e Initial load
duke
parents:
diff changeset
365 static int super_offset_in_bytes() { return offset_of(Klass, _super); }
a61af66fc99e Initial load
duke
parents:
diff changeset
366 static int super_check_offset_offset_in_bytes() { return offset_of(Klass, _super_check_offset); }
a61af66fc99e Initial load
duke
parents:
diff changeset
367 static int primary_supers_offset_in_bytes(){ return offset_of(Klass, _primary_supers); }
a61af66fc99e Initial load
duke
parents:
diff changeset
368 static int secondary_super_cache_offset_in_bytes() { return offset_of(Klass, _secondary_super_cache); }
a61af66fc99e Initial load
duke
parents:
diff changeset
369 static int secondary_supers_offset_in_bytes() { return offset_of(Klass, _secondary_supers); }
a61af66fc99e Initial load
duke
parents:
diff changeset
370 static int java_mirror_offset_in_bytes() { return offset_of(Klass, _java_mirror); }
a61af66fc99e Initial load
duke
parents:
diff changeset
371 static int modifier_flags_offset_in_bytes(){ return offset_of(Klass, _modifier_flags); }
a61af66fc99e Initial load
duke
parents:
diff changeset
372 static int layout_helper_offset_in_bytes() { return offset_of(Klass, _layout_helper); }
a61af66fc99e Initial load
duke
parents:
diff changeset
373 static int access_flags_offset_in_bytes() { return offset_of(Klass, _access_flags); }
a61af66fc99e Initial load
duke
parents:
diff changeset
374
a61af66fc99e Initial load
duke
parents:
diff changeset
375 // Unpacking layout_helper:
a61af66fc99e Initial load
duke
parents:
diff changeset
376 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
377 _lh_neutral_value = 0, // neutral non-array non-instance value
a61af66fc99e Initial load
duke
parents:
diff changeset
378 _lh_instance_slow_path_bit = 0x01,
a61af66fc99e Initial load
duke
parents:
diff changeset
379 _lh_log2_element_size_shift = BitsPerByte*0,
a61af66fc99e Initial load
duke
parents:
diff changeset
380 _lh_log2_element_size_mask = BitsPerLong-1,
a61af66fc99e Initial load
duke
parents:
diff changeset
381 _lh_element_type_shift = BitsPerByte*1,
a61af66fc99e Initial load
duke
parents:
diff changeset
382 _lh_element_type_mask = right_n_bits(BitsPerByte), // shifted mask
a61af66fc99e Initial load
duke
parents:
diff changeset
383 _lh_header_size_shift = BitsPerByte*2,
a61af66fc99e Initial load
duke
parents:
diff changeset
384 _lh_header_size_mask = right_n_bits(BitsPerByte), // shifted mask
a61af66fc99e Initial load
duke
parents:
diff changeset
385 _lh_array_tag_bits = 2,
a61af66fc99e Initial load
duke
parents:
diff changeset
386 _lh_array_tag_shift = BitsPerInt - _lh_array_tag_bits,
a61af66fc99e Initial load
duke
parents:
diff changeset
387 _lh_array_tag_type_value = ~0x00, // 0xC0000000 >> 30
a61af66fc99e Initial load
duke
parents:
diff changeset
388 _lh_array_tag_obj_value = ~0x01 // 0x80000000 >> 30
a61af66fc99e Initial load
duke
parents:
diff changeset
389 };
a61af66fc99e Initial load
duke
parents:
diff changeset
390
a61af66fc99e Initial load
duke
parents:
diff changeset
391 static int layout_helper_size_in_bytes(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
392 assert(lh > (jint)_lh_neutral_value, "must be instance");
a61af66fc99e Initial load
duke
parents:
diff changeset
393 return (int) lh & ~_lh_instance_slow_path_bit;
a61af66fc99e Initial load
duke
parents:
diff changeset
394 }
a61af66fc99e Initial load
duke
parents:
diff changeset
395 static bool layout_helper_needs_slow_path(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
396 assert(lh > (jint)_lh_neutral_value, "must be instance");
a61af66fc99e Initial load
duke
parents:
diff changeset
397 return (lh & _lh_instance_slow_path_bit) != 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
398 }
a61af66fc99e Initial load
duke
parents:
diff changeset
399 static bool layout_helper_is_instance(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
400 return (jint)lh > (jint)_lh_neutral_value;
a61af66fc99e Initial load
duke
parents:
diff changeset
401 }
a61af66fc99e Initial load
duke
parents:
diff changeset
402 static bool layout_helper_is_javaArray(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
403 return (jint)lh < (jint)_lh_neutral_value;
a61af66fc99e Initial load
duke
parents:
diff changeset
404 }
a61af66fc99e Initial load
duke
parents:
diff changeset
405 static bool layout_helper_is_typeArray(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
406 // _lh_array_tag_type_value == (lh >> _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
407 return (juint)lh >= (juint)(_lh_array_tag_type_value << _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
408 }
a61af66fc99e Initial load
duke
parents:
diff changeset
409 static bool layout_helper_is_objArray(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
410 // _lh_array_tag_obj_value == (lh >> _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
411 return (jint)lh < (jint)(_lh_array_tag_type_value << _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
412 }
a61af66fc99e Initial load
duke
parents:
diff changeset
413 static int layout_helper_header_size(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
414 assert(lh < (jint)_lh_neutral_value, "must be array");
a61af66fc99e Initial load
duke
parents:
diff changeset
415 int hsize = (lh >> _lh_header_size_shift) & _lh_header_size_mask;
a61af66fc99e Initial load
duke
parents:
diff changeset
416 assert(hsize > 0 && hsize < (int)sizeof(oopDesc)*3, "sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
417 return hsize;
a61af66fc99e Initial load
duke
parents:
diff changeset
418 }
a61af66fc99e Initial load
duke
parents:
diff changeset
419 static BasicType layout_helper_element_type(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
420 assert(lh < (jint)_lh_neutral_value, "must be array");
a61af66fc99e Initial load
duke
parents:
diff changeset
421 int btvalue = (lh >> _lh_element_type_shift) & _lh_element_type_mask;
a61af66fc99e Initial load
duke
parents:
diff changeset
422 assert(btvalue >= T_BOOLEAN && btvalue <= T_OBJECT, "sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
423 return (BasicType) btvalue;
a61af66fc99e Initial load
duke
parents:
diff changeset
424 }
a61af66fc99e Initial load
duke
parents:
diff changeset
425 static int layout_helper_log2_element_size(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
426 assert(lh < (jint)_lh_neutral_value, "must be array");
a61af66fc99e Initial load
duke
parents:
diff changeset
427 int l2esz = (lh >> _lh_log2_element_size_shift) & _lh_log2_element_size_mask;
a61af66fc99e Initial load
duke
parents:
diff changeset
428 assert(l2esz <= LogBitsPerLong, "sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
429 return l2esz;
a61af66fc99e Initial load
duke
parents:
diff changeset
430 }
a61af66fc99e Initial load
duke
parents:
diff changeset
431 static jint array_layout_helper(jint tag, int hsize, BasicType etype, int log2_esize) {
a61af66fc99e Initial load
duke
parents:
diff changeset
432 return (tag << _lh_array_tag_shift)
a61af66fc99e Initial load
duke
parents:
diff changeset
433 | (hsize << _lh_header_size_shift)
a61af66fc99e Initial load
duke
parents:
diff changeset
434 | ((int)etype << _lh_element_type_shift)
a61af66fc99e Initial load
duke
parents:
diff changeset
435 | (log2_esize << _lh_log2_element_size_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
436 }
a61af66fc99e Initial load
duke
parents:
diff changeset
437 static jint instance_layout_helper(jint size, bool slow_path_flag) {
a61af66fc99e Initial load
duke
parents:
diff changeset
438 return (size << LogHeapWordSize)
a61af66fc99e Initial load
duke
parents:
diff changeset
439 | (slow_path_flag ? _lh_instance_slow_path_bit : 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
440 }
a61af66fc99e Initial load
duke
parents:
diff changeset
441 static int layout_helper_to_size_helper(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
442 assert(lh > (jint)_lh_neutral_value, "must be instance");
a61af66fc99e Initial load
duke
parents:
diff changeset
443 // Note that the following expression discards _lh_instance_slow_path_bit.
a61af66fc99e Initial load
duke
parents:
diff changeset
444 return lh >> LogHeapWordSize;
a61af66fc99e Initial load
duke
parents:
diff changeset
445 }
a61af66fc99e Initial load
duke
parents:
diff changeset
446 // Out-of-line version computes everything based on the etype:
a61af66fc99e Initial load
duke
parents:
diff changeset
447 static jint array_layout_helper(BasicType etype);
a61af66fc99e Initial load
duke
parents:
diff changeset
448
a61af66fc99e Initial load
duke
parents:
diff changeset
449 // What is the maximum number of primary superclasses any klass can have?
a61af66fc99e Initial load
duke
parents:
diff changeset
450 #ifdef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
451 static juint primary_super_limit() { return _primary_super_limit; }
a61af66fc99e Initial load
duke
parents:
diff changeset
452 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
453 static juint primary_super_limit() {
a61af66fc99e Initial load
duke
parents:
diff changeset
454 assert(FastSuperclassLimit <= _primary_super_limit, "parameter oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
455 return FastSuperclassLimit;
a61af66fc99e Initial load
duke
parents:
diff changeset
456 }
a61af66fc99e Initial load
duke
parents:
diff changeset
457 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
458
a61af66fc99e Initial load
duke
parents:
diff changeset
459 // vtables
a61af66fc99e Initial load
duke
parents:
diff changeset
460 virtual klassVtable* vtable() const { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
461
a61af66fc99e Initial load
duke
parents:
diff changeset
462 static int klass_size_in_bytes() { return offset_of(Klass, _alloc_count) + sizeof(juint); } // all "visible" fields
a61af66fc99e Initial load
duke
parents:
diff changeset
463
a61af66fc99e Initial load
duke
parents:
diff changeset
464 // subclass check
a61af66fc99e Initial load
duke
parents:
diff changeset
465 bool is_subclass_of(klassOop k) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
466 // subtype check: true if is_subclass_of, or if k is interface and receiver implements it
a61af66fc99e Initial load
duke
parents:
diff changeset
467 bool is_subtype_of(klassOop k) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
468 juint off = k->klass_part()->super_check_offset();
a61af66fc99e Initial load
duke
parents:
diff changeset
469 klassOop sup = *(klassOop*)( (address)as_klassOop() + off );
a61af66fc99e Initial load
duke
parents:
diff changeset
470 const juint secondary_offset = secondary_super_cache_offset_in_bytes() + sizeof(oopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
471 if (sup == k) {
a61af66fc99e Initial load
duke
parents:
diff changeset
472 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
473 } else if (off != secondary_offset) {
a61af66fc99e Initial load
duke
parents:
diff changeset
474 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
475 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
476 return search_secondary_supers(k);
a61af66fc99e Initial load
duke
parents:
diff changeset
477 }
a61af66fc99e Initial load
duke
parents:
diff changeset
478 }
a61af66fc99e Initial load
duke
parents:
diff changeset
479 bool search_secondary_supers(klassOop k) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
480
605
98cb887364d3 6810672: Comment typos
twisti
parents: 518
diff changeset
481 // Find LCA in class hierarchy
0
a61af66fc99e Initial load
duke
parents:
diff changeset
482 Klass *LCA( Klass *k );
a61af66fc99e Initial load
duke
parents:
diff changeset
483
a61af66fc99e Initial load
duke
parents:
diff changeset
484 // Check whether reflection/jni/jvm code is allowed to instantiate this class;
a61af66fc99e Initial load
duke
parents:
diff changeset
485 // if not, throw either an Error or an Exception.
a61af66fc99e Initial load
duke
parents:
diff changeset
486 virtual void check_valid_for_instantiation(bool throwError, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
487
a61af66fc99e Initial load
duke
parents:
diff changeset
488 // Casting
a61af66fc99e Initial load
duke
parents:
diff changeset
489 static Klass* cast(klassOop k) {
a61af66fc99e Initial load
duke
parents:
diff changeset
490 assert(k->is_klass(), "cast to Klass");
a61af66fc99e Initial load
duke
parents:
diff changeset
491 return k->klass_part();
a61af66fc99e Initial load
duke
parents:
diff changeset
492 }
a61af66fc99e Initial load
duke
parents:
diff changeset
493
a61af66fc99e Initial load
duke
parents:
diff changeset
494 // array copying
a61af66fc99e Initial load
duke
parents:
diff changeset
495 virtual void copy_array(arrayOop s, int src_pos, arrayOop d, int dst_pos, int length, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
496
a61af66fc99e Initial load
duke
parents:
diff changeset
497 // tells if the class should be initialized
a61af66fc99e Initial load
duke
parents:
diff changeset
498 virtual bool should_be_initialized() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
499 // initializes the klass
a61af66fc99e Initial load
duke
parents:
diff changeset
500 virtual void initialize(TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
501 // lookup operation for MethodLookupCache
a61af66fc99e Initial load
duke
parents:
diff changeset
502 friend class MethodLookupCache;
a61af66fc99e Initial load
duke
parents:
diff changeset
503 virtual methodOop uncached_lookup_method(symbolOop name, symbolOop signature) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
504 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
505 methodOop lookup_method(symbolOop name, symbolOop signature) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
506 return uncached_lookup_method(name, signature);
a61af66fc99e Initial load
duke
parents:
diff changeset
507 }
a61af66fc99e Initial load
duke
parents:
diff changeset
508
a61af66fc99e Initial load
duke
parents:
diff changeset
509 // array class with specific rank
a61af66fc99e Initial load
duke
parents:
diff changeset
510 klassOop array_klass(int rank, TRAPS) { return array_klass_impl(false, rank, THREAD); }
a61af66fc99e Initial load
duke
parents:
diff changeset
511
a61af66fc99e Initial load
duke
parents:
diff changeset
512 // array class with this klass as element type
a61af66fc99e Initial load
duke
parents:
diff changeset
513 klassOop array_klass(TRAPS) { return array_klass_impl(false, THREAD); }
a61af66fc99e Initial load
duke
parents:
diff changeset
514
a61af66fc99e Initial load
duke
parents:
diff changeset
515 // These will return NULL instead of allocating on the heap:
a61af66fc99e Initial load
duke
parents:
diff changeset
516 // NB: these can block for a mutex, like other functions with TRAPS arg.
a61af66fc99e Initial load
duke
parents:
diff changeset
517 klassOop array_klass_or_null(int rank);
a61af66fc99e Initial load
duke
parents:
diff changeset
518 klassOop array_klass_or_null();
a61af66fc99e Initial load
duke
parents:
diff changeset
519
a61af66fc99e Initial load
duke
parents:
diff changeset
520 virtual oop protection_domain() { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
521 virtual oop class_loader() const { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
522
a61af66fc99e Initial load
duke
parents:
diff changeset
523 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
524 virtual klassOop array_klass_impl(bool or_null, int rank, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
525 virtual klassOop array_klass_impl(bool or_null, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
526
a61af66fc99e Initial load
duke
parents:
diff changeset
527 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
528 virtual void remove_unshareable_info();
a61af66fc99e Initial load
duke
parents:
diff changeset
529
a61af66fc99e Initial load
duke
parents:
diff changeset
530 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
531 // computes the subtype relationship
a61af66fc99e Initial load
duke
parents:
diff changeset
532 virtual bool compute_is_subtype_of(klassOop k);
a61af66fc99e Initial load
duke
parents:
diff changeset
533 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
534 // subclass accessor (here for convenience; undefined for non-klass objects)
a61af66fc99e Initial load
duke
parents:
diff changeset
535 virtual bool is_leaf_class() const { fatal("not a class"); return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
536 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
537 // ALL FUNCTIONS BELOW THIS POINT ARE DISPATCHED FROM AN OOP
a61af66fc99e Initial load
duke
parents:
diff changeset
538 // These functions describe behavior for the oop not the KLASS.
a61af66fc99e Initial load
duke
parents:
diff changeset
539
a61af66fc99e Initial load
duke
parents:
diff changeset
540 // actual oop size of obj in memory
a61af66fc99e Initial load
duke
parents:
diff changeset
541 virtual int oop_size(oop obj) const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
542
a61af66fc99e Initial load
duke
parents:
diff changeset
543 // actual oop size of this klass in memory
a61af66fc99e Initial load
duke
parents:
diff changeset
544 virtual int klass_oop_size() const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
545
a61af66fc99e Initial load
duke
parents:
diff changeset
546 // Returns the Java name for a class (Resource allocated)
a61af66fc99e Initial load
duke
parents:
diff changeset
547 // For arrays, this returns the name of the element with a leading '['.
a61af66fc99e Initial load
duke
parents:
diff changeset
548 // For classes, this returns the name with the package separators
a61af66fc99e Initial load
duke
parents:
diff changeset
549 // turned into '.'s.
a61af66fc99e Initial load
duke
parents:
diff changeset
550 const char* external_name() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
551 // Returns the name for a class (Resource allocated) as the class
a61af66fc99e Initial load
duke
parents:
diff changeset
552 // would appear in a signature.
a61af66fc99e Initial load
duke
parents:
diff changeset
553 // For arrays, this returns the name of the element with a leading '['.
a61af66fc99e Initial load
duke
parents:
diff changeset
554 // For classes, this returns the name with a leading 'L' and a trailing ';'
a61af66fc99e Initial load
duke
parents:
diff changeset
555 // and the package separators as '/'.
1039
987e948ebbc8 6815692: method handle code needs some cleanup (post-6655638)
jrose
parents: 628
diff changeset
556 virtual const char* signature_name() const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
557
a61af66fc99e Initial load
duke
parents:
diff changeset
558 // garbage collection support
a61af66fc99e Initial load
duke
parents:
diff changeset
559 virtual void oop_follow_contents(oop obj) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
560 virtual int oop_adjust_pointers(oop obj) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
561
a61af66fc99e Initial load
duke
parents:
diff changeset
562 // Parallel Scavenge and Parallel Old
a61af66fc99e Initial load
duke
parents:
diff changeset
563 PARALLEL_GC_DECLS_PV
a61af66fc99e Initial load
duke
parents:
diff changeset
564
a61af66fc99e Initial load
duke
parents:
diff changeset
565 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
566 // type testing operations
a61af66fc99e Initial load
duke
parents:
diff changeset
567 virtual bool oop_is_instance_slow() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
568 virtual bool oop_is_instanceRef() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
569 virtual bool oop_is_array() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
570 virtual bool oop_is_objArray_slow() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
571 virtual bool oop_is_symbol() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
572 virtual bool oop_is_klass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
573 virtual bool oop_is_thread() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
574 virtual bool oop_is_method() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
575 virtual bool oop_is_constMethod() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
576 virtual bool oop_is_methodData() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
577 virtual bool oop_is_constantPool() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
578 virtual bool oop_is_constantPoolCache() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
579 virtual bool oop_is_typeArray_slow() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
580 virtual bool oop_is_arrayKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
581 virtual bool oop_is_objArrayKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
582 virtual bool oop_is_typeArrayKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
583 virtual bool oop_is_compiledICHolder() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
584 virtual bool oop_is_instanceKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
585
a61af66fc99e Initial load
duke
parents:
diff changeset
586 bool oop_is_javaArray_slow() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
587 return oop_is_objArray_slow() || oop_is_typeArray_slow();
a61af66fc99e Initial load
duke
parents:
diff changeset
588 }
a61af66fc99e Initial load
duke
parents:
diff changeset
589
a61af66fc99e Initial load
duke
parents:
diff changeset
590 // Fast non-virtual versions, used by oop.inline.hpp and elsewhere:
a61af66fc99e Initial load
duke
parents:
diff changeset
591 #ifndef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
592 #define assert_same_query(xval, xcheck) xval
a61af66fc99e Initial load
duke
parents:
diff changeset
593 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
594 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
595 static bool assert_same_query(bool xval, bool xslow) {
a61af66fc99e Initial load
duke
parents:
diff changeset
596 assert(xval == xslow, "slow and fast queries agree");
a61af66fc99e Initial load
duke
parents:
diff changeset
597 return xval;
a61af66fc99e Initial load
duke
parents:
diff changeset
598 }
a61af66fc99e Initial load
duke
parents:
diff changeset
599 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
600 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
601 inline bool oop_is_instance() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
602 layout_helper_is_instance(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
603 oop_is_instance_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
604 inline bool oop_is_javaArray() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
605 layout_helper_is_javaArray(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
606 oop_is_javaArray_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
607 inline bool oop_is_objArray() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
608 layout_helper_is_objArray(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
609 oop_is_objArray_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
610 inline bool oop_is_typeArray() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
611 layout_helper_is_typeArray(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
612 oop_is_typeArray_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
613 #undef assert_same_query
a61af66fc99e Initial load
duke
parents:
diff changeset
614
a61af66fc99e Initial load
duke
parents:
diff changeset
615 // Unless overridden, oop is parsable if it has a klass pointer.
518
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
616 // Parsability of an object is object specific.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
617 virtual bool oop_is_parsable(oop obj) const { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
618
518
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
619 // Unless overridden, oop is safe for concurrent GC processing
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
620 // after its allocation is complete. The exception to
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
621 // this is the case where objects are changed after allocation.
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
622 // Class redefinition is one of the known exceptions. During
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
623 // class redefinition, an allocated class can changed in order
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
624 // order to create a merged class (the combiniation of the
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
625 // old class definition that has to be perserved and the new class
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
626 // definition which is being created.
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
627 virtual bool oop_is_conc_safe(oop obj) const { return true; }
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
628
0
a61af66fc99e Initial load
duke
parents:
diff changeset
629 // Access flags
a61af66fc99e Initial load
duke
parents:
diff changeset
630 AccessFlags access_flags() const { return _access_flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
631 void set_access_flags(AccessFlags flags) { _access_flags = flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
632
a61af66fc99e Initial load
duke
parents:
diff changeset
633 bool is_public() const { return _access_flags.is_public(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
634 bool is_final() const { return _access_flags.is_final(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
635 bool is_interface() const { return _access_flags.is_interface(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
636 bool is_abstract() const { return _access_flags.is_abstract(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
637 bool is_super() const { return _access_flags.is_super(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
638 bool is_synthetic() const { return _access_flags.is_synthetic(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
639 void set_is_synthetic() { _access_flags.set_is_synthetic(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
640 bool has_finalizer() const { return _access_flags.has_finalizer(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
641 bool has_final_method() const { return _access_flags.has_final_method(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
642 void set_has_finalizer() { _access_flags.set_has_finalizer(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
643 void set_has_final_method() { _access_flags.set_has_final_method(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
644 bool is_cloneable() const { return _access_flags.is_cloneable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
645 void set_is_cloneable() { _access_flags.set_is_cloneable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
646 bool has_vanilla_constructor() const { return _access_flags.has_vanilla_constructor(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
647 void set_has_vanilla_constructor() { _access_flags.set_has_vanilla_constructor(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
648 bool has_miranda_methods () const { return access_flags().has_miranda_methods(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
649 void set_has_miranda_methods() { _access_flags.set_has_miranda_methods(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
650
a61af66fc99e Initial load
duke
parents:
diff changeset
651 // Biased locking support
a61af66fc99e Initial load
duke
parents:
diff changeset
652 // Note: the prototype header is always set up to be at least the
a61af66fc99e Initial load
duke
parents:
diff changeset
653 // prototype markOop. If biased locking is enabled it may further be
a61af66fc99e Initial load
duke
parents:
diff changeset
654 // biasable and have an epoch.
a61af66fc99e Initial load
duke
parents:
diff changeset
655 markOop prototype_header() const { return _prototype_header; }
a61af66fc99e Initial load
duke
parents:
diff changeset
656 // NOTE: once instances of this klass are floating around in the
a61af66fc99e Initial load
duke
parents:
diff changeset
657 // system, this header must only be updated at a safepoint.
a61af66fc99e Initial load
duke
parents:
diff changeset
658 // NOTE 2: currently we only ever set the prototype header to the
a61af66fc99e Initial load
duke
parents:
diff changeset
659 // biasable prototype for instanceKlasses. There is no technical
a61af66fc99e Initial load
duke
parents:
diff changeset
660 // reason why it could not be done for arrayKlasses aside from
a61af66fc99e Initial load
duke
parents:
diff changeset
661 // wanting to reduce the initial scope of this optimization. There
a61af66fc99e Initial load
duke
parents:
diff changeset
662 // are potential problems in setting the bias pattern for
a61af66fc99e Initial load
duke
parents:
diff changeset
663 // JVM-internal oops.
a61af66fc99e Initial load
duke
parents:
diff changeset
664 inline void set_prototype_header(markOop header);
a61af66fc99e Initial load
duke
parents:
diff changeset
665 static int prototype_header_offset_in_bytes() { return offset_of(Klass, _prototype_header); }
a61af66fc99e Initial load
duke
parents:
diff changeset
666
a61af66fc99e Initial load
duke
parents:
diff changeset
667 int biased_lock_revocation_count() const { return (int) _biased_lock_revocation_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
668 // Atomically increments biased_lock_revocation_count and returns updated value
a61af66fc99e Initial load
duke
parents:
diff changeset
669 int atomic_incr_biased_lock_revocation_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
670 void set_biased_lock_revocation_count(int val) { _biased_lock_revocation_count = (jint) val; }
a61af66fc99e Initial load
duke
parents:
diff changeset
671 jlong last_biased_lock_bulk_revocation_time() { return _last_biased_lock_bulk_revocation_time; }
a61af66fc99e Initial load
duke
parents:
diff changeset
672 void set_last_biased_lock_bulk_revocation_time(jlong cur_time) { _last_biased_lock_bulk_revocation_time = cur_time; }
a61af66fc99e Initial load
duke
parents:
diff changeset
673
a61af66fc99e Initial load
duke
parents:
diff changeset
674
a61af66fc99e Initial load
duke
parents:
diff changeset
675 // garbage collection support
a61af66fc99e Initial load
duke
parents:
diff changeset
676 virtual void follow_weak_klass_links(
a61af66fc99e Initial load
duke
parents:
diff changeset
677 BoolObjectClosure* is_alive, OopClosure* keep_alive);
a61af66fc99e Initial load
duke
parents:
diff changeset
678
a61af66fc99e Initial load
duke
parents:
diff changeset
679 // Prefetch within oop iterators. This is a macro because we
a61af66fc99e Initial load
duke
parents:
diff changeset
680 // can't guarantee that the compiler will inline it. In 64-bit
a61af66fc99e Initial load
duke
parents:
diff changeset
681 // it generally doesn't. Signature is
a61af66fc99e Initial load
duke
parents:
diff changeset
682 //
a61af66fc99e Initial load
duke
parents:
diff changeset
683 // static void prefetch_beyond(oop* const start,
a61af66fc99e Initial load
duke
parents:
diff changeset
684 // oop* const end,
a61af66fc99e Initial load
duke
parents:
diff changeset
685 // const intx foffset,
a61af66fc99e Initial load
duke
parents:
diff changeset
686 // const Prefetch::style pstyle);
a61af66fc99e Initial load
duke
parents:
diff changeset
687 #define prefetch_beyond(start, end, foffset, pstyle) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
688 const intx foffset_ = (foffset); \
a61af66fc99e Initial load
duke
parents:
diff changeset
689 const Prefetch::style pstyle_ = (pstyle); \
a61af66fc99e Initial load
duke
parents:
diff changeset
690 assert(foffset_ > 0, "prefetch beyond, not behind"); \
a61af66fc99e Initial load
duke
parents:
diff changeset
691 if (pstyle_ != Prefetch::do_none) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
692 oop* ref = (start); \
a61af66fc99e Initial load
duke
parents:
diff changeset
693 if (ref < (end)) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
694 switch (pstyle_) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
695 case Prefetch::do_read: \
a61af66fc99e Initial load
duke
parents:
diff changeset
696 Prefetch::read(*ref, foffset_); \
a61af66fc99e Initial load
duke
parents:
diff changeset
697 break; \
a61af66fc99e Initial load
duke
parents:
diff changeset
698 case Prefetch::do_write: \
a61af66fc99e Initial load
duke
parents:
diff changeset
699 Prefetch::write(*ref, foffset_); \
a61af66fc99e Initial load
duke
parents:
diff changeset
700 break; \
a61af66fc99e Initial load
duke
parents:
diff changeset
701 default: \
a61af66fc99e Initial load
duke
parents:
diff changeset
702 ShouldNotReachHere(); \
a61af66fc99e Initial load
duke
parents:
diff changeset
703 break; \
a61af66fc99e Initial load
duke
parents:
diff changeset
704 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
705 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
706 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
707 }
a61af66fc99e Initial load
duke
parents:
diff changeset
708
a61af66fc99e Initial load
duke
parents:
diff changeset
709 // iterators
a61af66fc99e Initial load
duke
parents:
diff changeset
710 virtual int oop_oop_iterate(oop obj, OopClosure* blk) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
711 virtual int oop_oop_iterate_v(oop obj, OopClosure* blk) {
a61af66fc99e Initial load
duke
parents:
diff changeset
712 return oop_oop_iterate(obj, blk);
a61af66fc99e Initial load
duke
parents:
diff changeset
713 }
a61af66fc99e Initial load
duke
parents:
diff changeset
714
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
715 #ifndef SERIALGC
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
716 // In case we don't have a specialized backward scanner use forward
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
717 // iteration.
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
718 virtual int oop_oop_iterate_backwards_v(oop obj, OopClosure* blk) {
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
719 return oop_oop_iterate_v(obj, blk);
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
720 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
721 #endif // !SERIALGC
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
722
0
a61af66fc99e Initial load
duke
parents:
diff changeset
723 // Iterates "blk" over all the oops in "obj" (of type "this") within "mr".
a61af66fc99e Initial load
duke
parents:
diff changeset
724 // (I don't see why the _m should be required, but without it the Solaris
a61af66fc99e Initial load
duke
parents:
diff changeset
725 // C++ gives warning messages about overridings of the "oop_oop_iterate"
a61af66fc99e Initial load
duke
parents:
diff changeset
726 // defined above "hiding" this virtual function. (DLD, 6/20/00)) */
a61af66fc99e Initial load
duke
parents:
diff changeset
727 virtual int oop_oop_iterate_m(oop obj, OopClosure* blk, MemRegion mr) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
728 virtual int oop_oop_iterate_v_m(oop obj, OopClosure* blk, MemRegion mr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
729 return oop_oop_iterate_m(obj, blk, mr);
a61af66fc99e Initial load
duke
parents:
diff changeset
730 }
a61af66fc99e Initial load
duke
parents:
diff changeset
731
a61af66fc99e Initial load
duke
parents:
diff changeset
732 // Versions of the above iterators specialized to particular subtypes
a61af66fc99e Initial load
duke
parents:
diff changeset
733 // of OopClosure, to avoid closure virtual calls.
a61af66fc99e Initial load
duke
parents:
diff changeset
734 #define Klass_OOP_OOP_ITERATE_DECL(OopClosureType, nv_suffix) \
a61af66fc99e Initial load
duke
parents:
diff changeset
735 virtual int oop_oop_iterate##nv_suffix(oop obj, OopClosureType* blk) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
736 /* Default implementation reverts to general version. */ \
a61af66fc99e Initial load
duke
parents:
diff changeset
737 return oop_oop_iterate(obj, blk); \
a61af66fc99e Initial load
duke
parents:
diff changeset
738 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
739 \
a61af66fc99e Initial load
duke
parents:
diff changeset
740 /* Iterates "blk" over all the oops in "obj" (of type "this") within "mr". \
a61af66fc99e Initial load
duke
parents:
diff changeset
741 (I don't see why the _m should be required, but without it the Solaris \
a61af66fc99e Initial load
duke
parents:
diff changeset
742 C++ gives warning messages about overridings of the "oop_oop_iterate" \
a61af66fc99e Initial load
duke
parents:
diff changeset
743 defined above "hiding" this virtual function. (DLD, 6/20/00)) */ \
a61af66fc99e Initial load
duke
parents:
diff changeset
744 virtual int oop_oop_iterate##nv_suffix##_m(oop obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
745 OopClosureType* blk, \
a61af66fc99e Initial load
duke
parents:
diff changeset
746 MemRegion mr) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
747 return oop_oop_iterate_m(obj, blk, mr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
748 }
a61af66fc99e Initial load
duke
parents:
diff changeset
749
a61af66fc99e Initial load
duke
parents:
diff changeset
750 SPECIALIZED_OOP_OOP_ITERATE_CLOSURES_1(Klass_OOP_OOP_ITERATE_DECL)
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
751 SPECIALIZED_OOP_OOP_ITERATE_CLOSURES_2(Klass_OOP_OOP_ITERATE_DECL)
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
752
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
753 #ifndef SERIALGC
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
754 #define Klass_OOP_OOP_ITERATE_BACKWARDS_DECL(OopClosureType, nv_suffix) \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
755 virtual int oop_oop_iterate_backwards##nv_suffix(oop obj, \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
756 OopClosureType* blk) { \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
757 /* Default implementation reverts to general version. */ \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
758 return oop_oop_iterate_backwards_v(obj, blk); \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
759 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
760
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
761 SPECIALIZED_OOP_OOP_ITERATE_CLOSURES_1(Klass_OOP_OOP_ITERATE_BACKWARDS_DECL)
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
762 SPECIALIZED_OOP_OOP_ITERATE_CLOSURES_2(Klass_OOP_OOP_ITERATE_BACKWARDS_DECL)
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
763 #endif // !SERIALGC
0
a61af66fc99e Initial load
duke
parents:
diff changeset
764
a61af66fc99e Initial load
duke
parents:
diff changeset
765 virtual void array_klasses_do(void f(klassOop k)) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
766 virtual void with_array_klasses_do(void f(klassOop k));
a61af66fc99e Initial load
duke
parents:
diff changeset
767
a61af66fc99e Initial load
duke
parents:
diff changeset
768 // Return self, except for abstract classes with exactly 1
a61af66fc99e Initial load
duke
parents:
diff changeset
769 // implementor. Then return the 1 concrete implementation.
a61af66fc99e Initial load
duke
parents:
diff changeset
770 Klass *up_cast_abstract();
a61af66fc99e Initial load
duke
parents:
diff changeset
771
a61af66fc99e Initial load
duke
parents:
diff changeset
772 // klass name
a61af66fc99e Initial load
duke
parents:
diff changeset
773 symbolOop name() const { return _name; }
a61af66fc99e Initial load
duke
parents:
diff changeset
774 void set_name(symbolOop n) { oop_store_without_check((oop*) &_name, (oop) n); }
a61af66fc99e Initial load
duke
parents:
diff changeset
775
a61af66fc99e Initial load
duke
parents:
diff changeset
776 friend class klassKlass;
a61af66fc99e Initial load
duke
parents:
diff changeset
777
a61af66fc99e Initial load
duke
parents:
diff changeset
778 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
779 // jvm support
a61af66fc99e Initial load
duke
parents:
diff changeset
780 virtual jint compute_modifier_flags(TRAPS) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
781
a61af66fc99e Initial load
duke
parents:
diff changeset
782 // JVMTI support
a61af66fc99e Initial load
duke
parents:
diff changeset
783 virtual jint jvmti_class_status() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
784
a61af66fc99e Initial load
duke
parents:
diff changeset
785 // Printing
1155
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1039
diff changeset
786 virtual void oop_print_value_on(oop obj, outputStream* st);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
787 virtual void oop_print_on (oop obj, outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
788
a61af66fc99e Initial load
duke
parents:
diff changeset
789 // Verification
a61af66fc99e Initial load
duke
parents:
diff changeset
790 virtual const char* internal_name() const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
791 virtual void oop_verify_on(oop obj, outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
792 virtual void oop_verify_old_oop(oop obj, oop* p, bool allow_dirty);
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
793 virtual void oop_verify_old_oop(oop obj, narrowOop* p, bool allow_dirty);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
794 // tells whether obj is partially constructed (gc during class loading)
a61af66fc99e Initial load
duke
parents:
diff changeset
795 virtual bool oop_partially_loaded(oop obj) const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
796 virtual void oop_set_partially_loaded(oop obj) {};
a61af66fc99e Initial load
duke
parents:
diff changeset
797
a61af66fc99e Initial load
duke
parents:
diff changeset
798 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
799 void verify_vtable_index(int index);
a61af66fc99e Initial load
duke
parents:
diff changeset
800 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
801 };