annotate src/share/vm/oops/klass.hpp @ 4710:41406797186b

7113012: G1: rename not-fully-young GCs as "mixed" Summary: Renamed partially-young GCs as mixed and fully-young GCs as young. Change all external output that includes those terms (GC log and GC ergo log) as well as any comments, fields, methods, etc. The changeset also includes very minor code tidying up (added some curly brackets). Reviewed-by: johnc, brutisso
author tonyp
date Fri, 16 Dec 2011 02:14:27 -0500
parents c7f3d0b4570f
children 0654ee04b214 069ab3f976d3 94ec88ca68e2
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;
a61af66fc99e Initial load
duke
parents:
diff changeset
240 // Superclass
a61af66fc99e Initial load
duke
parents:
diff changeset
241 klassOop _super;
a61af66fc99e Initial load
duke
parents:
diff changeset
242 // First subclass (NULL if none); _subklass->next_sibling() is next one
a61af66fc99e Initial load
duke
parents:
diff changeset
243 klassOop _subklass;
a61af66fc99e Initial load
duke
parents:
diff changeset
244 // Sibling link (or NULL); links all subklasses of a klass
a61af66fc99e Initial load
duke
parents:
diff changeset
245 klassOop _next_sibling;
a61af66fc99e Initial load
duke
parents:
diff changeset
246
a61af66fc99e Initial load
duke
parents:
diff changeset
247 //
a61af66fc99e Initial load
duke
parents:
diff changeset
248 // End of the oop block.
a61af66fc99e Initial load
duke
parents:
diff changeset
249 //
a61af66fc99e Initial load
duke
parents:
diff changeset
250
a61af66fc99e Initial load
duke
parents:
diff changeset
251 jint _modifier_flags; // Processed access flags, for use by Class.getModifiers.
a61af66fc99e Initial load
duke
parents:
diff changeset
252 AccessFlags _access_flags; // Access flags. The class/interface distinction is stored here.
a61af66fc99e Initial load
duke
parents:
diff changeset
253
a61af66fc99e Initial load
duke
parents:
diff changeset
254 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
255 int _verify_count; // to avoid redundant verifies
a61af66fc99e Initial load
duke
parents:
diff changeset
256 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
257
a61af66fc99e Initial load
duke
parents:
diff changeset
258 juint _alloc_count; // allocation profiling support - update klass_size_in_bytes() if moved/deleted
a61af66fc99e Initial load
duke
parents:
diff changeset
259
a61af66fc99e Initial load
duke
parents:
diff changeset
260 // Biased locking implementation and statistics
a61af66fc99e Initial load
duke
parents:
diff changeset
261 // (the 64-bit chunk goes first, to avoid some fragmentation)
a61af66fc99e Initial load
duke
parents:
diff changeset
262 jlong _last_biased_lock_bulk_revocation_time;
a61af66fc99e Initial load
duke
parents:
diff changeset
263 markOop _prototype_header; // Used when biased locking is both enabled and disabled for this type
a61af66fc99e Initial load
duke
parents:
diff changeset
264 jint _biased_lock_revocation_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
265
a61af66fc99e Initial load
duke
parents:
diff changeset
266 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
267
a61af66fc99e Initial load
duke
parents:
diff changeset
268 // returns the enclosing klassOop
a61af66fc99e Initial load
duke
parents:
diff changeset
269 klassOop as_klassOop() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
270 // see klassOop.hpp for layout.
a61af66fc99e Initial load
duke
parents:
diff changeset
271 return (klassOop) (((char*) this) - sizeof(klassOopDesc));
a61af66fc99e Initial load
duke
parents:
diff changeset
272 }
a61af66fc99e Initial load
duke
parents:
diff changeset
273
a61af66fc99e Initial load
duke
parents:
diff changeset
274 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
275 // Allocation
a61af66fc99e Initial load
duke
parents:
diff changeset
276 const Klass_vtbl& vtbl_value() const { return *this; } // used only on "example instances"
a61af66fc99e Initial load
duke
parents:
diff changeset
277 static KlassHandle base_create_klass(KlassHandle& klass, int size, const Klass_vtbl& vtbl, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
278 static klassOop base_create_klass_oop(KlassHandle& klass, int size, const Klass_vtbl& vtbl, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
279
a61af66fc99e Initial load
duke
parents:
diff changeset
280 // super
a61af66fc99e Initial load
duke
parents:
diff changeset
281 klassOop super() const { return _super; }
a61af66fc99e Initial load
duke
parents:
diff changeset
282 void set_super(klassOop k) { oop_store_without_check((oop*) &_super, (oop) k); }
a61af66fc99e Initial load
duke
parents:
diff changeset
283
a61af66fc99e Initial load
duke
parents:
diff changeset
284 // initializes _super link, _primary_supers & _secondary_supers arrays
a61af66fc99e Initial load
duke
parents:
diff changeset
285 void initialize_supers(klassOop k, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
286 void initialize_supers_impl1(klassOop k);
a61af66fc99e Initial load
duke
parents:
diff changeset
287 void initialize_supers_impl2(klassOop k);
a61af66fc99e Initial load
duke
parents:
diff changeset
288
a61af66fc99e Initial load
duke
parents:
diff changeset
289 // klass-specific helper for initializing _secondary_supers
a61af66fc99e Initial load
duke
parents:
diff changeset
290 virtual objArrayOop compute_secondary_supers(int num_extra_slots, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
291
a61af66fc99e Initial load
duke
parents:
diff changeset
292 // java_super is the Java-level super type as specified by Class.getSuperClass.
a61af66fc99e Initial load
duke
parents:
diff changeset
293 virtual klassOop java_super() const { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
294
a61af66fc99e Initial load
duke
parents:
diff changeset
295 juint super_check_offset() const { return _super_check_offset; }
a61af66fc99e Initial load
duke
parents:
diff changeset
296 void set_super_check_offset(juint o) { _super_check_offset = o; }
a61af66fc99e Initial load
duke
parents:
diff changeset
297
a61af66fc99e Initial load
duke
parents:
diff changeset
298 klassOop secondary_super_cache() const { return _secondary_super_cache; }
a61af66fc99e Initial load
duke
parents:
diff changeset
299 void set_secondary_super_cache(klassOop k) { oop_store_without_check((oop*) &_secondary_super_cache, (oop) k); }
a61af66fc99e Initial load
duke
parents:
diff changeset
300
a61af66fc99e Initial load
duke
parents:
diff changeset
301 objArrayOop secondary_supers() const { return _secondary_supers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
302 void set_secondary_supers(objArrayOop k) { oop_store_without_check((oop*) &_secondary_supers, (oop) k); }
a61af66fc99e Initial load
duke
parents:
diff changeset
303
a61af66fc99e Initial load
duke
parents:
diff changeset
304 // Return the element of the _super chain of the given depth.
a61af66fc99e Initial load
duke
parents:
diff changeset
305 // If there is no such element, return either NULL or this.
a61af66fc99e Initial load
duke
parents:
diff changeset
306 klassOop primary_super_of_depth(juint i) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
307 assert(i < primary_super_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
308 klassOop super = _primary_supers[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
309 assert(super == NULL || super->klass_part()->super_depth() == i, "correct display");
a61af66fc99e Initial load
duke
parents:
diff changeset
310 return super;
a61af66fc99e Initial load
duke
parents:
diff changeset
311 }
a61af66fc99e Initial load
duke
parents:
diff changeset
312
a61af66fc99e Initial load
duke
parents:
diff changeset
313 // Can this klass be a primary super? False for interfaces and arrays of
a61af66fc99e Initial load
duke
parents:
diff changeset
314 // interfaces. False also for arrays or classes with long super chains.
a61af66fc99e Initial load
duke
parents:
diff changeset
315 bool can_be_primary_super() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
316 const juint secondary_offset = secondary_super_cache_offset_in_bytes() + sizeof(oopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
317 return super_check_offset() != secondary_offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
318 }
a61af66fc99e Initial load
duke
parents:
diff changeset
319 virtual bool can_be_primary_super_slow() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
320
a61af66fc99e Initial load
duke
parents:
diff changeset
321 // Returns number of primary supers; may be a number in the inclusive range [0, primary_super_limit].
a61af66fc99e Initial load
duke
parents:
diff changeset
322 juint super_depth() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
323 if (!can_be_primary_super()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
324 return primary_super_limit();
a61af66fc99e Initial load
duke
parents:
diff changeset
325 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
326 juint d = (super_check_offset() - (primary_supers_offset_in_bytes() + sizeof(oopDesc))) / sizeof(klassOop);
a61af66fc99e Initial load
duke
parents:
diff changeset
327 assert(d < primary_super_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
328 assert(_primary_supers[d] == as_klassOop(), "proper init");
a61af66fc99e Initial load
duke
parents:
diff changeset
329 return d;
a61af66fc99e Initial load
duke
parents:
diff changeset
330 }
a61af66fc99e Initial load
duke
parents:
diff changeset
331 }
a61af66fc99e Initial load
duke
parents:
diff changeset
332
a61af66fc99e Initial load
duke
parents:
diff changeset
333 // java mirror
a61af66fc99e Initial load
duke
parents:
diff changeset
334 oop java_mirror() const { return _java_mirror; }
a61af66fc99e Initial load
duke
parents:
diff changeset
335 void set_java_mirror(oop m) { oop_store((oop*) &_java_mirror, m); }
a61af66fc99e Initial load
duke
parents:
diff changeset
336
a61af66fc99e Initial load
duke
parents:
diff changeset
337 // modifier flags
a61af66fc99e Initial load
duke
parents:
diff changeset
338 jint modifier_flags() const { return _modifier_flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
339 void set_modifier_flags(jint flags) { _modifier_flags = flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
340
a61af66fc99e Initial load
duke
parents:
diff changeset
341 // size helper
a61af66fc99e Initial load
duke
parents:
diff changeset
342 int layout_helper() const { return _layout_helper; }
a61af66fc99e Initial load
duke
parents:
diff changeset
343 void set_layout_helper(int lh) { _layout_helper = lh; }
a61af66fc99e Initial load
duke
parents:
diff changeset
344
a61af66fc99e Initial load
duke
parents:
diff changeset
345 // Note: for instances layout_helper() may include padding.
a61af66fc99e Initial load
duke
parents:
diff changeset
346 // Use instanceKlass::contains_field_offset to classify field offsets.
a61af66fc99e Initial load
duke
parents:
diff changeset
347
a61af66fc99e Initial load
duke
parents:
diff changeset
348 // sub/superklass links
a61af66fc99e Initial load
duke
parents:
diff changeset
349 instanceKlass* superklass() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
350 Klass* subklass() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
351 Klass* next_sibling() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
352 void append_to_sibling_list(); // add newly created receiver to superklass' subklass list
a61af66fc99e Initial load
duke
parents:
diff changeset
353 void remove_from_sibling_list(); // remove receiver from sibling list
a61af66fc99e Initial load
duke
parents:
diff changeset
354 protected: // internal accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
355 klassOop subklass_oop() const { return _subklass; }
a61af66fc99e Initial load
duke
parents:
diff changeset
356 klassOop next_sibling_oop() const { return _next_sibling; }
a61af66fc99e Initial load
duke
parents:
diff changeset
357 void set_subklass(klassOop s);
a61af66fc99e Initial load
duke
parents:
diff changeset
358 void set_next_sibling(klassOop s);
a61af66fc99e Initial load
duke
parents:
diff changeset
359
a61af66fc99e Initial load
duke
parents:
diff changeset
360 oop* adr_super() const { return (oop*)&_super; }
a61af66fc99e Initial load
duke
parents:
diff changeset
361 oop* adr_primary_supers() const { return (oop*)&_primary_supers[0]; }
a61af66fc99e Initial load
duke
parents:
diff changeset
362 oop* adr_secondary_super_cache() const { return (oop*)&_secondary_super_cache; }
a61af66fc99e Initial load
duke
parents:
diff changeset
363 oop* adr_secondary_supers()const { return (oop*)&_secondary_supers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
364 oop* adr_java_mirror() const { return (oop*)&_java_mirror; }
a61af66fc99e Initial load
duke
parents:
diff changeset
365 oop* adr_subklass() const { return (oop*)&_subklass; }
a61af66fc99e Initial load
duke
parents:
diff changeset
366 oop* adr_next_sibling() const { return (oop*)&_next_sibling; }
a61af66fc99e Initial load
duke
parents:
diff changeset
367
a61af66fc99e Initial load
duke
parents:
diff changeset
368 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
369 // Allocation profiling support
a61af66fc99e Initial load
duke
parents:
diff changeset
370 juint alloc_count() const { return _alloc_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
371 void set_alloc_count(juint n) { _alloc_count = n; }
a61af66fc99e Initial load
duke
parents:
diff changeset
372 virtual juint alloc_size() const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
373 virtual void set_alloc_size(juint n) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
374
a61af66fc99e Initial load
duke
parents:
diff changeset
375 // Compiler support
a61af66fc99e Initial load
duke
parents:
diff changeset
376 static int super_offset_in_bytes() { return offset_of(Klass, _super); }
a61af66fc99e Initial load
duke
parents:
diff changeset
377 static int super_check_offset_offset_in_bytes() { return offset_of(Klass, _super_check_offset); }
a61af66fc99e Initial load
duke
parents:
diff changeset
378 static int primary_supers_offset_in_bytes(){ return offset_of(Klass, _primary_supers); }
a61af66fc99e Initial load
duke
parents:
diff changeset
379 static int secondary_super_cache_offset_in_bytes() { return offset_of(Klass, _secondary_super_cache); }
a61af66fc99e Initial load
duke
parents:
diff changeset
380 static int secondary_supers_offset_in_bytes() { return offset_of(Klass, _secondary_supers); }
a61af66fc99e Initial load
duke
parents:
diff changeset
381 static int java_mirror_offset_in_bytes() { return offset_of(Klass, _java_mirror); }
a61af66fc99e Initial load
duke
parents:
diff changeset
382 static int modifier_flags_offset_in_bytes(){ return offset_of(Klass, _modifier_flags); }
a61af66fc99e Initial load
duke
parents:
diff changeset
383 static int layout_helper_offset_in_bytes() { return offset_of(Klass, _layout_helper); }
a61af66fc99e Initial load
duke
parents:
diff changeset
384 static int access_flags_offset_in_bytes() { return offset_of(Klass, _access_flags); }
a61af66fc99e Initial load
duke
parents:
diff changeset
385
a61af66fc99e Initial load
duke
parents:
diff changeset
386 // Unpacking layout_helper:
a61af66fc99e Initial load
duke
parents:
diff changeset
387 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
388 _lh_neutral_value = 0, // neutral non-array non-instance value
a61af66fc99e Initial load
duke
parents:
diff changeset
389 _lh_instance_slow_path_bit = 0x01,
a61af66fc99e Initial load
duke
parents:
diff changeset
390 _lh_log2_element_size_shift = BitsPerByte*0,
a61af66fc99e Initial load
duke
parents:
diff changeset
391 _lh_log2_element_size_mask = BitsPerLong-1,
a61af66fc99e Initial load
duke
parents:
diff changeset
392 _lh_element_type_shift = BitsPerByte*1,
a61af66fc99e Initial load
duke
parents:
diff changeset
393 _lh_element_type_mask = right_n_bits(BitsPerByte), // shifted mask
a61af66fc99e Initial load
duke
parents:
diff changeset
394 _lh_header_size_shift = BitsPerByte*2,
a61af66fc99e Initial load
duke
parents:
diff changeset
395 _lh_header_size_mask = right_n_bits(BitsPerByte), // shifted mask
a61af66fc99e Initial load
duke
parents:
diff changeset
396 _lh_array_tag_bits = 2,
a61af66fc99e Initial load
duke
parents:
diff changeset
397 _lh_array_tag_shift = BitsPerInt - _lh_array_tag_bits,
a61af66fc99e Initial load
duke
parents:
diff changeset
398 _lh_array_tag_type_value = ~0x00, // 0xC0000000 >> 30
a61af66fc99e Initial load
duke
parents:
diff changeset
399 _lh_array_tag_obj_value = ~0x01 // 0x80000000 >> 30
a61af66fc99e Initial load
duke
parents:
diff changeset
400 };
a61af66fc99e Initial load
duke
parents:
diff changeset
401
a61af66fc99e Initial load
duke
parents:
diff changeset
402 static int layout_helper_size_in_bytes(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
403 assert(lh > (jint)_lh_neutral_value, "must be instance");
a61af66fc99e Initial load
duke
parents:
diff changeset
404 return (int) lh & ~_lh_instance_slow_path_bit;
a61af66fc99e Initial load
duke
parents:
diff changeset
405 }
a61af66fc99e Initial load
duke
parents:
diff changeset
406 static bool layout_helper_needs_slow_path(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
407 assert(lh > (jint)_lh_neutral_value, "must be instance");
a61af66fc99e Initial load
duke
parents:
diff changeset
408 return (lh & _lh_instance_slow_path_bit) != 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
409 }
a61af66fc99e Initial load
duke
parents:
diff changeset
410 static bool layout_helper_is_instance(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
411 return (jint)lh > (jint)_lh_neutral_value;
a61af66fc99e Initial load
duke
parents:
diff changeset
412 }
a61af66fc99e Initial load
duke
parents:
diff changeset
413 static bool layout_helper_is_javaArray(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
414 return (jint)lh < (jint)_lh_neutral_value;
a61af66fc99e Initial load
duke
parents:
diff changeset
415 }
a61af66fc99e Initial load
duke
parents:
diff changeset
416 static bool layout_helper_is_typeArray(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
417 // _lh_array_tag_type_value == (lh >> _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
418 return (juint)lh >= (juint)(_lh_array_tag_type_value << _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
419 }
a61af66fc99e Initial load
duke
parents:
diff changeset
420 static bool layout_helper_is_objArray(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
421 // _lh_array_tag_obj_value == (lh >> _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
422 return (jint)lh < (jint)(_lh_array_tag_type_value << _lh_array_tag_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
423 }
a61af66fc99e Initial load
duke
parents:
diff changeset
424 static int layout_helper_header_size(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
425 assert(lh < (jint)_lh_neutral_value, "must be array");
a61af66fc99e Initial load
duke
parents:
diff changeset
426 int hsize = (lh >> _lh_header_size_shift) & _lh_header_size_mask;
a61af66fc99e Initial load
duke
parents:
diff changeset
427 assert(hsize > 0 && hsize < (int)sizeof(oopDesc)*3, "sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
428 return hsize;
a61af66fc99e Initial load
duke
parents:
diff changeset
429 }
a61af66fc99e Initial load
duke
parents:
diff changeset
430 static BasicType layout_helper_element_type(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
431 assert(lh < (jint)_lh_neutral_value, "must be array");
a61af66fc99e Initial load
duke
parents:
diff changeset
432 int btvalue = (lh >> _lh_element_type_shift) & _lh_element_type_mask;
a61af66fc99e Initial load
duke
parents:
diff changeset
433 assert(btvalue >= T_BOOLEAN && btvalue <= T_OBJECT, "sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
434 return (BasicType) btvalue;
a61af66fc99e Initial load
duke
parents:
diff changeset
435 }
a61af66fc99e Initial load
duke
parents:
diff changeset
436 static int layout_helper_log2_element_size(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
437 assert(lh < (jint)_lh_neutral_value, "must be array");
a61af66fc99e Initial load
duke
parents:
diff changeset
438 int l2esz = (lh >> _lh_log2_element_size_shift) & _lh_log2_element_size_mask;
a61af66fc99e Initial load
duke
parents:
diff changeset
439 assert(l2esz <= LogBitsPerLong, "sanity");
a61af66fc99e Initial load
duke
parents:
diff changeset
440 return l2esz;
a61af66fc99e Initial load
duke
parents:
diff changeset
441 }
a61af66fc99e Initial load
duke
parents:
diff changeset
442 static jint array_layout_helper(jint tag, int hsize, BasicType etype, int log2_esize) {
a61af66fc99e Initial load
duke
parents:
diff changeset
443 return (tag << _lh_array_tag_shift)
a61af66fc99e Initial load
duke
parents:
diff changeset
444 | (hsize << _lh_header_size_shift)
a61af66fc99e Initial load
duke
parents:
diff changeset
445 | ((int)etype << _lh_element_type_shift)
a61af66fc99e Initial load
duke
parents:
diff changeset
446 | (log2_esize << _lh_log2_element_size_shift);
a61af66fc99e Initial load
duke
parents:
diff changeset
447 }
a61af66fc99e Initial load
duke
parents:
diff changeset
448 static jint instance_layout_helper(jint size, bool slow_path_flag) {
a61af66fc99e Initial load
duke
parents:
diff changeset
449 return (size << LogHeapWordSize)
a61af66fc99e Initial load
duke
parents:
diff changeset
450 | (slow_path_flag ? _lh_instance_slow_path_bit : 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
451 }
a61af66fc99e Initial load
duke
parents:
diff changeset
452 static int layout_helper_to_size_helper(jint lh) {
a61af66fc99e Initial load
duke
parents:
diff changeset
453 assert(lh > (jint)_lh_neutral_value, "must be instance");
a61af66fc99e Initial load
duke
parents:
diff changeset
454 // Note that the following expression discards _lh_instance_slow_path_bit.
a61af66fc99e Initial load
duke
parents:
diff changeset
455 return lh >> LogHeapWordSize;
a61af66fc99e Initial load
duke
parents:
diff changeset
456 }
a61af66fc99e Initial load
duke
parents:
diff changeset
457 // Out-of-line version computes everything based on the etype:
a61af66fc99e Initial load
duke
parents:
diff changeset
458 static jint array_layout_helper(BasicType etype);
a61af66fc99e Initial load
duke
parents:
diff changeset
459
a61af66fc99e Initial load
duke
parents:
diff changeset
460 // What is the maximum number of primary superclasses any klass can have?
a61af66fc99e Initial load
duke
parents:
diff changeset
461 #ifdef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
462 static juint primary_super_limit() { return _primary_super_limit; }
a61af66fc99e Initial load
duke
parents:
diff changeset
463 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
464 static juint primary_super_limit() {
a61af66fc99e Initial load
duke
parents:
diff changeset
465 assert(FastSuperclassLimit <= _primary_super_limit, "parameter oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
466 return FastSuperclassLimit;
a61af66fc99e Initial load
duke
parents:
diff changeset
467 }
a61af66fc99e Initial load
duke
parents:
diff changeset
468 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
469
a61af66fc99e Initial load
duke
parents:
diff changeset
470 // vtables
a61af66fc99e Initial load
duke
parents:
diff changeset
471 virtual klassVtable* vtable() const { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
472
a61af66fc99e Initial load
duke
parents:
diff changeset
473 static int klass_size_in_bytes() { return offset_of(Klass, _alloc_count) + sizeof(juint); } // all "visible" fields
a61af66fc99e Initial load
duke
parents:
diff changeset
474
a61af66fc99e Initial load
duke
parents:
diff changeset
475 // subclass check
a61af66fc99e Initial load
duke
parents:
diff changeset
476 bool is_subclass_of(klassOop k) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
477 // subtype check: true if is_subclass_of, or if k is interface and receiver implements it
a61af66fc99e Initial load
duke
parents:
diff changeset
478 bool is_subtype_of(klassOop k) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
479 juint off = k->klass_part()->super_check_offset();
a61af66fc99e Initial load
duke
parents:
diff changeset
480 klassOop sup = *(klassOop*)( (address)as_klassOop() + off );
a61af66fc99e Initial load
duke
parents:
diff changeset
481 const juint secondary_offset = secondary_super_cache_offset_in_bytes() + sizeof(oopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
482 if (sup == k) {
a61af66fc99e Initial load
duke
parents:
diff changeset
483 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
484 } else if (off != secondary_offset) {
a61af66fc99e Initial load
duke
parents:
diff changeset
485 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
486 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
487 return search_secondary_supers(k);
a61af66fc99e Initial load
duke
parents:
diff changeset
488 }
a61af66fc99e Initial load
duke
parents:
diff changeset
489 }
a61af66fc99e Initial load
duke
parents:
diff changeset
490 bool search_secondary_supers(klassOop k) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
491
605
98cb887364d3 6810672: Comment typos
twisti
parents: 518
diff changeset
492 // Find LCA in class hierarchy
0
a61af66fc99e Initial load
duke
parents:
diff changeset
493 Klass *LCA( Klass *k );
a61af66fc99e Initial load
duke
parents:
diff changeset
494
a61af66fc99e Initial load
duke
parents:
diff changeset
495 // Check whether reflection/jni/jvm code is allowed to instantiate this class;
a61af66fc99e Initial load
duke
parents:
diff changeset
496 // if not, throw either an Error or an Exception.
a61af66fc99e Initial load
duke
parents:
diff changeset
497 virtual void check_valid_for_instantiation(bool throwError, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
498
a61af66fc99e Initial load
duke
parents:
diff changeset
499 // Casting
a61af66fc99e Initial load
duke
parents:
diff changeset
500 static Klass* cast(klassOop k) {
a61af66fc99e Initial load
duke
parents:
diff changeset
501 assert(k->is_klass(), "cast to Klass");
a61af66fc99e Initial load
duke
parents:
diff changeset
502 return k->klass_part();
a61af66fc99e Initial load
duke
parents:
diff changeset
503 }
a61af66fc99e Initial load
duke
parents:
diff changeset
504
a61af66fc99e Initial load
duke
parents:
diff changeset
505 // array copying
a61af66fc99e Initial load
duke
parents:
diff changeset
506 virtual void copy_array(arrayOop s, int src_pos, arrayOop d, int dst_pos, int length, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
507
a61af66fc99e Initial load
duke
parents:
diff changeset
508 // tells if the class should be initialized
a61af66fc99e Initial load
duke
parents:
diff changeset
509 virtual bool should_be_initialized() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
510 // initializes the klass
a61af66fc99e Initial load
duke
parents:
diff changeset
511 virtual void initialize(TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
512 // lookup operation for MethodLookupCache
a61af66fc99e Initial load
duke
parents:
diff changeset
513 friend class MethodLookupCache;
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
514 virtual methodOop uncached_lookup_method(Symbol* name, Symbol* signature) const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
515 public:
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
516 methodOop lookup_method(Symbol* name, Symbol* signature) const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
517 return uncached_lookup_method(name, signature);
a61af66fc99e Initial load
duke
parents:
diff changeset
518 }
a61af66fc99e Initial load
duke
parents:
diff changeset
519
a61af66fc99e Initial load
duke
parents:
diff changeset
520 // array class with specific rank
a61af66fc99e Initial load
duke
parents:
diff changeset
521 klassOop array_klass(int rank, TRAPS) { return array_klass_impl(false, rank, THREAD); }
a61af66fc99e Initial load
duke
parents:
diff changeset
522
a61af66fc99e Initial load
duke
parents:
diff changeset
523 // array class with this klass as element type
a61af66fc99e Initial load
duke
parents:
diff changeset
524 klassOop array_klass(TRAPS) { return array_klass_impl(false, THREAD); }
a61af66fc99e Initial load
duke
parents:
diff changeset
525
a61af66fc99e Initial load
duke
parents:
diff changeset
526 // These will return NULL instead of allocating on the heap:
a61af66fc99e Initial load
duke
parents:
diff changeset
527 // NB: these can block for a mutex, like other functions with TRAPS arg.
a61af66fc99e Initial load
duke
parents:
diff changeset
528 klassOop array_klass_or_null(int rank);
a61af66fc99e Initial load
duke
parents:
diff changeset
529 klassOop array_klass_or_null();
a61af66fc99e Initial load
duke
parents:
diff changeset
530
a61af66fc99e Initial load
duke
parents:
diff changeset
531 virtual oop protection_domain() { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
532 virtual oop class_loader() const { return NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
533
a61af66fc99e Initial load
duke
parents:
diff changeset
534 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
535 virtual klassOop array_klass_impl(bool or_null, int rank, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
536 virtual klassOop array_klass_impl(bool or_null, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
537
a61af66fc99e Initial load
duke
parents:
diff changeset
538 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
539 virtual void remove_unshareable_info();
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
540 virtual void shared_symbols_iterate(SymbolClosure* closure);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
541
a61af66fc99e Initial load
duke
parents:
diff changeset
542 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
543 // computes the subtype relationship
a61af66fc99e Initial load
duke
parents:
diff changeset
544 virtual bool compute_is_subtype_of(klassOop k);
a61af66fc99e Initial load
duke
parents:
diff changeset
545 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
546 // subclass accessor (here for convenience; undefined for non-klass objects)
a61af66fc99e Initial load
duke
parents:
diff changeset
547 virtual bool is_leaf_class() const { fatal("not a class"); return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
548 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
549 // ALL FUNCTIONS BELOW THIS POINT ARE DISPATCHED FROM AN OOP
a61af66fc99e Initial load
duke
parents:
diff changeset
550 // These functions describe behavior for the oop not the KLASS.
a61af66fc99e Initial load
duke
parents:
diff changeset
551
a61af66fc99e Initial load
duke
parents:
diff changeset
552 // actual oop size of obj in memory
a61af66fc99e Initial load
duke
parents:
diff changeset
553 virtual int oop_size(oop obj) const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
554
a61af66fc99e Initial load
duke
parents:
diff changeset
555 // actual oop size of this klass in memory
a61af66fc99e Initial load
duke
parents:
diff changeset
556 virtual int klass_oop_size() const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
557
a61af66fc99e Initial load
duke
parents:
diff changeset
558 // Returns the Java name for a class (Resource allocated)
a61af66fc99e Initial load
duke
parents:
diff changeset
559 // For arrays, this returns the name of the element with a leading '['.
a61af66fc99e Initial load
duke
parents:
diff changeset
560 // For classes, this returns the name with the package separators
a61af66fc99e Initial load
duke
parents:
diff changeset
561 // turned into '.'s.
a61af66fc99e Initial load
duke
parents:
diff changeset
562 const char* external_name() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
563 // Returns the name for a class (Resource allocated) as the class
a61af66fc99e Initial load
duke
parents:
diff changeset
564 // would appear in a signature.
a61af66fc99e Initial load
duke
parents:
diff changeset
565 // For arrays, this returns the name of the element with a leading '['.
a61af66fc99e Initial load
duke
parents:
diff changeset
566 // For classes, this returns the name with a leading 'L' and a trailing ';'
a61af66fc99e Initial load
duke
parents:
diff changeset
567 // and the package separators as '/'.
1039
987e948ebbc8 6815692: method handle code needs some cleanup (post-6655638)
jrose
parents: 628
diff changeset
568 virtual const char* signature_name() const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
569
a61af66fc99e Initial load
duke
parents:
diff changeset
570 // garbage collection support
a61af66fc99e Initial load
duke
parents:
diff changeset
571 virtual void oop_follow_contents(oop obj) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
572 virtual int oop_adjust_pointers(oop obj) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
573
a61af66fc99e Initial load
duke
parents:
diff changeset
574 // Parallel Scavenge and Parallel Old
a61af66fc99e Initial load
duke
parents:
diff changeset
575 PARALLEL_GC_DECLS_PV
a61af66fc99e Initial load
duke
parents:
diff changeset
576
a61af66fc99e Initial load
duke
parents:
diff changeset
577 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
578 // type testing operations
a61af66fc99e Initial load
duke
parents:
diff changeset
579 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
580 virtual bool oop_is_instanceMirror() const { return false; }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
581 virtual bool oop_is_instanceRef() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
582 virtual bool oop_is_array() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
583 virtual bool oop_is_objArray_slow() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
584 virtual bool oop_is_klass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
585 virtual bool oop_is_thread() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
586 virtual bool oop_is_method() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
587 virtual bool oop_is_constMethod() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
588 virtual bool oop_is_methodData() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
589 virtual bool oop_is_constantPool() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
590 virtual bool oop_is_constantPoolCache() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
591 virtual bool oop_is_typeArray_slow() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
592 virtual bool oop_is_arrayKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
593 virtual bool oop_is_objArrayKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
594 virtual bool oop_is_typeArrayKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
595 virtual bool oop_is_compiledICHolder() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
596 virtual bool oop_is_instanceKlass() const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
597
a61af66fc99e Initial load
duke
parents:
diff changeset
598 bool oop_is_javaArray_slow() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
599 return oop_is_objArray_slow() || oop_is_typeArray_slow();
a61af66fc99e Initial load
duke
parents:
diff changeset
600 }
a61af66fc99e Initial load
duke
parents:
diff changeset
601
a61af66fc99e Initial load
duke
parents:
diff changeset
602 // Fast non-virtual versions, used by oop.inline.hpp and elsewhere:
a61af66fc99e Initial load
duke
parents:
diff changeset
603 #ifndef ASSERT
a61af66fc99e Initial load
duke
parents:
diff changeset
604 #define assert_same_query(xval, xcheck) xval
a61af66fc99e Initial load
duke
parents:
diff changeset
605 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
606 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
607 static bool assert_same_query(bool xval, bool xslow) {
a61af66fc99e Initial load
duke
parents:
diff changeset
608 assert(xval == xslow, "slow and fast queries agree");
a61af66fc99e Initial load
duke
parents:
diff changeset
609 return xval;
a61af66fc99e Initial load
duke
parents:
diff changeset
610 }
a61af66fc99e Initial load
duke
parents:
diff changeset
611 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
612 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
613 inline bool oop_is_instance() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
614 layout_helper_is_instance(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
615 oop_is_instance_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
616 inline bool oop_is_javaArray() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
617 layout_helper_is_javaArray(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
618 oop_is_javaArray_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
619 inline bool oop_is_objArray() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
620 layout_helper_is_objArray(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
621 oop_is_objArray_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
622 inline bool oop_is_typeArray() const { return assert_same_query(
a61af66fc99e Initial load
duke
parents:
diff changeset
623 layout_helper_is_typeArray(layout_helper()),
a61af66fc99e Initial load
duke
parents:
diff changeset
624 oop_is_typeArray_slow()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
625 #undef assert_same_query
a61af66fc99e Initial load
duke
parents:
diff changeset
626
a61af66fc99e Initial load
duke
parents:
diff changeset
627 // 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
628 // Parsability of an object is object specific.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
629 virtual bool oop_is_parsable(oop obj) const { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
630
518
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 356
diff changeset
631 // 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
632 // 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
633 // 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
634 // 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
635 // 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
636 // 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
637 // 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
638 // 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
639 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
640
0
a61af66fc99e Initial load
duke
parents:
diff changeset
641 // Access flags
a61af66fc99e Initial load
duke
parents:
diff changeset
642 AccessFlags access_flags() const { return _access_flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
643 void set_access_flags(AccessFlags flags) { _access_flags = flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
644
a61af66fc99e Initial load
duke
parents:
diff changeset
645 bool is_public() const { return _access_flags.is_public(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
646 bool is_final() const { return _access_flags.is_final(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
647 bool is_interface() const { return _access_flags.is_interface(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
648 bool is_abstract() const { return _access_flags.is_abstract(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
649 bool is_super() const { return _access_flags.is_super(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
650 bool is_synthetic() const { return _access_flags.is_synthetic(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
651 void set_is_synthetic() { _access_flags.set_is_synthetic(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
652 bool has_finalizer() const { return _access_flags.has_finalizer(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
653 bool has_final_method() const { return _access_flags.has_final_method(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
654 void set_has_finalizer() { _access_flags.set_has_finalizer(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
655 void set_has_final_method() { _access_flags.set_has_final_method(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
656 bool is_cloneable() const { return _access_flags.is_cloneable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
657 void set_is_cloneable() { _access_flags.set_is_cloneable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
658 bool has_vanilla_constructor() const { return _access_flags.has_vanilla_constructor(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
659 void set_has_vanilla_constructor() { _access_flags.set_has_vanilla_constructor(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
660 bool has_miranda_methods () const { return access_flags().has_miranda_methods(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
661 void set_has_miranda_methods() { _access_flags.set_has_miranda_methods(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
662
a61af66fc99e Initial load
duke
parents:
diff changeset
663 // Biased locking support
a61af66fc99e Initial load
duke
parents:
diff changeset
664 // Note: the prototype header is always set up to be at least the
a61af66fc99e Initial load
duke
parents:
diff changeset
665 // prototype markOop. If biased locking is enabled it may further be
a61af66fc99e Initial load
duke
parents:
diff changeset
666 // biasable and have an epoch.
a61af66fc99e Initial load
duke
parents:
diff changeset
667 markOop prototype_header() const { return _prototype_header; }
a61af66fc99e Initial load
duke
parents:
diff changeset
668 // NOTE: once instances of this klass are floating around in the
a61af66fc99e Initial load
duke
parents:
diff changeset
669 // system, this header must only be updated at a safepoint.
a61af66fc99e Initial load
duke
parents:
diff changeset
670 // NOTE 2: currently we only ever set the prototype header to the
a61af66fc99e Initial load
duke
parents:
diff changeset
671 // biasable prototype for instanceKlasses. There is no technical
a61af66fc99e Initial load
duke
parents:
diff changeset
672 // reason why it could not be done for arrayKlasses aside from
a61af66fc99e Initial load
duke
parents:
diff changeset
673 // wanting to reduce the initial scope of this optimization. There
a61af66fc99e Initial load
duke
parents:
diff changeset
674 // are potential problems in setting the bias pattern for
a61af66fc99e Initial load
duke
parents:
diff changeset
675 // JVM-internal oops.
a61af66fc99e Initial load
duke
parents:
diff changeset
676 inline void set_prototype_header(markOop header);
a61af66fc99e Initial load
duke
parents:
diff changeset
677 static int prototype_header_offset_in_bytes() { return offset_of(Klass, _prototype_header); }
a61af66fc99e Initial load
duke
parents:
diff changeset
678
a61af66fc99e Initial load
duke
parents:
diff changeset
679 int biased_lock_revocation_count() const { return (int) _biased_lock_revocation_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
680 // Atomically increments biased_lock_revocation_count and returns updated value
a61af66fc99e Initial load
duke
parents:
diff changeset
681 int atomic_incr_biased_lock_revocation_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
682 void set_biased_lock_revocation_count(int val) { _biased_lock_revocation_count = (jint) val; }
a61af66fc99e Initial load
duke
parents:
diff changeset
683 jlong last_biased_lock_bulk_revocation_time() { return _last_biased_lock_bulk_revocation_time; }
a61af66fc99e Initial load
duke
parents:
diff changeset
684 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
685
a61af66fc99e Initial load
duke
parents:
diff changeset
686
a61af66fc99e Initial load
duke
parents:
diff changeset
687 // garbage collection support
a61af66fc99e Initial load
duke
parents:
diff changeset
688 virtual void follow_weak_klass_links(
a61af66fc99e Initial load
duke
parents:
diff changeset
689 BoolObjectClosure* is_alive, OopClosure* keep_alive);
a61af66fc99e Initial load
duke
parents:
diff changeset
690
a61af66fc99e Initial load
duke
parents:
diff changeset
691 // Prefetch within oop iterators. This is a macro because we
a61af66fc99e Initial load
duke
parents:
diff changeset
692 // can't guarantee that the compiler will inline it. In 64-bit
a61af66fc99e Initial load
duke
parents:
diff changeset
693 // it generally doesn't. Signature is
a61af66fc99e Initial load
duke
parents:
diff changeset
694 //
a61af66fc99e Initial load
duke
parents:
diff changeset
695 // static void prefetch_beyond(oop* const start,
a61af66fc99e Initial load
duke
parents:
diff changeset
696 // oop* const end,
a61af66fc99e Initial load
duke
parents:
diff changeset
697 // const intx foffset,
a61af66fc99e Initial load
duke
parents:
diff changeset
698 // const Prefetch::style pstyle);
a61af66fc99e Initial load
duke
parents:
diff changeset
699 #define prefetch_beyond(start, end, foffset, pstyle) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
700 const intx foffset_ = (foffset); \
a61af66fc99e Initial load
duke
parents:
diff changeset
701 const Prefetch::style pstyle_ = (pstyle); \
a61af66fc99e Initial load
duke
parents:
diff changeset
702 assert(foffset_ > 0, "prefetch beyond, not behind"); \
a61af66fc99e Initial load
duke
parents:
diff changeset
703 if (pstyle_ != Prefetch::do_none) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
704 oop* ref = (start); \
a61af66fc99e Initial load
duke
parents:
diff changeset
705 if (ref < (end)) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
706 switch (pstyle_) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
707 case Prefetch::do_read: \
a61af66fc99e Initial load
duke
parents:
diff changeset
708 Prefetch::read(*ref, foffset_); \
a61af66fc99e Initial load
duke
parents:
diff changeset
709 break; \
a61af66fc99e Initial load
duke
parents:
diff changeset
710 case Prefetch::do_write: \
a61af66fc99e Initial load
duke
parents:
diff changeset
711 Prefetch::write(*ref, foffset_); \
a61af66fc99e Initial load
duke
parents:
diff changeset
712 break; \
a61af66fc99e Initial load
duke
parents:
diff changeset
713 default: \
a61af66fc99e Initial load
duke
parents:
diff changeset
714 ShouldNotReachHere(); \
a61af66fc99e Initial load
duke
parents:
diff changeset
715 break; \
a61af66fc99e Initial load
duke
parents:
diff changeset
716 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
717 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
718 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
719 }
a61af66fc99e Initial load
duke
parents:
diff changeset
720
a61af66fc99e Initial load
duke
parents:
diff changeset
721 // iterators
a61af66fc99e Initial load
duke
parents:
diff changeset
722 virtual int oop_oop_iterate(oop obj, OopClosure* blk) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
723 virtual int oop_oop_iterate_v(oop obj, OopClosure* blk) {
a61af66fc99e Initial load
duke
parents:
diff changeset
724 return oop_oop_iterate(obj, blk);
a61af66fc99e Initial load
duke
parents:
diff changeset
725 }
a61af66fc99e Initial load
duke
parents:
diff changeset
726
342
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
727 #ifndef SERIALGC
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
728 // 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
729 // iteration.
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
730 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
731 return oop_oop_iterate_v(obj, blk);
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
732 }
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
733 #endif // !SERIALGC
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
734
0
a61af66fc99e Initial load
duke
parents:
diff changeset
735 // Iterates "blk" over all the oops in "obj" (of type "this") within "mr".
a61af66fc99e Initial load
duke
parents:
diff changeset
736 // (I don't see why the _m should be required, but without it the Solaris
a61af66fc99e Initial load
duke
parents:
diff changeset
737 // C++ gives warning messages about overridings of the "oop_oop_iterate"
a61af66fc99e Initial load
duke
parents:
diff changeset
738 // defined above "hiding" this virtual function. (DLD, 6/20/00)) */
a61af66fc99e Initial load
duke
parents:
diff changeset
739 virtual int oop_oop_iterate_m(oop obj, OopClosure* blk, MemRegion mr) = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
740 virtual int oop_oop_iterate_v_m(oop obj, OopClosure* blk, MemRegion mr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
741 return oop_oop_iterate_m(obj, blk, mr);
a61af66fc99e Initial load
duke
parents:
diff changeset
742 }
a61af66fc99e Initial load
duke
parents:
diff changeset
743
a61af66fc99e Initial load
duke
parents:
diff changeset
744 // Versions of the above iterators specialized to particular subtypes
a61af66fc99e Initial load
duke
parents:
diff changeset
745 // of OopClosure, to avoid closure virtual calls.
a61af66fc99e Initial load
duke
parents:
diff changeset
746 #define Klass_OOP_OOP_ITERATE_DECL(OopClosureType, nv_suffix) \
a61af66fc99e Initial load
duke
parents:
diff changeset
747 virtual int oop_oop_iterate##nv_suffix(oop obj, OopClosureType* blk) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
748 /* Default implementation reverts to general version. */ \
a61af66fc99e Initial load
duke
parents:
diff changeset
749 return oop_oop_iterate(obj, blk); \
a61af66fc99e Initial load
duke
parents:
diff changeset
750 } \
a61af66fc99e Initial load
duke
parents:
diff changeset
751 \
a61af66fc99e Initial load
duke
parents:
diff changeset
752 /* Iterates "blk" over all the oops in "obj" (of type "this") within "mr". \
a61af66fc99e Initial load
duke
parents:
diff changeset
753 (I don't see why the _m should be required, but without it the Solaris \
a61af66fc99e Initial load
duke
parents:
diff changeset
754 C++ gives warning messages about overridings of the "oop_oop_iterate" \
a61af66fc99e Initial load
duke
parents:
diff changeset
755 defined above "hiding" this virtual function. (DLD, 6/20/00)) */ \
a61af66fc99e Initial load
duke
parents:
diff changeset
756 virtual int oop_oop_iterate##nv_suffix##_m(oop obj, \
a61af66fc99e Initial load
duke
parents:
diff changeset
757 OopClosureType* blk, \
a61af66fc99e Initial load
duke
parents:
diff changeset
758 MemRegion mr) { \
a61af66fc99e Initial load
duke
parents:
diff changeset
759 return oop_oop_iterate_m(obj, blk, mr); \
a61af66fc99e Initial load
duke
parents:
diff changeset
760 }
a61af66fc99e Initial load
duke
parents:
diff changeset
761
a61af66fc99e Initial load
duke
parents:
diff changeset
762 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
763 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
764
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
765 #ifndef SERIALGC
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
766 #define Klass_OOP_OOP_ITERATE_BACKWARDS_DECL(OopClosureType, nv_suffix) \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
767 virtual int oop_oop_iterate_backwards##nv_suffix(oop obj, \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
768 OopClosureType* blk) { \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
769 /* Default implementation reverts to general version. */ \
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
770 return oop_oop_iterate_backwards_v(obj, blk); \
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
37f87013dfd8 6711316: Open source the Garbage-First garbage collector
ysr
parents: 113
diff changeset
773 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
774 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
775 #endif // !SERIALGC
0
a61af66fc99e Initial load
duke
parents:
diff changeset
776
a61af66fc99e Initial load
duke
parents:
diff changeset
777 virtual void array_klasses_do(void f(klassOop k)) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
778 virtual void with_array_klasses_do(void f(klassOop k));
a61af66fc99e Initial load
duke
parents:
diff changeset
779
a61af66fc99e Initial load
duke
parents:
diff changeset
780 // Return self, except for abstract classes with exactly 1
a61af66fc99e Initial load
duke
parents:
diff changeset
781 // implementor. Then return the 1 concrete implementation.
a61af66fc99e Initial load
duke
parents:
diff changeset
782 Klass *up_cast_abstract();
a61af66fc99e Initial load
duke
parents:
diff changeset
783
a61af66fc99e Initial load
duke
parents:
diff changeset
784 // klass name
2177
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
785 Symbol* name() const { return _name; }
3582bf76420e 6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents: 1972
diff changeset
786 void set_name(Symbol* n);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
787
a61af66fc99e Initial load
duke
parents:
diff changeset
788 friend class klassKlass;
a61af66fc99e Initial load
duke
parents:
diff changeset
789
a61af66fc99e Initial load
duke
parents:
diff changeset
790 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
791 // jvm support
a61af66fc99e Initial load
duke
parents:
diff changeset
792 virtual jint compute_modifier_flags(TRAPS) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
793
a61af66fc99e Initial load
duke
parents:
diff changeset
794 // JVMTI support
a61af66fc99e Initial load
duke
parents:
diff changeset
795 virtual jint jvmti_class_status() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
796
a61af66fc99e Initial load
duke
parents:
diff changeset
797 // Printing
1155
4e6abf09f540 6912062: disassembler plugin needs to produce symbolic information in product mode
jrose
parents: 1039
diff changeset
798 virtual void oop_print_value_on(oop obj, outputStream* st);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
799 virtual void oop_print_on (oop obj, outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
800
a61af66fc99e Initial load
duke
parents:
diff changeset
801 // Verification
a61af66fc99e Initial load
duke
parents:
diff changeset
802 virtual const char* internal_name() const = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
803 virtual void oop_verify_on(oop obj, outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
804 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
805 virtual void oop_verify_old_oop(oop obj, narrowOop* p, bool allow_dirty);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
806 // tells whether obj is partially constructed (gc during class loading)
a61af66fc99e Initial load
duke
parents:
diff changeset
807 virtual bool oop_partially_loaded(oop obj) const { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
808 virtual void oop_set_partially_loaded(oop obj) {};
a61af66fc99e Initial load
duke
parents:
diff changeset
809
a61af66fc99e Initial load
duke
parents:
diff changeset
810 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
811 void verify_vtable_index(int index);
a61af66fc99e Initial load
duke
parents:
diff changeset
812 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
813 };
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
814
2376
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2177
diff changeset
815
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2177
diff changeset
816 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
817
c7f3d0b4570f 7017732: move static fields into Class to prepare for perm gen removal
never
parents: 2177
diff changeset
818
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
819 #endif // SHARE_VM_OOPS_KLASS_HPP