annotate src/share/vm/oops/klass.hpp @ 3011:f00918f35c7f

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