annotate src/share/vm/oops/methodData.hpp @ 9126:bc26f978b0ce

HotSpotResolvedObjectType: implement hasFinalizeSubclass() correctly don't use the (wrong) cached value, but ask the runtime on each request. Fixes regression on xml.* benchmarks @ specjvm2008. The problem was: After the constructor of Object was deoptimized due to an assumption violation, it was recompiled again after some time. However, on recompilation, the value of hasFinalizeSubclass for the class was not updated and it was compiled again with a, now wrong, assumption, which then triggers deoptimization again. This was repeated until it hit the recompilation limit (defined by PerMethodRecompilationCutoff), and therefore only executed by the interpreter from now on, causing the performance regression.
author Bernhard Urban <bernhard.urban@jku.at>
date Mon, 15 Apr 2013 19:54:58 +0200
parents 89e4d67fdd2a
children c76b43ed5089
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
2 * Copyright (c) 2000, 2013, 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: 1251
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1251
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: 1251
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: 1783
diff changeset
25 #ifndef SHARE_VM_OOPS_METHODDATAOOP_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
26 #define SHARE_VM_OOPS_METHODDATAOOP_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
27
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
28 #include "interpreter/bytecodes.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
29 #include "memory/universe.hpp"
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
30 #include "oops/method.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
31 #include "oops/oop.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
32 #include "runtime/orderAccess.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
33
0
a61af66fc99e Initial load
duke
parents:
diff changeset
34 class BytecodeStream;
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
35 class KlassSizeStats;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
36
a61af66fc99e Initial load
duke
parents:
diff changeset
37 // The MethodData object collects counts and other profile information
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // during zeroth-tier (interpretive) and first-tier execution.
a61af66fc99e Initial load
duke
parents:
diff changeset
39 // The profile is used later by compilation heuristics. Some heuristics
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // enable use of aggressive (or "heroic") optimizations. An aggressive
a61af66fc99e Initial load
duke
parents:
diff changeset
41 // optimization often has a down-side, a corner case that it handles
a61af66fc99e Initial load
duke
parents:
diff changeset
42 // poorly, but which is thought to be rare. The profile provides
a61af66fc99e Initial load
duke
parents:
diff changeset
43 // evidence of this rarity for a given method or even BCI. It allows
a61af66fc99e Initial load
duke
parents:
diff changeset
44 // the compiler to back out of the optimization at places where it
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // has historically been a poor choice. Other heuristics try to use
a61af66fc99e Initial load
duke
parents:
diff changeset
46 // specific information gathered about types observed at a given site.
a61af66fc99e Initial load
duke
parents:
diff changeset
47 //
a61af66fc99e Initial load
duke
parents:
diff changeset
48 // All data in the profile is approximate. It is expected to be accurate
a61af66fc99e Initial load
duke
parents:
diff changeset
49 // on the whole, but the system expects occasional inaccuraces, due to
a61af66fc99e Initial load
duke
parents:
diff changeset
50 // counter overflow, multiprocessor races during data collection, space
a61af66fc99e Initial load
duke
parents:
diff changeset
51 // limitations, missing MDO blocks, etc. Bad or missing data will degrade
a61af66fc99e Initial load
duke
parents:
diff changeset
52 // optimization quality but will not affect correctness. Also, each MDO
a61af66fc99e Initial load
duke
parents:
diff changeset
53 // is marked with its birth-date ("creation_mileage") which can be used
a61af66fc99e Initial load
duke
parents:
diff changeset
54 // to assess the quality ("maturity") of its data.
a61af66fc99e Initial load
duke
parents:
diff changeset
55 //
a61af66fc99e Initial load
duke
parents:
diff changeset
56 // Short (<32-bit) counters are designed to overflow to a known "saturated"
a61af66fc99e Initial load
duke
parents:
diff changeset
57 // state. Also, certain recorded per-BCI events are given one-bit counters
a61af66fc99e Initial load
duke
parents:
diff changeset
58 // which overflow to a saturated state which applied to all counters at
a61af66fc99e Initial load
duke
parents:
diff changeset
59 // that BCI. In other words, there is a small lattice which approximates
a61af66fc99e Initial load
duke
parents:
diff changeset
60 // the ideal of an infinite-precision counter for each event at each BCI,
a61af66fc99e Initial load
duke
parents:
diff changeset
61 // and the lattice quickly "bottoms out" in a state where all counters
a61af66fc99e Initial load
duke
parents:
diff changeset
62 // are taken to be indefinitely large.
a61af66fc99e Initial load
duke
parents:
diff changeset
63 //
a61af66fc99e Initial load
duke
parents:
diff changeset
64 // The reader will find many data races in profile gathering code, starting
a61af66fc99e Initial load
duke
parents:
diff changeset
65 // with invocation counter incrementation. None of these races harm correct
a61af66fc99e Initial load
duke
parents:
diff changeset
66 // execution of the compiled code.
a61af66fc99e Initial load
duke
parents:
diff changeset
67
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
68 // forward decl
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
69 class ProfileData;
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
70
0
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // DataLayout
a61af66fc99e Initial load
duke
parents:
diff changeset
72 //
a61af66fc99e Initial load
duke
parents:
diff changeset
73 // Overlay for generic profiling data.
a61af66fc99e Initial load
duke
parents:
diff changeset
74 class DataLayout VALUE_OBJ_CLASS_SPEC {
a61af66fc99e Initial load
duke
parents:
diff changeset
75 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
76 // Every data layout begins with a header. This header
a61af66fc99e Initial load
duke
parents:
diff changeset
77 // contains a tag, which is used to indicate the size/layout
a61af66fc99e Initial load
duke
parents:
diff changeset
78 // of the data, 4 bits of flags, which can be used in any way,
a61af66fc99e Initial load
duke
parents:
diff changeset
79 // 4 bits of trap history (none/one reason/many reasons),
a61af66fc99e Initial load
duke
parents:
diff changeset
80 // and a bci, which is used to tie this piece of data to a
a61af66fc99e Initial load
duke
parents:
diff changeset
81 // specific bci in the bytecodes.
a61af66fc99e Initial load
duke
parents:
diff changeset
82 union {
a61af66fc99e Initial load
duke
parents:
diff changeset
83 intptr_t _bits;
a61af66fc99e Initial load
duke
parents:
diff changeset
84 struct {
a61af66fc99e Initial load
duke
parents:
diff changeset
85 u1 _tag;
a61af66fc99e Initial load
duke
parents:
diff changeset
86 u1 _flags;
a61af66fc99e Initial load
duke
parents:
diff changeset
87 u2 _bci;
a61af66fc99e Initial load
duke
parents:
diff changeset
88 } _struct;
a61af66fc99e Initial load
duke
parents:
diff changeset
89 } _header;
a61af66fc99e Initial load
duke
parents:
diff changeset
90
a61af66fc99e Initial load
duke
parents:
diff changeset
91 // The data layout has an arbitrary number of cells, each sized
a61af66fc99e Initial load
duke
parents:
diff changeset
92 // to accomodate a pointer or an integer.
a61af66fc99e Initial load
duke
parents:
diff changeset
93 intptr_t _cells[1];
a61af66fc99e Initial load
duke
parents:
diff changeset
94
a61af66fc99e Initial load
duke
parents:
diff changeset
95 // Some types of data layouts need a length field.
a61af66fc99e Initial load
duke
parents:
diff changeset
96 static bool needs_array_len(u1 tag);
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 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
100 counter_increment = 1
a61af66fc99e Initial load
duke
parents:
diff changeset
101 };
a61af66fc99e Initial load
duke
parents:
diff changeset
102
a61af66fc99e Initial load
duke
parents:
diff changeset
103 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
104 cell_size = sizeof(intptr_t)
a61af66fc99e Initial load
duke
parents:
diff changeset
105 };
a61af66fc99e Initial load
duke
parents:
diff changeset
106
a61af66fc99e Initial load
duke
parents:
diff changeset
107 // Tag values
a61af66fc99e Initial load
duke
parents:
diff changeset
108 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
109 no_tag,
a61af66fc99e Initial load
duke
parents:
diff changeset
110 bit_data_tag,
a61af66fc99e Initial load
duke
parents:
diff changeset
111 counter_data_tag,
a61af66fc99e Initial load
duke
parents:
diff changeset
112 jump_data_tag,
a61af66fc99e Initial load
duke
parents:
diff changeset
113 receiver_type_data_tag,
a61af66fc99e Initial load
duke
parents:
diff changeset
114 virtual_call_data_tag,
a61af66fc99e Initial load
duke
parents:
diff changeset
115 ret_data_tag,
a61af66fc99e Initial load
duke
parents:
diff changeset
116 branch_data_tag,
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
117 multi_branch_data_tag,
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
118 arg_info_data_tag
0
a61af66fc99e Initial load
duke
parents:
diff changeset
119 };
a61af66fc99e Initial load
duke
parents:
diff changeset
120
a61af66fc99e Initial load
duke
parents:
diff changeset
121 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
122 // The _struct._flags word is formatted as [trap_state:4 | flags:4].
a61af66fc99e Initial load
duke
parents:
diff changeset
123 // The trap state breaks down further as [recompile:1 | reason:3].
a61af66fc99e Initial load
duke
parents:
diff changeset
124 // This further breakdown is defined in deoptimization.cpp.
a61af66fc99e Initial load
duke
parents:
diff changeset
125 // See Deoptimization::trap_state_reason for an assert that
a61af66fc99e Initial load
duke
parents:
diff changeset
126 // trap_bits is big enough to hold reasons < Reason_RECORDED_LIMIT.
a61af66fc99e Initial load
duke
parents:
diff changeset
127 //
a61af66fc99e Initial load
duke
parents:
diff changeset
128 // The trap_state is collected only if ProfileTraps is true.
a61af66fc99e Initial load
duke
parents:
diff changeset
129 trap_bits = 1+3, // 3: enough to distinguish [0..Reason_RECORDED_LIMIT].
a61af66fc99e Initial load
duke
parents:
diff changeset
130 trap_shift = BitsPerByte - trap_bits,
a61af66fc99e Initial load
duke
parents:
diff changeset
131 trap_mask = right_n_bits(trap_bits),
a61af66fc99e Initial load
duke
parents:
diff changeset
132 trap_mask_in_place = (trap_mask << trap_shift),
a61af66fc99e Initial load
duke
parents:
diff changeset
133 flag_limit = trap_shift,
a61af66fc99e Initial load
duke
parents:
diff changeset
134 flag_mask = right_n_bits(flag_limit),
a61af66fc99e Initial load
duke
parents:
diff changeset
135 first_flag = 0
a61af66fc99e Initial load
duke
parents:
diff changeset
136 };
a61af66fc99e Initial load
duke
parents:
diff changeset
137
a61af66fc99e Initial load
duke
parents:
diff changeset
138 // Size computation
a61af66fc99e Initial load
duke
parents:
diff changeset
139 static int header_size_in_bytes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
140 return cell_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
141 }
a61af66fc99e Initial load
duke
parents:
diff changeset
142 static int header_size_in_cells() {
a61af66fc99e Initial load
duke
parents:
diff changeset
143 return 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
144 }
a61af66fc99e Initial load
duke
parents:
diff changeset
145
a61af66fc99e Initial load
duke
parents:
diff changeset
146 static int compute_size_in_bytes(int cell_count) {
a61af66fc99e Initial load
duke
parents:
diff changeset
147 return header_size_in_bytes() + cell_count * cell_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
148 }
a61af66fc99e Initial load
duke
parents:
diff changeset
149
a61af66fc99e Initial load
duke
parents:
diff changeset
150 // Initialization
a61af66fc99e Initial load
duke
parents:
diff changeset
151 void initialize(u1 tag, u2 bci, int cell_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
152
a61af66fc99e Initial load
duke
parents:
diff changeset
153 // Accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
154 u1 tag() {
a61af66fc99e Initial load
duke
parents:
diff changeset
155 return _header._struct._tag;
a61af66fc99e Initial load
duke
parents:
diff changeset
156 }
a61af66fc99e Initial load
duke
parents:
diff changeset
157
a61af66fc99e Initial load
duke
parents:
diff changeset
158 // Return a few bits of trap state. Range is [0..trap_mask].
a61af66fc99e Initial load
duke
parents:
diff changeset
159 // The state tells if traps with zero, one, or many reasons have occurred.
a61af66fc99e Initial load
duke
parents:
diff changeset
160 // It also tells whether zero or many recompilations have occurred.
a61af66fc99e Initial load
duke
parents:
diff changeset
161 // The associated trap histogram in the MDO itself tells whether
a61af66fc99e Initial load
duke
parents:
diff changeset
162 // traps are common or not. If a BCI shows that a trap X has
a61af66fc99e Initial load
duke
parents:
diff changeset
163 // occurred, and the MDO shows N occurrences of X, we make the
a61af66fc99e Initial load
duke
parents:
diff changeset
164 // simplifying assumption that all N occurrences can be blamed
a61af66fc99e Initial load
duke
parents:
diff changeset
165 // on that BCI.
a61af66fc99e Initial load
duke
parents:
diff changeset
166 int trap_state() {
a61af66fc99e Initial load
duke
parents:
diff changeset
167 return ((_header._struct._flags >> trap_shift) & trap_mask);
a61af66fc99e Initial load
duke
parents:
diff changeset
168 }
a61af66fc99e Initial load
duke
parents:
diff changeset
169
a61af66fc99e Initial load
duke
parents:
diff changeset
170 void set_trap_state(int new_state) {
a61af66fc99e Initial load
duke
parents:
diff changeset
171 assert(ProfileTraps, "used only under +ProfileTraps");
a61af66fc99e Initial load
duke
parents:
diff changeset
172 uint old_flags = (_header._struct._flags & flag_mask);
a61af66fc99e Initial load
duke
parents:
diff changeset
173 _header._struct._flags = (new_state << trap_shift) | old_flags;
a61af66fc99e Initial load
duke
parents:
diff changeset
174 }
a61af66fc99e Initial load
duke
parents:
diff changeset
175
a61af66fc99e Initial load
duke
parents:
diff changeset
176 u1 flags() {
a61af66fc99e Initial load
duke
parents:
diff changeset
177 return _header._struct._flags;
a61af66fc99e Initial load
duke
parents:
diff changeset
178 }
a61af66fc99e Initial load
duke
parents:
diff changeset
179
a61af66fc99e Initial load
duke
parents:
diff changeset
180 u2 bci() {
a61af66fc99e Initial load
duke
parents:
diff changeset
181 return _header._struct._bci;
a61af66fc99e Initial load
duke
parents:
diff changeset
182 }
a61af66fc99e Initial load
duke
parents:
diff changeset
183
a61af66fc99e Initial load
duke
parents:
diff changeset
184 void set_header(intptr_t value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
185 _header._bits = value;
a61af66fc99e Initial load
duke
parents:
diff changeset
186 }
a61af66fc99e Initial load
duke
parents:
diff changeset
187 void release_set_header(intptr_t value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
188 OrderAccess::release_store_ptr(&_header._bits, value);
a61af66fc99e Initial load
duke
parents:
diff changeset
189 }
a61af66fc99e Initial load
duke
parents:
diff changeset
190 intptr_t header() {
a61af66fc99e Initial load
duke
parents:
diff changeset
191 return _header._bits;
a61af66fc99e Initial load
duke
parents:
diff changeset
192 }
a61af66fc99e Initial load
duke
parents:
diff changeset
193 void set_cell_at(int index, intptr_t value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
194 _cells[index] = value;
a61af66fc99e Initial load
duke
parents:
diff changeset
195 }
a61af66fc99e Initial load
duke
parents:
diff changeset
196 void release_set_cell_at(int index, intptr_t value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
197 OrderAccess::release_store_ptr(&_cells[index], value);
a61af66fc99e Initial load
duke
parents:
diff changeset
198 }
a61af66fc99e Initial load
duke
parents:
diff changeset
199 intptr_t cell_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
200 return _cells[index];
a61af66fc99e Initial load
duke
parents:
diff changeset
201 }
a61af66fc99e Initial load
duke
parents:
diff changeset
202
a61af66fc99e Initial load
duke
parents:
diff changeset
203 void set_flag_at(int flag_number) {
a61af66fc99e Initial load
duke
parents:
diff changeset
204 assert(flag_number < flag_limit, "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
205 _header._struct._flags |= (0x1 << flag_number);
a61af66fc99e Initial load
duke
parents:
diff changeset
206 }
a61af66fc99e Initial load
duke
parents:
diff changeset
207 bool flag_at(int flag_number) {
a61af66fc99e Initial load
duke
parents:
diff changeset
208 assert(flag_number < flag_limit, "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
209 return (_header._struct._flags & (0x1 << flag_number)) != 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
210 }
a61af66fc99e Initial load
duke
parents:
diff changeset
211
a61af66fc99e Initial load
duke
parents:
diff changeset
212 // Low-level support for code generation.
a61af66fc99e Initial load
duke
parents:
diff changeset
213 static ByteSize header_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
214 return byte_offset_of(DataLayout, _header);
a61af66fc99e Initial load
duke
parents:
diff changeset
215 }
a61af66fc99e Initial load
duke
parents:
diff changeset
216 static ByteSize tag_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
217 return byte_offset_of(DataLayout, _header._struct._tag);
a61af66fc99e Initial load
duke
parents:
diff changeset
218 }
a61af66fc99e Initial load
duke
parents:
diff changeset
219 static ByteSize flags_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
220 return byte_offset_of(DataLayout, _header._struct._flags);
a61af66fc99e Initial load
duke
parents:
diff changeset
221 }
a61af66fc99e Initial load
duke
parents:
diff changeset
222 static ByteSize bci_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
223 return byte_offset_of(DataLayout, _header._struct._bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
224 }
a61af66fc99e Initial load
duke
parents:
diff changeset
225 static ByteSize cell_offset(int index) {
2333
f767174aac14 7021653: Parfait issue in hotspot/src/share/vm/oops/methodDataOops.hpp
coleenp
parents: 2264
diff changeset
226 return byte_offset_of(DataLayout, _cells) + in_ByteSize(index * cell_size);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
227 }
a61af66fc99e Initial load
duke
parents:
diff changeset
228 // Return a value which, when or-ed as a byte into _flags, sets the flag.
a61af66fc99e Initial load
duke
parents:
diff changeset
229 static int flag_number_to_byte_constant(int flag_number) {
a61af66fc99e Initial load
duke
parents:
diff changeset
230 assert(0 <= flag_number && flag_number < flag_limit, "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
231 DataLayout temp; temp.set_header(0);
a61af66fc99e Initial load
duke
parents:
diff changeset
232 temp.set_flag_at(flag_number);
a61af66fc99e Initial load
duke
parents:
diff changeset
233 return temp._header._struct._flags;
a61af66fc99e Initial load
duke
parents:
diff changeset
234 }
a61af66fc99e Initial load
duke
parents:
diff changeset
235 // Return a value which, when or-ed as a word into _header, sets the flag.
a61af66fc99e Initial load
duke
parents:
diff changeset
236 static intptr_t flag_mask_to_header_mask(int byte_constant) {
a61af66fc99e Initial load
duke
parents:
diff changeset
237 DataLayout temp; temp.set_header(0);
a61af66fc99e Initial load
duke
parents:
diff changeset
238 temp._header._struct._flags = byte_constant;
a61af66fc99e Initial load
duke
parents:
diff changeset
239 return temp._header._bits;
a61af66fc99e Initial load
duke
parents:
diff changeset
240 }
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
241
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
242 ProfileData* data_in();
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
243
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
244 // GC support
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
245 void clean_weak_klass_links(BoolObjectClosure* cl);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
246 };
a61af66fc99e Initial load
duke
parents:
diff changeset
247
a61af66fc99e Initial load
duke
parents:
diff changeset
248
a61af66fc99e Initial load
duke
parents:
diff changeset
249 // ProfileData class hierarchy
a61af66fc99e Initial load
duke
parents:
diff changeset
250 class ProfileData;
a61af66fc99e Initial load
duke
parents:
diff changeset
251 class BitData;
a61af66fc99e Initial load
duke
parents:
diff changeset
252 class CounterData;
a61af66fc99e Initial load
duke
parents:
diff changeset
253 class ReceiverTypeData;
a61af66fc99e Initial load
duke
parents:
diff changeset
254 class VirtualCallData;
a61af66fc99e Initial load
duke
parents:
diff changeset
255 class RetData;
a61af66fc99e Initial load
duke
parents:
diff changeset
256 class JumpData;
a61af66fc99e Initial load
duke
parents:
diff changeset
257 class BranchData;
a61af66fc99e Initial load
duke
parents:
diff changeset
258 class ArrayData;
a61af66fc99e Initial load
duke
parents:
diff changeset
259 class MultiBranchData;
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
260 class ArgInfoData;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
261
a61af66fc99e Initial load
duke
parents:
diff changeset
262
a61af66fc99e Initial load
duke
parents:
diff changeset
263 // ProfileData
a61af66fc99e Initial load
duke
parents:
diff changeset
264 //
a61af66fc99e Initial load
duke
parents:
diff changeset
265 // A ProfileData object is created to refer to a section of profiling
a61af66fc99e Initial load
duke
parents:
diff changeset
266 // data in a structured way.
a61af66fc99e Initial load
duke
parents:
diff changeset
267 class ProfileData : public ResourceObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
268 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
269 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
270 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
271 tab_width_one = 16,
a61af66fc99e Initial load
duke
parents:
diff changeset
272 tab_width_two = 36
a61af66fc99e Initial load
duke
parents:
diff changeset
273 };
a61af66fc99e Initial load
duke
parents:
diff changeset
274 #endif // !PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
275
a61af66fc99e Initial load
duke
parents:
diff changeset
276 // This is a pointer to a section of profiling data.
a61af66fc99e Initial load
duke
parents:
diff changeset
277 DataLayout* _data;
a61af66fc99e Initial load
duke
parents:
diff changeset
278
a61af66fc99e Initial load
duke
parents:
diff changeset
279 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
280 DataLayout* data() { return _data; }
a61af66fc99e Initial load
duke
parents:
diff changeset
281
a61af66fc99e Initial load
duke
parents:
diff changeset
282 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
283 cell_size = DataLayout::cell_size
a61af66fc99e Initial load
duke
parents:
diff changeset
284 };
a61af66fc99e Initial load
duke
parents:
diff changeset
285
a61af66fc99e Initial load
duke
parents:
diff changeset
286 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
287 // How many cells are in this?
a61af66fc99e Initial load
duke
parents:
diff changeset
288 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
289 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
290 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
291 }
a61af66fc99e Initial load
duke
parents:
diff changeset
292
a61af66fc99e Initial load
duke
parents:
diff changeset
293 // Return the size of this data.
a61af66fc99e Initial load
duke
parents:
diff changeset
294 int size_in_bytes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
295 return DataLayout::compute_size_in_bytes(cell_count());
a61af66fc99e Initial load
duke
parents:
diff changeset
296 }
a61af66fc99e Initial load
duke
parents:
diff changeset
297
a61af66fc99e Initial load
duke
parents:
diff changeset
298 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
299 // Low-level accessors for underlying data
a61af66fc99e Initial load
duke
parents:
diff changeset
300 void set_intptr_at(int index, intptr_t value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
301 assert(0 <= index && index < cell_count(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
302 data()->set_cell_at(index, value);
a61af66fc99e Initial load
duke
parents:
diff changeset
303 }
a61af66fc99e Initial load
duke
parents:
diff changeset
304 void release_set_intptr_at(int index, intptr_t value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
305 assert(0 <= index && index < cell_count(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
306 data()->release_set_cell_at(index, value);
a61af66fc99e Initial load
duke
parents:
diff changeset
307 }
a61af66fc99e Initial load
duke
parents:
diff changeset
308 intptr_t intptr_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
309 assert(0 <= index && index < cell_count(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
310 return data()->cell_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
311 }
a61af66fc99e Initial load
duke
parents:
diff changeset
312 void set_uint_at(int index, uint value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
313 set_intptr_at(index, (intptr_t) value);
a61af66fc99e Initial load
duke
parents:
diff changeset
314 }
a61af66fc99e Initial load
duke
parents:
diff changeset
315 void release_set_uint_at(int index, uint value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
316 release_set_intptr_at(index, (intptr_t) value);
a61af66fc99e Initial load
duke
parents:
diff changeset
317 }
a61af66fc99e Initial load
duke
parents:
diff changeset
318 uint uint_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
319 return (uint)intptr_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
320 }
a61af66fc99e Initial load
duke
parents:
diff changeset
321 void set_int_at(int index, int value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
322 set_intptr_at(index, (intptr_t) value);
a61af66fc99e Initial load
duke
parents:
diff changeset
323 }
a61af66fc99e Initial load
duke
parents:
diff changeset
324 void release_set_int_at(int index, int value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
325 release_set_intptr_at(index, (intptr_t) value);
a61af66fc99e Initial load
duke
parents:
diff changeset
326 }
a61af66fc99e Initial load
duke
parents:
diff changeset
327 int int_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
328 return (int)intptr_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
329 }
a61af66fc99e Initial load
duke
parents:
diff changeset
330 int int_at_unchecked(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
331 return (int)data()->cell_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
332 }
a61af66fc99e Initial load
duke
parents:
diff changeset
333 void set_oop_at(int index, oop value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
334 set_intptr_at(index, (intptr_t) value);
a61af66fc99e Initial load
duke
parents:
diff changeset
335 }
a61af66fc99e Initial load
duke
parents:
diff changeset
336 oop oop_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
337 return (oop)intptr_at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
338 }
a61af66fc99e Initial load
duke
parents:
diff changeset
339
a61af66fc99e Initial load
duke
parents:
diff changeset
340 void set_flag_at(int flag_number) {
a61af66fc99e Initial load
duke
parents:
diff changeset
341 data()->set_flag_at(flag_number);
a61af66fc99e Initial load
duke
parents:
diff changeset
342 }
a61af66fc99e Initial load
duke
parents:
diff changeset
343 bool flag_at(int flag_number) {
a61af66fc99e Initial load
duke
parents:
diff changeset
344 return data()->flag_at(flag_number);
a61af66fc99e Initial load
duke
parents:
diff changeset
345 }
a61af66fc99e Initial load
duke
parents:
diff changeset
346
a61af66fc99e Initial load
duke
parents:
diff changeset
347 // two convenient imports for use by subclasses:
a61af66fc99e Initial load
duke
parents:
diff changeset
348 static ByteSize cell_offset(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
349 return DataLayout::cell_offset(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
350 }
a61af66fc99e Initial load
duke
parents:
diff changeset
351 static int flag_number_to_byte_constant(int flag_number) {
a61af66fc99e Initial load
duke
parents:
diff changeset
352 return DataLayout::flag_number_to_byte_constant(flag_number);
a61af66fc99e Initial load
duke
parents:
diff changeset
353 }
a61af66fc99e Initial load
duke
parents:
diff changeset
354
a61af66fc99e Initial load
duke
parents:
diff changeset
355 ProfileData(DataLayout* data) {
a61af66fc99e Initial load
duke
parents:
diff changeset
356 _data = data;
a61af66fc99e Initial load
duke
parents:
diff changeset
357 }
a61af66fc99e Initial load
duke
parents:
diff changeset
358
a61af66fc99e Initial load
duke
parents:
diff changeset
359 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
360 // Constructor for invalid ProfileData.
a61af66fc99e Initial load
duke
parents:
diff changeset
361 ProfileData();
a61af66fc99e Initial load
duke
parents:
diff changeset
362
a61af66fc99e Initial load
duke
parents:
diff changeset
363 u2 bci() {
a61af66fc99e Initial load
duke
parents:
diff changeset
364 return data()->bci();
a61af66fc99e Initial load
duke
parents:
diff changeset
365 }
a61af66fc99e Initial load
duke
parents:
diff changeset
366
a61af66fc99e Initial load
duke
parents:
diff changeset
367 address dp() {
a61af66fc99e Initial load
duke
parents:
diff changeset
368 return (address)_data;
a61af66fc99e Initial load
duke
parents:
diff changeset
369 }
a61af66fc99e Initial load
duke
parents:
diff changeset
370
a61af66fc99e Initial load
duke
parents:
diff changeset
371 int trap_state() {
a61af66fc99e Initial load
duke
parents:
diff changeset
372 return data()->trap_state();
a61af66fc99e Initial load
duke
parents:
diff changeset
373 }
a61af66fc99e Initial load
duke
parents:
diff changeset
374 void set_trap_state(int new_state) {
a61af66fc99e Initial load
duke
parents:
diff changeset
375 data()->set_trap_state(new_state);
a61af66fc99e Initial load
duke
parents:
diff changeset
376 }
a61af66fc99e Initial load
duke
parents:
diff changeset
377
a61af66fc99e Initial load
duke
parents:
diff changeset
378 // Type checking
a61af66fc99e Initial load
duke
parents:
diff changeset
379 virtual bool is_BitData() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
380 virtual bool is_CounterData() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
381 virtual bool is_JumpData() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
382 virtual bool is_ReceiverTypeData(){ return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
383 virtual bool is_VirtualCallData() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
384 virtual bool is_RetData() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
385 virtual bool is_BranchData() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
386 virtual bool is_ArrayData() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
387 virtual bool is_MultiBranchData() { return false; }
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
388 virtual bool is_ArgInfoData() { return false; }
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
389
0
a61af66fc99e Initial load
duke
parents:
diff changeset
390
a61af66fc99e Initial load
duke
parents:
diff changeset
391 BitData* as_BitData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
392 assert(is_BitData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
393 return is_BitData() ? (BitData*) this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
394 }
a61af66fc99e Initial load
duke
parents:
diff changeset
395 CounterData* as_CounterData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
396 assert(is_CounterData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
397 return is_CounterData() ? (CounterData*) this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
398 }
a61af66fc99e Initial load
duke
parents:
diff changeset
399 JumpData* as_JumpData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
400 assert(is_JumpData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
401 return is_JumpData() ? (JumpData*) this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
402 }
a61af66fc99e Initial load
duke
parents:
diff changeset
403 ReceiverTypeData* as_ReceiverTypeData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
404 assert(is_ReceiverTypeData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
405 return is_ReceiverTypeData() ? (ReceiverTypeData*)this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
406 }
a61af66fc99e Initial load
duke
parents:
diff changeset
407 VirtualCallData* as_VirtualCallData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
408 assert(is_VirtualCallData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
409 return is_VirtualCallData() ? (VirtualCallData*)this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
410 }
a61af66fc99e Initial load
duke
parents:
diff changeset
411 RetData* as_RetData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
412 assert(is_RetData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
413 return is_RetData() ? (RetData*) this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
414 }
a61af66fc99e Initial load
duke
parents:
diff changeset
415 BranchData* as_BranchData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
416 assert(is_BranchData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
417 return is_BranchData() ? (BranchData*) this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
418 }
a61af66fc99e Initial load
duke
parents:
diff changeset
419 ArrayData* as_ArrayData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
420 assert(is_ArrayData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
421 return is_ArrayData() ? (ArrayData*) this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
422 }
a61af66fc99e Initial load
duke
parents:
diff changeset
423 MultiBranchData* as_MultiBranchData() {
a61af66fc99e Initial load
duke
parents:
diff changeset
424 assert(is_MultiBranchData(), "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
425 return is_MultiBranchData() ? (MultiBranchData*)this : NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
426 }
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
427 ArgInfoData* as_ArgInfoData() {
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
428 assert(is_ArgInfoData(), "wrong type");
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
429 return is_ArgInfoData() ? (ArgInfoData*)this : NULL;
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
430 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
431
a61af66fc99e Initial load
duke
parents:
diff changeset
432
a61af66fc99e Initial load
duke
parents:
diff changeset
433 // Subclass specific initialization
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
434 virtual void post_initialize(BytecodeStream* stream, MethodData* mdo) {}
0
a61af66fc99e Initial load
duke
parents:
diff changeset
435
a61af66fc99e Initial load
duke
parents:
diff changeset
436 // GC support
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
437 virtual void clean_weak_klass_links(BoolObjectClosure* is_alive_closure) {}
0
a61af66fc99e Initial load
duke
parents:
diff changeset
438
a61af66fc99e Initial load
duke
parents:
diff changeset
439 // CI translation: ProfileData can represent both MethodDataOop data
a61af66fc99e Initial load
duke
parents:
diff changeset
440 // as well as CIMethodData data. This function is provided for translating
a61af66fc99e Initial load
duke
parents:
diff changeset
441 // an oop in a ProfileData to the ci equivalent. Generally speaking,
a61af66fc99e Initial load
duke
parents:
diff changeset
442 // most ProfileData don't require any translation, so we provide the null
a61af66fc99e Initial load
duke
parents:
diff changeset
443 // translation here, and the required translators are in the ci subclasses.
a61af66fc99e Initial load
duke
parents:
diff changeset
444 virtual void translate_from(ProfileData* data) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
445
a61af66fc99e Initial load
duke
parents:
diff changeset
446 virtual void print_data_on(outputStream* st) {
a61af66fc99e Initial load
duke
parents:
diff changeset
447 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
448 }
a61af66fc99e Initial load
duke
parents:
diff changeset
449
a61af66fc99e Initial load
duke
parents:
diff changeset
450 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
451 void print_shared(outputStream* st, const char* name);
a61af66fc99e Initial load
duke
parents:
diff changeset
452 void tab(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
453 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
454 };
a61af66fc99e Initial load
duke
parents:
diff changeset
455
a61af66fc99e Initial load
duke
parents:
diff changeset
456 // BitData
a61af66fc99e Initial load
duke
parents:
diff changeset
457 //
a61af66fc99e Initial load
duke
parents:
diff changeset
458 // A BitData holds a flag or two in its header.
a61af66fc99e Initial load
duke
parents:
diff changeset
459 class BitData : public ProfileData {
a61af66fc99e Initial load
duke
parents:
diff changeset
460 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
461 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
462 // null_seen:
a61af66fc99e Initial load
duke
parents:
diff changeset
463 // saw a null operand (cast/aastore/instanceof)
8616
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
464 null_seen_flag = DataLayout::first_flag + 0
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
465 #ifdef GRAAL
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
466 // bytecode threw any exception
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
467 , exception_seen_flag = null_seen_flag + 1
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
468 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
469 };
a61af66fc99e Initial load
duke
parents:
diff changeset
470 enum { bit_cell_count = 0 }; // no additional data fields needed.
a61af66fc99e Initial load
duke
parents:
diff changeset
471 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
472 BitData(DataLayout* layout) : ProfileData(layout) {
a61af66fc99e Initial load
duke
parents:
diff changeset
473 }
a61af66fc99e Initial load
duke
parents:
diff changeset
474
a61af66fc99e Initial load
duke
parents:
diff changeset
475 virtual bool is_BitData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
476
a61af66fc99e Initial load
duke
parents:
diff changeset
477 static int static_cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
478 return bit_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
479 }
a61af66fc99e Initial load
duke
parents:
diff changeset
480
a61af66fc99e Initial load
duke
parents:
diff changeset
481 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
482 return static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
483 }
a61af66fc99e Initial load
duke
parents:
diff changeset
484
a61af66fc99e Initial load
duke
parents:
diff changeset
485 // Accessor
a61af66fc99e Initial load
duke
parents:
diff changeset
486
a61af66fc99e Initial load
duke
parents:
diff changeset
487 // The null_seen flag bit is specially known to the interpreter.
a61af66fc99e Initial load
duke
parents:
diff changeset
488 // Consulting it allows the compiler to avoid setting up null_check traps.
a61af66fc99e Initial load
duke
parents:
diff changeset
489 bool null_seen() { return flag_at(null_seen_flag); }
a61af66fc99e Initial load
duke
parents:
diff changeset
490 void set_null_seen() { set_flag_at(null_seen_flag); }
8616
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
491 #ifdef GRAAL
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
492 // true if an exception was thrown at the specific BCI
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
493 bool exception_seen() { return flag_at(exception_seen_flag); }
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
494 void set_exception_seen() { set_flag_at(exception_seen_flag); }
d343737786fe changed profiling of exceptions so that the ExceptionSeen flag also works without GRAALVM
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8611
diff changeset
495 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
496
a61af66fc99e Initial load
duke
parents:
diff changeset
497 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
498 static int null_seen_byte_constant() {
a61af66fc99e Initial load
duke
parents:
diff changeset
499 return flag_number_to_byte_constant(null_seen_flag);
a61af66fc99e Initial load
duke
parents:
diff changeset
500 }
a61af66fc99e Initial load
duke
parents:
diff changeset
501
a61af66fc99e Initial load
duke
parents:
diff changeset
502 static ByteSize bit_data_size() {
a61af66fc99e Initial load
duke
parents:
diff changeset
503 return cell_offset(bit_cell_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
504 }
a61af66fc99e Initial load
duke
parents:
diff changeset
505
a61af66fc99e Initial load
duke
parents:
diff changeset
506 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
507 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
508 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
509 };
a61af66fc99e Initial load
duke
parents:
diff changeset
510
a61af66fc99e Initial load
duke
parents:
diff changeset
511 // CounterData
a61af66fc99e Initial load
duke
parents:
diff changeset
512 //
a61af66fc99e Initial load
duke
parents:
diff changeset
513 // A CounterData corresponds to a simple counter.
a61af66fc99e Initial load
duke
parents:
diff changeset
514 class CounterData : public BitData {
a61af66fc99e Initial load
duke
parents:
diff changeset
515 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
516 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
517 count_off,
a61af66fc99e Initial load
duke
parents:
diff changeset
518 counter_cell_count
a61af66fc99e Initial load
duke
parents:
diff changeset
519 };
a61af66fc99e Initial load
duke
parents:
diff changeset
520 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
521 CounterData(DataLayout* layout) : BitData(layout) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
522
a61af66fc99e Initial load
duke
parents:
diff changeset
523 virtual bool is_CounterData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
524
a61af66fc99e Initial load
duke
parents:
diff changeset
525 static int static_cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
526 return counter_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
527 }
a61af66fc99e Initial load
duke
parents:
diff changeset
528
a61af66fc99e Initial load
duke
parents:
diff changeset
529 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
530 return static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
531 }
a61af66fc99e Initial load
duke
parents:
diff changeset
532
a61af66fc99e Initial load
duke
parents:
diff changeset
533 // Direct accessor
a61af66fc99e Initial load
duke
parents:
diff changeset
534 uint count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
535 return uint_at(count_off);
a61af66fc99e Initial load
duke
parents:
diff changeset
536 }
a61af66fc99e Initial load
duke
parents:
diff changeset
537
a61af66fc99e Initial load
duke
parents:
diff changeset
538 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
539 static ByteSize count_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
540 return cell_offset(count_off);
a61af66fc99e Initial load
duke
parents:
diff changeset
541 }
a61af66fc99e Initial load
duke
parents:
diff changeset
542 static ByteSize counter_data_size() {
a61af66fc99e Initial load
duke
parents:
diff changeset
543 return cell_offset(counter_cell_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
544 }
a61af66fc99e Initial load
duke
parents:
diff changeset
545
1251
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
546 void set_count(uint count) {
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
547 set_uint_at(count_off, count);
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
548 }
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
549
0
a61af66fc99e Initial load
duke
parents:
diff changeset
550 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
551 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
552 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
553 };
a61af66fc99e Initial load
duke
parents:
diff changeset
554
a61af66fc99e Initial load
duke
parents:
diff changeset
555 // JumpData
a61af66fc99e Initial load
duke
parents:
diff changeset
556 //
a61af66fc99e Initial load
duke
parents:
diff changeset
557 // A JumpData is used to access profiling information for a direct
a61af66fc99e Initial load
duke
parents:
diff changeset
558 // branch. It is a counter, used for counting the number of branches,
a61af66fc99e Initial load
duke
parents:
diff changeset
559 // plus a data displacement, used for realigning the data pointer to
a61af66fc99e Initial load
duke
parents:
diff changeset
560 // the corresponding target bci.
a61af66fc99e Initial load
duke
parents:
diff changeset
561 class JumpData : public ProfileData {
a61af66fc99e Initial load
duke
parents:
diff changeset
562 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
563 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
564 taken_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
565 displacement_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
566 jump_cell_count
a61af66fc99e Initial load
duke
parents:
diff changeset
567 };
a61af66fc99e Initial load
duke
parents:
diff changeset
568
a61af66fc99e Initial load
duke
parents:
diff changeset
569 void set_displacement(int displacement) {
a61af66fc99e Initial load
duke
parents:
diff changeset
570 set_int_at(displacement_off_set, displacement);
a61af66fc99e Initial load
duke
parents:
diff changeset
571 }
a61af66fc99e Initial load
duke
parents:
diff changeset
572
a61af66fc99e Initial load
duke
parents:
diff changeset
573 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
574 JumpData(DataLayout* layout) : ProfileData(layout) {
a61af66fc99e Initial load
duke
parents:
diff changeset
575 assert(layout->tag() == DataLayout::jump_data_tag ||
a61af66fc99e Initial load
duke
parents:
diff changeset
576 layout->tag() == DataLayout::branch_data_tag, "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
577 }
a61af66fc99e Initial load
duke
parents:
diff changeset
578
a61af66fc99e Initial load
duke
parents:
diff changeset
579 virtual bool is_JumpData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
580
a61af66fc99e Initial load
duke
parents:
diff changeset
581 static int static_cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
582 return jump_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
583 }
a61af66fc99e Initial load
duke
parents:
diff changeset
584
a61af66fc99e Initial load
duke
parents:
diff changeset
585 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
586 return static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
587 }
a61af66fc99e Initial load
duke
parents:
diff changeset
588
a61af66fc99e Initial load
duke
parents:
diff changeset
589 // Direct accessor
a61af66fc99e Initial load
duke
parents:
diff changeset
590 uint taken() {
a61af66fc99e Initial load
duke
parents:
diff changeset
591 return uint_at(taken_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
592 }
3905
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
593
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
594 void set_taken(uint cnt) {
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
595 set_uint_at(taken_off_set, cnt);
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
596 }
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
597
0
a61af66fc99e Initial load
duke
parents:
diff changeset
598 // Saturating counter
a61af66fc99e Initial load
duke
parents:
diff changeset
599 uint inc_taken() {
a61af66fc99e Initial load
duke
parents:
diff changeset
600 uint cnt = taken() + 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
601 // Did we wrap? Will compiler screw us??
a61af66fc99e Initial load
duke
parents:
diff changeset
602 if (cnt == 0) cnt--;
a61af66fc99e Initial load
duke
parents:
diff changeset
603 set_uint_at(taken_off_set, cnt);
a61af66fc99e Initial load
duke
parents:
diff changeset
604 return cnt;
a61af66fc99e Initial load
duke
parents:
diff changeset
605 }
a61af66fc99e Initial load
duke
parents:
diff changeset
606
a61af66fc99e Initial load
duke
parents:
diff changeset
607 int displacement() {
a61af66fc99e Initial load
duke
parents:
diff changeset
608 return int_at(displacement_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
609 }
a61af66fc99e Initial load
duke
parents:
diff changeset
610
a61af66fc99e Initial load
duke
parents:
diff changeset
611 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
612 static ByteSize taken_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
613 return cell_offset(taken_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
614 }
a61af66fc99e Initial load
duke
parents:
diff changeset
615
a61af66fc99e Initial load
duke
parents:
diff changeset
616 static ByteSize displacement_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
617 return cell_offset(displacement_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
618 }
a61af66fc99e Initial load
duke
parents:
diff changeset
619
a61af66fc99e Initial load
duke
parents:
diff changeset
620 // Specific initialization.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
621 void post_initialize(BytecodeStream* stream, MethodData* mdo);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
622
a61af66fc99e Initial load
duke
parents:
diff changeset
623 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
624 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
625 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
626 };
a61af66fc99e Initial load
duke
parents:
diff changeset
627
a61af66fc99e Initial load
duke
parents:
diff changeset
628 // ReceiverTypeData
a61af66fc99e Initial load
duke
parents:
diff changeset
629 //
a61af66fc99e Initial load
duke
parents:
diff changeset
630 // A ReceiverTypeData is used to access profiling information about a
a61af66fc99e Initial load
duke
parents:
diff changeset
631 // dynamic type check. It consists of a counter which counts the total times
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
632 // that the check is reached, and a series of (Klass*, count) pairs
0
a61af66fc99e Initial load
duke
parents:
diff changeset
633 // which are used to store a type profile for the receiver of the check.
a61af66fc99e Initial load
duke
parents:
diff changeset
634 class ReceiverTypeData : public CounterData {
a61af66fc99e Initial load
duke
parents:
diff changeset
635 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
636 enum {
7154
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
637 #ifdef GRAAL
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
638 // Graal is interested in knowing the percentage of type checks
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
639 // involving a type not explicitly in the profile
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
640 nonprofiled_receiver_count_off_set = counter_cell_count,
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
641 receiver0_offset,
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
642 #else
0
a61af66fc99e Initial load
duke
parents:
diff changeset
643 receiver0_offset = counter_cell_count,
7154
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
644 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
645 count0_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
646 receiver_type_row_cell_count = (count0_offset + 1) - receiver0_offset
a61af66fc99e Initial load
duke
parents:
diff changeset
647 };
a61af66fc99e Initial load
duke
parents:
diff changeset
648
a61af66fc99e Initial load
duke
parents:
diff changeset
649 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
650 ReceiverTypeData(DataLayout* layout) : CounterData(layout) {
a61af66fc99e Initial load
duke
parents:
diff changeset
651 assert(layout->tag() == DataLayout::receiver_type_data_tag ||
a61af66fc99e Initial load
duke
parents:
diff changeset
652 layout->tag() == DataLayout::virtual_call_data_tag, "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
653 }
a61af66fc99e Initial load
duke
parents:
diff changeset
654
a61af66fc99e Initial load
duke
parents:
diff changeset
655 virtual bool is_ReceiverTypeData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
656
a61af66fc99e Initial load
duke
parents:
diff changeset
657 static int static_cell_count() {
7154
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
658 return counter_cell_count + (uint) TypeProfileWidth * receiver_type_row_cell_count GRAAL_ONLY(+ 1);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
659 }
a61af66fc99e Initial load
duke
parents:
diff changeset
660
a61af66fc99e Initial load
duke
parents:
diff changeset
661 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
662 return static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
663 }
a61af66fc99e Initial load
duke
parents:
diff changeset
664
a61af66fc99e Initial load
duke
parents:
diff changeset
665 // Direct accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
666 static uint row_limit() {
a61af66fc99e Initial load
duke
parents:
diff changeset
667 return TypeProfileWidth;
a61af66fc99e Initial load
duke
parents:
diff changeset
668 }
a61af66fc99e Initial load
duke
parents:
diff changeset
669 static int receiver_cell_index(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
670 return receiver0_offset + row * receiver_type_row_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
671 }
a61af66fc99e Initial load
duke
parents:
diff changeset
672 static int receiver_count_cell_index(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
673 return count0_offset + row * receiver_type_row_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
674 }
a61af66fc99e Initial load
duke
parents:
diff changeset
675
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
676 Klass* receiver(uint row) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
677 assert(row < row_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
678
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
679 Klass* recv = (Klass*)intptr_at(receiver_cell_index(row));
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
680 assert(recv == NULL || recv->is_klass(), "wrong type");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
681 return recv;
a61af66fc99e Initial load
duke
parents:
diff changeset
682 }
a61af66fc99e Initial load
duke
parents:
diff changeset
683
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
684 void set_receiver(uint row, Klass* k) {
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
685 assert((uint)row < row_limit(), "oob");
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
686 set_intptr_at(receiver_cell_index(row), (uintptr_t)k);
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
687 }
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
688
0
a61af66fc99e Initial load
duke
parents:
diff changeset
689 uint receiver_count(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
690 assert(row < row_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
691 return uint_at(receiver_count_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
692 }
a61af66fc99e Initial load
duke
parents:
diff changeset
693
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
694 void set_receiver_count(uint row, uint count) {
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
695 assert(row < row_limit(), "oob");
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
696 set_uint_at(receiver_count_cell_index(row), count);
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
697 }
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
698
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
699 void clear_row(uint row) {
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
700 assert(row < row_limit(), "oob");
1251
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
701 // Clear total count - indicator of polymorphic call site.
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
702 // The site may look like as monomorphic after that but
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
703 // it allow to have more accurate profiling information because
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
704 // there was execution phase change since klasses were unloaded.
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
705 // If the site is still polymorphic then MDO will be updated
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
706 // to reflect it. But it could be the case that the site becomes
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
707 // only bimorphic. Then keeping total count not 0 will be wrong.
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
708 // Even if we use monomorphic (when it is not) for compilation
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
709 // we will only have trap, deoptimization and recompile again
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
710 // with updated MDO after executing method in Interpreter.
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
711 // An additional receiver will be recorded in the cleaned row
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
712 // during next call execution.
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
713 //
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
714 // Note: our profiling logic works with empty rows in any slot.
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
715 // We do sorting a profiling info (ciCallProfile) for compilation.
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
716 //
576e77447e3c 6923002: assert(false,"this call site should not be polymorphic")
kvn
parents: 1206
diff changeset
717 set_count(0);
941
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
718 set_receiver(row, NULL);
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
719 set_receiver_count(row, 0);
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
720 }
8b46c4d82093 4957990: Perm heap bloat in JVM
ysr
parents: 196
diff changeset
721
0
a61af66fc99e Initial load
duke
parents:
diff changeset
722 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
723 static ByteSize receiver_offset(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
724 return cell_offset(receiver_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
725 }
a61af66fc99e Initial load
duke
parents:
diff changeset
726 static ByteSize receiver_count_offset(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
727 return cell_offset(receiver_count_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
728 }
7154
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
729 #ifdef GRAAL
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
730 static ByteSize nonprofiled_receiver_count_offset() {
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
731 return cell_offset(nonprofiled_receiver_count_off_set);
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
732 }
5d0bb7d52783 changes to support Graal co-existing with the other HotSpot compiler(s) and being used for explicit compilation requests and code installation via the Graal API
Doug Simon <doug.simon@oracle.com>
parents: 6948
diff changeset
733 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
734 static ByteSize receiver_type_data_size() {
a61af66fc99e Initial load
duke
parents:
diff changeset
735 return cell_offset(static_cell_count());
a61af66fc99e Initial load
duke
parents:
diff changeset
736 }
a61af66fc99e Initial load
duke
parents:
diff changeset
737
a61af66fc99e Initial load
duke
parents:
diff changeset
738 // GC support
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
739 virtual void clean_weak_klass_links(BoolObjectClosure* is_alive_closure);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
740
a61af66fc99e Initial load
duke
parents:
diff changeset
741 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
742 void print_receiver_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
743 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
744 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
745 };
a61af66fc99e Initial load
duke
parents:
diff changeset
746
a61af66fc99e Initial load
duke
parents:
diff changeset
747 // VirtualCallData
a61af66fc99e Initial load
duke
parents:
diff changeset
748 //
a61af66fc99e Initial load
duke
parents:
diff changeset
749 // A VirtualCallData is used to access profiling information about a
a61af66fc99e Initial load
duke
parents:
diff changeset
750 // virtual call. For now, it has nothing more than a ReceiverTypeData.
a61af66fc99e Initial load
duke
parents:
diff changeset
751 class VirtualCallData : public ReceiverTypeData {
a61af66fc99e Initial load
duke
parents:
diff changeset
752 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
753 VirtualCallData(DataLayout* layout) : ReceiverTypeData(layout) {
a61af66fc99e Initial load
duke
parents:
diff changeset
754 assert(layout->tag() == DataLayout::virtual_call_data_tag, "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
755 }
a61af66fc99e Initial load
duke
parents:
diff changeset
756
a61af66fc99e Initial load
duke
parents:
diff changeset
757 virtual bool is_VirtualCallData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
758
a61af66fc99e Initial load
duke
parents:
diff changeset
759 static int static_cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
760 // At this point we could add more profile state, e.g., for arguments.
a61af66fc99e Initial load
duke
parents:
diff changeset
761 // But for now it's the same size as the base record type.
a61af66fc99e Initial load
duke
parents:
diff changeset
762 return ReceiverTypeData::static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
763 }
a61af66fc99e Initial load
duke
parents:
diff changeset
764
a61af66fc99e Initial load
duke
parents:
diff changeset
765 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
766 return static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
767 }
a61af66fc99e Initial load
duke
parents:
diff changeset
768
a61af66fc99e Initial load
duke
parents:
diff changeset
769 // Direct accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
770 static ByteSize virtual_call_data_size() {
a61af66fc99e Initial load
duke
parents:
diff changeset
771 return cell_offset(static_cell_count());
a61af66fc99e Initial load
duke
parents:
diff changeset
772 }
a61af66fc99e Initial load
duke
parents:
diff changeset
773
a61af66fc99e Initial load
duke
parents:
diff changeset
774 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
775 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
776 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
777 };
a61af66fc99e Initial load
duke
parents:
diff changeset
778
a61af66fc99e Initial load
duke
parents:
diff changeset
779 // RetData
a61af66fc99e Initial load
duke
parents:
diff changeset
780 //
a61af66fc99e Initial load
duke
parents:
diff changeset
781 // A RetData is used to access profiling information for a ret bytecode.
a61af66fc99e Initial load
duke
parents:
diff changeset
782 // It is composed of a count of the number of times that the ret has
a61af66fc99e Initial load
duke
parents:
diff changeset
783 // been executed, followed by a series of triples of the form
a61af66fc99e Initial load
duke
parents:
diff changeset
784 // (bci, count, di) which count the number of times that some bci was the
a61af66fc99e Initial load
duke
parents:
diff changeset
785 // target of the ret and cache a corresponding data displacement.
a61af66fc99e Initial load
duke
parents:
diff changeset
786 class RetData : public CounterData {
a61af66fc99e Initial load
duke
parents:
diff changeset
787 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
788 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
789 bci0_offset = counter_cell_count,
a61af66fc99e Initial load
duke
parents:
diff changeset
790 count0_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
791 displacement0_offset,
a61af66fc99e Initial load
duke
parents:
diff changeset
792 ret_row_cell_count = (displacement0_offset + 1) - bci0_offset
a61af66fc99e Initial load
duke
parents:
diff changeset
793 };
a61af66fc99e Initial load
duke
parents:
diff changeset
794
a61af66fc99e Initial load
duke
parents:
diff changeset
795 void set_bci(uint row, int bci) {
a61af66fc99e Initial load
duke
parents:
diff changeset
796 assert((uint)row < row_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
797 set_int_at(bci0_offset + row * ret_row_cell_count, bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
798 }
a61af66fc99e Initial load
duke
parents:
diff changeset
799 void release_set_bci(uint row, int bci) {
a61af66fc99e Initial load
duke
parents:
diff changeset
800 assert((uint)row < row_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
801 // 'release' when setting the bci acts as a valid flag for other
a61af66fc99e Initial load
duke
parents:
diff changeset
802 // threads wrt bci_count and bci_displacement.
a61af66fc99e Initial load
duke
parents:
diff changeset
803 release_set_int_at(bci0_offset + row * ret_row_cell_count, bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
804 }
a61af66fc99e Initial load
duke
parents:
diff changeset
805 void set_bci_count(uint row, uint count) {
a61af66fc99e Initial load
duke
parents:
diff changeset
806 assert((uint)row < row_limit(), "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
807 set_uint_at(count0_offset + row * ret_row_cell_count, count);
a61af66fc99e Initial load
duke
parents:
diff changeset
808 }
a61af66fc99e Initial load
duke
parents:
diff changeset
809 void set_bci_displacement(uint row, int disp) {
a61af66fc99e Initial load
duke
parents:
diff changeset
810 set_int_at(displacement0_offset + row * ret_row_cell_count, disp);
a61af66fc99e Initial load
duke
parents:
diff changeset
811 }
a61af66fc99e Initial load
duke
parents:
diff changeset
812
a61af66fc99e Initial load
duke
parents:
diff changeset
813 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
814 RetData(DataLayout* layout) : CounterData(layout) {
a61af66fc99e Initial load
duke
parents:
diff changeset
815 assert(layout->tag() == DataLayout::ret_data_tag, "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
816 }
a61af66fc99e Initial load
duke
parents:
diff changeset
817
a61af66fc99e Initial load
duke
parents:
diff changeset
818 virtual bool is_RetData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
819
a61af66fc99e Initial load
duke
parents:
diff changeset
820 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
821 no_bci = -1 // value of bci when bci1/2 are not in use.
a61af66fc99e Initial load
duke
parents:
diff changeset
822 };
a61af66fc99e Initial load
duke
parents:
diff changeset
823
a61af66fc99e Initial load
duke
parents:
diff changeset
824 static int static_cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
825 return counter_cell_count + (uint) BciProfileWidth * ret_row_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
826 }
a61af66fc99e Initial load
duke
parents:
diff changeset
827
a61af66fc99e Initial load
duke
parents:
diff changeset
828 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
829 return static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
830 }
a61af66fc99e Initial load
duke
parents:
diff changeset
831
a61af66fc99e Initial load
duke
parents:
diff changeset
832 static uint row_limit() {
a61af66fc99e Initial load
duke
parents:
diff changeset
833 return BciProfileWidth;
a61af66fc99e Initial load
duke
parents:
diff changeset
834 }
a61af66fc99e Initial load
duke
parents:
diff changeset
835 static int bci_cell_index(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
836 return bci0_offset + row * ret_row_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
837 }
a61af66fc99e Initial load
duke
parents:
diff changeset
838 static int bci_count_cell_index(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
839 return count0_offset + row * ret_row_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
840 }
a61af66fc99e Initial load
duke
parents:
diff changeset
841 static int bci_displacement_cell_index(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
842 return displacement0_offset + row * ret_row_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
843 }
a61af66fc99e Initial load
duke
parents:
diff changeset
844
a61af66fc99e Initial load
duke
parents:
diff changeset
845 // Direct accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
846 int bci(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
847 return int_at(bci_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
848 }
a61af66fc99e Initial load
duke
parents:
diff changeset
849 uint bci_count(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
850 return uint_at(bci_count_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
851 }
a61af66fc99e Initial load
duke
parents:
diff changeset
852 int bci_displacement(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
853 return int_at(bci_displacement_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
854 }
a61af66fc99e Initial load
duke
parents:
diff changeset
855
a61af66fc99e Initial load
duke
parents:
diff changeset
856 // Interpreter Runtime support
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
857 address fixup_ret(int return_bci, MethodData* mdo);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
858
a61af66fc99e Initial load
duke
parents:
diff changeset
859 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
860 static ByteSize bci_offset(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
861 return cell_offset(bci_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
862 }
a61af66fc99e Initial load
duke
parents:
diff changeset
863 static ByteSize bci_count_offset(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
864 return cell_offset(bci_count_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
865 }
a61af66fc99e Initial load
duke
parents:
diff changeset
866 static ByteSize bci_displacement_offset(uint row) {
a61af66fc99e Initial load
duke
parents:
diff changeset
867 return cell_offset(bci_displacement_cell_index(row));
a61af66fc99e Initial load
duke
parents:
diff changeset
868 }
a61af66fc99e Initial load
duke
parents:
diff changeset
869
a61af66fc99e Initial load
duke
parents:
diff changeset
870 // Specific initialization.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
871 void post_initialize(BytecodeStream* stream, MethodData* mdo);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
872
a61af66fc99e Initial load
duke
parents:
diff changeset
873 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
874 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
875 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
876 };
a61af66fc99e Initial load
duke
parents:
diff changeset
877
a61af66fc99e Initial load
duke
parents:
diff changeset
878 // BranchData
a61af66fc99e Initial load
duke
parents:
diff changeset
879 //
a61af66fc99e Initial load
duke
parents:
diff changeset
880 // A BranchData is used to access profiling data for a two-way branch.
a61af66fc99e Initial load
duke
parents:
diff changeset
881 // It consists of taken and not_taken counts as well as a data displacement
a61af66fc99e Initial load
duke
parents:
diff changeset
882 // for the taken case.
a61af66fc99e Initial load
duke
parents:
diff changeset
883 class BranchData : public JumpData {
a61af66fc99e Initial load
duke
parents:
diff changeset
884 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
885 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
886 not_taken_off_set = jump_cell_count,
a61af66fc99e Initial load
duke
parents:
diff changeset
887 branch_cell_count
a61af66fc99e Initial load
duke
parents:
diff changeset
888 };
a61af66fc99e Initial load
duke
parents:
diff changeset
889
a61af66fc99e Initial load
duke
parents:
diff changeset
890 void set_displacement(int displacement) {
a61af66fc99e Initial load
duke
parents:
diff changeset
891 set_int_at(displacement_off_set, displacement);
a61af66fc99e Initial load
duke
parents:
diff changeset
892 }
a61af66fc99e Initial load
duke
parents:
diff changeset
893
a61af66fc99e Initial load
duke
parents:
diff changeset
894 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
895 BranchData(DataLayout* layout) : JumpData(layout) {
a61af66fc99e Initial load
duke
parents:
diff changeset
896 assert(layout->tag() == DataLayout::branch_data_tag, "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
897 }
a61af66fc99e Initial load
duke
parents:
diff changeset
898
a61af66fc99e Initial load
duke
parents:
diff changeset
899 virtual bool is_BranchData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
900
a61af66fc99e Initial load
duke
parents:
diff changeset
901 static int static_cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
902 return branch_cell_count;
a61af66fc99e Initial load
duke
parents:
diff changeset
903 }
a61af66fc99e Initial load
duke
parents:
diff changeset
904
a61af66fc99e Initial load
duke
parents:
diff changeset
905 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
906 return static_cell_count();
a61af66fc99e Initial load
duke
parents:
diff changeset
907 }
a61af66fc99e Initial load
duke
parents:
diff changeset
908
a61af66fc99e Initial load
duke
parents:
diff changeset
909 // Direct accessor
a61af66fc99e Initial load
duke
parents:
diff changeset
910 uint not_taken() {
a61af66fc99e Initial load
duke
parents:
diff changeset
911 return uint_at(not_taken_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
912 }
a61af66fc99e Initial load
duke
parents:
diff changeset
913
3905
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
914 void set_not_taken(uint cnt) {
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
915 set_uint_at(not_taken_off_set, cnt);
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
916 }
c26de9aef2ed 7071307: MethodHandle bimorphic inlining should consider the frequency
never
parents: 3345
diff changeset
917
0
a61af66fc99e Initial load
duke
parents:
diff changeset
918 uint inc_not_taken() {
a61af66fc99e Initial load
duke
parents:
diff changeset
919 uint cnt = not_taken() + 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
920 // Did we wrap? Will compiler screw us??
a61af66fc99e Initial load
duke
parents:
diff changeset
921 if (cnt == 0) cnt--;
a61af66fc99e Initial load
duke
parents:
diff changeset
922 set_uint_at(not_taken_off_set, cnt);
a61af66fc99e Initial load
duke
parents:
diff changeset
923 return cnt;
a61af66fc99e Initial load
duke
parents:
diff changeset
924 }
a61af66fc99e Initial load
duke
parents:
diff changeset
925
a61af66fc99e Initial load
duke
parents:
diff changeset
926 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
927 static ByteSize not_taken_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
928 return cell_offset(not_taken_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
929 }
a61af66fc99e Initial load
duke
parents:
diff changeset
930 static ByteSize branch_data_size() {
a61af66fc99e Initial load
duke
parents:
diff changeset
931 return cell_offset(branch_cell_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
932 }
a61af66fc99e Initial load
duke
parents:
diff changeset
933
a61af66fc99e Initial load
duke
parents:
diff changeset
934 // Specific initialization.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
935 void post_initialize(BytecodeStream* stream, MethodData* mdo);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
936
a61af66fc99e Initial load
duke
parents:
diff changeset
937 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
938 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
939 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
940 };
a61af66fc99e Initial load
duke
parents:
diff changeset
941
a61af66fc99e Initial load
duke
parents:
diff changeset
942 // ArrayData
a61af66fc99e Initial load
duke
parents:
diff changeset
943 //
a61af66fc99e Initial load
duke
parents:
diff changeset
944 // A ArrayData is a base class for accessing profiling data which does
a61af66fc99e Initial load
duke
parents:
diff changeset
945 // not have a statically known size. It consists of an array length
a61af66fc99e Initial load
duke
parents:
diff changeset
946 // and an array start.
a61af66fc99e Initial load
duke
parents:
diff changeset
947 class ArrayData : public ProfileData {
a61af66fc99e Initial load
duke
parents:
diff changeset
948 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
949 friend class DataLayout;
a61af66fc99e Initial load
duke
parents:
diff changeset
950
a61af66fc99e Initial load
duke
parents:
diff changeset
951 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
952 array_len_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
953 array_start_off_set
a61af66fc99e Initial load
duke
parents:
diff changeset
954 };
a61af66fc99e Initial load
duke
parents:
diff changeset
955
a61af66fc99e Initial load
duke
parents:
diff changeset
956 uint array_uint_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
957 int aindex = index + array_start_off_set;
a61af66fc99e Initial load
duke
parents:
diff changeset
958 return uint_at(aindex);
a61af66fc99e Initial load
duke
parents:
diff changeset
959 }
a61af66fc99e Initial load
duke
parents:
diff changeset
960 int array_int_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
961 int aindex = index + array_start_off_set;
a61af66fc99e Initial load
duke
parents:
diff changeset
962 return int_at(aindex);
a61af66fc99e Initial load
duke
parents:
diff changeset
963 }
a61af66fc99e Initial load
duke
parents:
diff changeset
964 oop array_oop_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
965 int aindex = index + array_start_off_set;
a61af66fc99e Initial load
duke
parents:
diff changeset
966 return oop_at(aindex);
a61af66fc99e Initial load
duke
parents:
diff changeset
967 }
a61af66fc99e Initial load
duke
parents:
diff changeset
968 void array_set_int_at(int index, int value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
969 int aindex = index + array_start_off_set;
a61af66fc99e Initial load
duke
parents:
diff changeset
970 set_int_at(aindex, value);
a61af66fc99e Initial load
duke
parents:
diff changeset
971 }
a61af66fc99e Initial load
duke
parents:
diff changeset
972
a61af66fc99e Initial load
duke
parents:
diff changeset
973 // Code generation support for subclasses.
a61af66fc99e Initial load
duke
parents:
diff changeset
974 static ByteSize array_element_offset(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
975 return cell_offset(array_start_off_set + index);
a61af66fc99e Initial load
duke
parents:
diff changeset
976 }
a61af66fc99e Initial load
duke
parents:
diff changeset
977
a61af66fc99e Initial load
duke
parents:
diff changeset
978 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
979 ArrayData(DataLayout* layout) : ProfileData(layout) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
980
a61af66fc99e Initial load
duke
parents:
diff changeset
981 virtual bool is_ArrayData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
982
a61af66fc99e Initial load
duke
parents:
diff changeset
983 static int static_cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
984 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
985 }
a61af66fc99e Initial load
duke
parents:
diff changeset
986
a61af66fc99e Initial load
duke
parents:
diff changeset
987 int array_len() {
a61af66fc99e Initial load
duke
parents:
diff changeset
988 return int_at_unchecked(array_len_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
989 }
a61af66fc99e Initial load
duke
parents:
diff changeset
990
a61af66fc99e Initial load
duke
parents:
diff changeset
991 virtual int cell_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
992 return array_len() + 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
993 }
a61af66fc99e Initial load
duke
parents:
diff changeset
994
a61af66fc99e Initial load
duke
parents:
diff changeset
995 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
996 static ByteSize array_len_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
997 return cell_offset(array_len_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
998 }
a61af66fc99e Initial load
duke
parents:
diff changeset
999 static ByteSize array_start_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1000 return cell_offset(array_start_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
1001 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1002 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1003
a61af66fc99e Initial load
duke
parents:
diff changeset
1004 // MultiBranchData
a61af66fc99e Initial load
duke
parents:
diff changeset
1005 //
a61af66fc99e Initial load
duke
parents:
diff changeset
1006 // A MultiBranchData is used to access profiling information for
a61af66fc99e Initial load
duke
parents:
diff changeset
1007 // a multi-way branch (*switch bytecodes). It consists of a series
a61af66fc99e Initial load
duke
parents:
diff changeset
1008 // of (count, displacement) pairs, which count the number of times each
a61af66fc99e Initial load
duke
parents:
diff changeset
1009 // case was taken and specify the data displacment for each branch target.
a61af66fc99e Initial load
duke
parents:
diff changeset
1010 class MultiBranchData : public ArrayData {
a61af66fc99e Initial load
duke
parents:
diff changeset
1011 protected:
a61af66fc99e Initial load
duke
parents:
diff changeset
1012 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
1013 default_count_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
1014 default_disaplacement_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
1015 case_array_start
a61af66fc99e Initial load
duke
parents:
diff changeset
1016 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1017 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
1018 relative_count_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
1019 relative_displacement_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
1020 per_case_cell_count
a61af66fc99e Initial load
duke
parents:
diff changeset
1021 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1022
a61af66fc99e Initial load
duke
parents:
diff changeset
1023 void set_default_displacement(int displacement) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1024 array_set_int_at(default_disaplacement_off_set, displacement);
a61af66fc99e Initial load
duke
parents:
diff changeset
1025 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1026 void set_displacement_at(int index, int displacement) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1027 array_set_int_at(case_array_start +
a61af66fc99e Initial load
duke
parents:
diff changeset
1028 index * per_case_cell_count +
a61af66fc99e Initial load
duke
parents:
diff changeset
1029 relative_displacement_off_set,
a61af66fc99e Initial load
duke
parents:
diff changeset
1030 displacement);
a61af66fc99e Initial load
duke
parents:
diff changeset
1031 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1032
a61af66fc99e Initial load
duke
parents:
diff changeset
1033 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
1034 MultiBranchData(DataLayout* layout) : ArrayData(layout) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1035 assert(layout->tag() == DataLayout::multi_branch_data_tag, "wrong type");
a61af66fc99e Initial load
duke
parents:
diff changeset
1036 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1037
a61af66fc99e Initial load
duke
parents:
diff changeset
1038 virtual bool is_MultiBranchData() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1039
a61af66fc99e Initial load
duke
parents:
diff changeset
1040 static int compute_cell_count(BytecodeStream* stream);
a61af66fc99e Initial load
duke
parents:
diff changeset
1041
a61af66fc99e Initial load
duke
parents:
diff changeset
1042 int number_of_cases() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1043 int alen = array_len() - 2; // get rid of default case here.
a61af66fc99e Initial load
duke
parents:
diff changeset
1044 assert(alen % per_case_cell_count == 0, "must be even");
a61af66fc99e Initial load
duke
parents:
diff changeset
1045 return (alen / per_case_cell_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
1046 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1047
a61af66fc99e Initial load
duke
parents:
diff changeset
1048 uint default_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1049 return array_uint_at(default_count_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
1050 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1051 int default_displacement() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1052 return array_int_at(default_disaplacement_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
1053 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1054
a61af66fc99e Initial load
duke
parents:
diff changeset
1055 uint count_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1056 return array_uint_at(case_array_start +
a61af66fc99e Initial load
duke
parents:
diff changeset
1057 index * per_case_cell_count +
a61af66fc99e Initial load
duke
parents:
diff changeset
1058 relative_count_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
1059 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1060 int displacement_at(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1061 return array_int_at(case_array_start +
a61af66fc99e Initial load
duke
parents:
diff changeset
1062 index * per_case_cell_count +
a61af66fc99e Initial load
duke
parents:
diff changeset
1063 relative_displacement_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
1064 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1065
a61af66fc99e Initial load
duke
parents:
diff changeset
1066 // Code generation support
a61af66fc99e Initial load
duke
parents:
diff changeset
1067 static ByteSize default_count_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1068 return array_element_offset(default_count_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
1069 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1070 static ByteSize default_displacement_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1071 return array_element_offset(default_disaplacement_off_set);
a61af66fc99e Initial load
duke
parents:
diff changeset
1072 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1073 static ByteSize case_count_offset(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1074 return case_array_offset() +
a61af66fc99e Initial load
duke
parents:
diff changeset
1075 (per_case_size() * index) +
a61af66fc99e Initial load
duke
parents:
diff changeset
1076 relative_count_offset();
a61af66fc99e Initial load
duke
parents:
diff changeset
1077 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1078 static ByteSize case_array_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1079 return array_element_offset(case_array_start);
a61af66fc99e Initial load
duke
parents:
diff changeset
1080 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1081 static ByteSize per_case_size() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1082 return in_ByteSize(per_case_cell_count) * cell_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1083 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1084 static ByteSize relative_count_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1085 return in_ByteSize(relative_count_off_set) * cell_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1086 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1087 static ByteSize relative_displacement_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1088 return in_ByteSize(relative_displacement_off_set) * cell_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1089 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1090
a61af66fc99e Initial load
duke
parents:
diff changeset
1091 // Specific initialization.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1092 void post_initialize(BytecodeStream* stream, MethodData* mdo);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1093
a61af66fc99e Initial load
duke
parents:
diff changeset
1094 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
1095 void print_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
1096 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
1097 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1098
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1099 class ArgInfoData : public ArrayData {
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1100
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1101 public:
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1102 ArgInfoData(DataLayout* layout) : ArrayData(layout) {
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1103 assert(layout->tag() == DataLayout::arg_info_data_tag, "wrong type");
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1104 }
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1105
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1106 virtual bool is_ArgInfoData() { return true; }
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1107
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1108
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1109 int number_of_args() {
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1110 return array_len();
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1111 }
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1112
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1113 uint arg_modified(int arg) {
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1114 return array_uint_at(arg);
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1115 }
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1116
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1117 void set_arg_modified(int arg, uint val) {
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1118 array_set_int_at(arg, val);
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1119 }
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1120
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1121 #ifndef PRODUCT
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1122 void print_data_on(outputStream* st);
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1123 #endif
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1124 };
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1125
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1126 // MethodData*
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1127 //
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1128 // A MethodData* holds information which has been collected about
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1129 // a method. Its layout looks like this:
a61af66fc99e Initial load
duke
parents:
diff changeset
1130 //
a61af66fc99e Initial load
duke
parents:
diff changeset
1131 // -----------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
1132 // | header |
a61af66fc99e Initial load
duke
parents:
diff changeset
1133 // | klass |
a61af66fc99e Initial load
duke
parents:
diff changeset
1134 // -----------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
1135 // | method |
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1136 // | size of the MethodData* |
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1137 // -----------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
1138 // | Data entries... |
a61af66fc99e Initial load
duke
parents:
diff changeset
1139 // | (variable size) |
a61af66fc99e Initial load
duke
parents:
diff changeset
1140 // | |
a61af66fc99e Initial load
duke
parents:
diff changeset
1141 // . .
a61af66fc99e Initial load
duke
parents:
diff changeset
1142 // . .
a61af66fc99e Initial load
duke
parents:
diff changeset
1143 // . .
a61af66fc99e Initial load
duke
parents:
diff changeset
1144 // | |
a61af66fc99e Initial load
duke
parents:
diff changeset
1145 // -----------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
1146 //
a61af66fc99e Initial load
duke
parents:
diff changeset
1147 // The data entry area is a heterogeneous array of DataLayouts. Each
a61af66fc99e Initial load
duke
parents:
diff changeset
1148 // DataLayout in the array corresponds to a specific bytecode in the
a61af66fc99e Initial load
duke
parents:
diff changeset
1149 // method. The entries in the array are sorted by the corresponding
a61af66fc99e Initial load
duke
parents:
diff changeset
1150 // bytecode. Access to the data is via resource-allocated ProfileData,
a61af66fc99e Initial load
duke
parents:
diff changeset
1151 // which point to the underlying blocks of DataLayout structures.
a61af66fc99e Initial load
duke
parents:
diff changeset
1152 //
a61af66fc99e Initial load
duke
parents:
diff changeset
1153 // During interpretation, if profiling in enabled, the interpreter
a61af66fc99e Initial load
duke
parents:
diff changeset
1154 // maintains a method data pointer (mdp), which points at the entry
a61af66fc99e Initial load
duke
parents:
diff changeset
1155 // in the array corresponding to the current bci. In the course of
a61af66fc99e Initial load
duke
parents:
diff changeset
1156 // intepretation, when a bytecode is encountered that has profile data
a61af66fc99e Initial load
duke
parents:
diff changeset
1157 // associated with it, the entry pointed to by mdp is updated, then the
a61af66fc99e Initial load
duke
parents:
diff changeset
1158 // mdp is adjusted to point to the next appropriate DataLayout. If mdp
a61af66fc99e Initial load
duke
parents:
diff changeset
1159 // is NULL to begin with, the interpreter assumes that the current method
a61af66fc99e Initial load
duke
parents:
diff changeset
1160 // is not (yet) being profiled.
a61af66fc99e Initial load
duke
parents:
diff changeset
1161 //
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1162 // In MethodData* parlance, "dp" is a "data pointer", the actual address
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1163 // of a DataLayout element. A "di" is a "data index", the offset in bytes
a61af66fc99e Initial load
duke
parents:
diff changeset
1164 // from the base of the data entry array. A "displacement" is the byte offset
a61af66fc99e Initial load
duke
parents:
diff changeset
1165 // in certain ProfileData objects that indicate the amount the mdp must be
a61af66fc99e Initial load
duke
parents:
diff changeset
1166 // adjusted in the event of a change in control flow.
a61af66fc99e Initial load
duke
parents:
diff changeset
1167 //
a61af66fc99e Initial load
duke
parents:
diff changeset
1168
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1169 class MethodData : public Metadata {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1170 friend class VMStructs;
a61af66fc99e Initial load
duke
parents:
diff changeset
1171 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
1172 friend class ProfileData;
a61af66fc99e Initial load
duke
parents:
diff changeset
1173
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1174 // Back pointer to the Method*
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1175 Method* _method;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1176
a61af66fc99e Initial load
duke
parents:
diff changeset
1177 // Size of this oop in bytes
a61af66fc99e Initial load
duke
parents:
diff changeset
1178 int _size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1179
a61af66fc99e Initial load
duke
parents:
diff changeset
1180 // Cached hint for bci_to_dp and bci_to_data
a61af66fc99e Initial load
duke
parents:
diff changeset
1181 int _hint_di;
a61af66fc99e Initial load
duke
parents:
diff changeset
1182
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1183 MethodData(methodHandle method, int size, TRAPS);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1184 public:
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1185 static MethodData* allocate(ClassLoaderData* loader_data, methodHandle method, TRAPS);
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1186 MethodData() {}; // For ciMethodData
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1187
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1188 bool is_methodData() const volatile { return true; }
8611
6c4db417385a added API to reset the profiling information for a method
Christian Haeubl <haeubl@ssw.jku.at>
parents: 8124
diff changeset
1189 void initialize();
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1190
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1191 // Whole-method sticky bits and flags
a61af66fc99e Initial load
duke
parents:
diff changeset
1192 enum {
3345
bad7ecd0b6ed 5091921: Sign flip issues in loop optimizer
kvn
parents: 2333
diff changeset
1193 _trap_hist_limit = 17, // decoupled from Deoptimization::Reason_LIMIT
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1194 _trap_hist_mask = max_jubyte,
a61af66fc99e Initial load
duke
parents:
diff changeset
1195 _extra_data_count = 4 // extra DataLayout headers, for trap history
a61af66fc99e Initial load
duke
parents:
diff changeset
1196 }; // Public flag values
a61af66fc99e Initial load
duke
parents:
diff changeset
1197 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
1198 uint _nof_decompiles; // count of all nmethod removals
a61af66fc99e Initial load
duke
parents:
diff changeset
1199 uint _nof_overflow_recompiles; // recompile count, excluding recomp. bits
a61af66fc99e Initial load
duke
parents:
diff changeset
1200 uint _nof_overflow_traps; // trap count, excluding _trap_hist
a61af66fc99e Initial load
duke
parents:
diff changeset
1201 union {
a61af66fc99e Initial load
duke
parents:
diff changeset
1202 intptr_t _align;
a61af66fc99e Initial load
duke
parents:
diff changeset
1203 u1 _array[_trap_hist_limit];
a61af66fc99e Initial load
duke
parents:
diff changeset
1204 } _trap_hist;
a61af66fc99e Initial load
duke
parents:
diff changeset
1205
a61af66fc99e Initial load
duke
parents:
diff changeset
1206 // Support for interprocedural escape analysis, from Thomas Kotzmann.
a61af66fc99e Initial load
duke
parents:
diff changeset
1207 intx _eflags; // flags on escape information
a61af66fc99e Initial load
duke
parents:
diff changeset
1208 intx _arg_local; // bit set of non-escaping arguments
a61af66fc99e Initial load
duke
parents:
diff changeset
1209 intx _arg_stack; // bit set of stack-allocatable arguments
a61af66fc99e Initial load
duke
parents:
diff changeset
1210 intx _arg_returned; // bit set of returned arguments
a61af66fc99e Initial load
duke
parents:
diff changeset
1211
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1212 int _creation_mileage; // method mileage at MDO creation
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1213
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1214 // How many invocations has this MDO seen?
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1215 // These counters are used to determine the exact age of MDO.
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1216 // We need those because in tiered a method can be concurrently
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1217 // executed at different levels.
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1218 InvocationCounter _invocation_counter;
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1219 // Same for backedges.
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1220 InvocationCounter _backedge_counter;
2252
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1221 // Counter values at the time profiling started.
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1222 int _invocation_counter_start;
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1223 int _backedge_counter_start;
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1224 // Number of loops and blocks is computed when compiling the first
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1225 // time with C1. It is used to determine if method is trivial.
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1226 short _num_loops;
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1227 short _num_blocks;
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1228 // Highest compile level this method has ever seen.
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1229 u1 _highest_comp_level;
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1230 // Same for OSR level
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1231 u1 _highest_osr_comp_level;
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1232 // Does this method contain anything worth profiling?
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1233 bool _would_profile;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1234
a61af66fc99e Initial load
duke
parents:
diff changeset
1235 // Size of _data array in bytes. (Excludes header and extra_data fields.)
a61af66fc99e Initial load
duke
parents:
diff changeset
1236 int _data_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1237
a61af66fc99e Initial load
duke
parents:
diff changeset
1238 // Beginning of the data entries
a61af66fc99e Initial load
duke
parents:
diff changeset
1239 intptr_t _data[1];
a61af66fc99e Initial load
duke
parents:
diff changeset
1240
a61af66fc99e Initial load
duke
parents:
diff changeset
1241 // Helper for size computation
a61af66fc99e Initial load
duke
parents:
diff changeset
1242 static int compute_data_size(BytecodeStream* stream);
a61af66fc99e Initial load
duke
parents:
diff changeset
1243 static int bytecode_cell_count(Bytecodes::Code code);
a61af66fc99e Initial load
duke
parents:
diff changeset
1244 enum { no_profile_data = -1, variable_cell_count = -2 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1245
a61af66fc99e Initial load
duke
parents:
diff changeset
1246 // Helper for initialization
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1247 DataLayout* data_layout_at(int data_index) const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1248 assert(data_index % sizeof(intptr_t) == 0, "unaligned");
a61af66fc99e Initial load
duke
parents:
diff changeset
1249 return (DataLayout*) (((address)_data) + data_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1250 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1251
a61af66fc99e Initial load
duke
parents:
diff changeset
1252 // Initialize an individual data segment. Returns the size of
a61af66fc99e Initial load
duke
parents:
diff changeset
1253 // the segment in bytes.
a61af66fc99e Initial load
duke
parents:
diff changeset
1254 int initialize_data(BytecodeStream* stream, int data_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
1255
a61af66fc99e Initial load
duke
parents:
diff changeset
1256 // Helper for data_at
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1257 DataLayout* limit_data_position() const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1258 return (DataLayout*)((address)data_base() + _data_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
1259 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1260 bool out_of_bounds(int data_index) const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1261 return data_index >= data_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
1262 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1263
a61af66fc99e Initial load
duke
parents:
diff changeset
1264 // Give each of the data entries a chance to perform specific
a61af66fc99e Initial load
duke
parents:
diff changeset
1265 // data initialization.
a61af66fc99e Initial load
duke
parents:
diff changeset
1266 void post_initialize(BytecodeStream* stream);
a61af66fc99e Initial load
duke
parents:
diff changeset
1267
a61af66fc99e Initial load
duke
parents:
diff changeset
1268 // hint accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
1269 int hint_di() const { return _hint_di; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1270 void set_hint_di(int di) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1271 assert(!out_of_bounds(di), "hint_di out of bounds");
a61af66fc99e Initial load
duke
parents:
diff changeset
1272 _hint_di = di;
a61af66fc99e Initial load
duke
parents:
diff changeset
1273 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1274 ProfileData* data_before(int bci) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1275 // avoid SEGV on this edge case
a61af66fc99e Initial load
duke
parents:
diff changeset
1276 if (data_size() == 0)
a61af66fc99e Initial load
duke
parents:
diff changeset
1277 return NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
1278 int hint = hint_di();
a61af66fc99e Initial load
duke
parents:
diff changeset
1279 if (data_layout_at(hint)->bci() <= bci)
a61af66fc99e Initial load
duke
parents:
diff changeset
1280 return data_at(hint);
a61af66fc99e Initial load
duke
parents:
diff changeset
1281 return first_data();
a61af66fc99e Initial load
duke
parents:
diff changeset
1282 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1283
a61af66fc99e Initial load
duke
parents:
diff changeset
1284 // What is the index of the first data entry?
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1285 int first_di() const { return 0; }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1286
a61af66fc99e Initial load
duke
parents:
diff changeset
1287 // Find or create an extra ProfileData:
a61af66fc99e Initial load
duke
parents:
diff changeset
1288 ProfileData* bci_to_extra_data(int bci, bool create_if_missing);
a61af66fc99e Initial load
duke
parents:
diff changeset
1289
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1290 // return the argument info cell
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1291 ArgInfoData *arg_info();
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1292
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1293 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
1294 static int header_size() {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1295 return sizeof(MethodData)/wordSize;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1296 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1297
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1298 // Compute the size of a MethodData* before it is created.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1299 static int compute_allocation_size_in_bytes(methodHandle method);
a61af66fc99e Initial load
duke
parents:
diff changeset
1300 static int compute_allocation_size_in_words(methodHandle method);
a61af66fc99e Initial load
duke
parents:
diff changeset
1301 static int compute_extra_data_count(int data_size, int empty_bc_count);
a61af66fc99e Initial load
duke
parents:
diff changeset
1302
a61af66fc99e Initial load
duke
parents:
diff changeset
1303 // Determine if a given bytecode can have profile information.
a61af66fc99e Initial load
duke
parents:
diff changeset
1304 static bool bytecode_has_profile(Bytecodes::Code code) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1305 return bytecode_cell_count(code) != no_profile_data;
a61af66fc99e Initial load
duke
parents:
diff changeset
1306 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1307
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8000
diff changeset
1308 // reset into original state
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8000
diff changeset
1309 void init();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1310
a61af66fc99e Initial load
duke
parents:
diff changeset
1311 // My size
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1312 int size_in_bytes() const { return _size; }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1313 int size() const { return align_object_size(align_size_up(_size, BytesPerWord)/BytesPerWord); }
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
1314 #if INCLUDE_SERVICES
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
1315 void collect_statistics(KlassSizeStats *sz) const;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
1316 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1317
a61af66fc99e Initial load
duke
parents:
diff changeset
1318 int creation_mileage() const { return _creation_mileage; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1319 void set_creation_mileage(int x) { _creation_mileage = x; }
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1320
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1321 int invocation_count() {
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1322 if (invocation_counter()->carry()) {
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1323 return InvocationCounter::count_limit;
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1324 }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1325 return invocation_counter()->count();
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1326 }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1327 int backedge_count() {
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1328 if (backedge_counter()->carry()) {
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1329 return InvocationCounter::count_limit;
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1330 }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1331 return backedge_counter()->count();
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1332 }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1333
2252
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1334 int invocation_count_start() {
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1335 if (invocation_counter()->carry()) {
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1336 return 0;
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1337 }
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1338 return _invocation_counter_start;
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1339 }
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1340
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1341 int backedge_count_start() {
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1342 if (backedge_counter()->carry()) {
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1343 return 0;
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1344 }
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1345 return _backedge_counter_start;
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1346 }
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1347
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1348 int invocation_count_delta() { return invocation_count() - invocation_count_start(); }
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1349 int backedge_count_delta() { return backedge_count() - backedge_count_start(); }
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1350
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1351 void reset_start_counters() {
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1352 _invocation_counter_start = invocation_count();
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1353 _backedge_counter_start = backedge_count();
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1354 }
72d6c57d0658 7017434: Tiered needs to support reprofiling
iveresov
parents: 1972
diff changeset
1355
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1356 InvocationCounter* invocation_counter() { return &_invocation_counter; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1357 InvocationCounter* backedge_counter() { return &_backedge_counter; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1358
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1359 void set_would_profile(bool p) { _would_profile = p; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1360 bool would_profile() const { return _would_profile; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1361
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1362 int highest_comp_level() { return _highest_comp_level; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1363 void set_highest_comp_level(int level) { _highest_comp_level = level; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1364 int highest_osr_comp_level() { return _highest_osr_comp_level; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1365 void set_highest_osr_comp_level(int level) { _highest_osr_comp_level = level; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1366
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1367 int num_loops() const { return _num_loops; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1368 void set_num_loops(int n) { _num_loops = n; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1369 int num_blocks() const { return _num_blocks; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1370 void set_num_blocks(int n) { _num_blocks = n; }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1371
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1372 bool is_mature() const; // consult mileage and ProfileMaturityPercentage
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1373 static int mileage_of(Method* m);
4568
8e1d9c27989a better allocation of methodData's extraData so that exceptions and deoptimizations can be recorded more accurately
Christian Haeubl <christian.haeubl@oracle.com>
parents: 4439
diff changeset
1374 static bool is_empty_data(int size, Bytecodes::Code code);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1375
a61af66fc99e Initial load
duke
parents:
diff changeset
1376 // Support for interprocedural escape analysis, from Thomas Kotzmann.
a61af66fc99e Initial load
duke
parents:
diff changeset
1377 enum EscapeFlag {
a61af66fc99e Initial load
duke
parents:
diff changeset
1378 estimated = 1 << 0,
78
e1e86702e43e 6680665: bytecode Escape Analyzer produces incorrect escape information for methods without oop arguments
kvn
parents: 45
diff changeset
1379 return_local = 1 << 1,
e1e86702e43e 6680665: bytecode Escape Analyzer produces incorrect escape information for methods without oop arguments
kvn
parents: 45
diff changeset
1380 return_allocated = 1 << 2,
e1e86702e43e 6680665: bytecode Escape Analyzer produces incorrect escape information for methods without oop arguments
kvn
parents: 45
diff changeset
1381 allocated_escapes = 1 << 3,
e1e86702e43e 6680665: bytecode Escape Analyzer produces incorrect escape information for methods without oop arguments
kvn
parents: 45
diff changeset
1382 unknown_modified = 1 << 4
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1383 };
a61af66fc99e Initial load
duke
parents:
diff changeset
1384
a61af66fc99e Initial load
duke
parents:
diff changeset
1385 intx eflags() { return _eflags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1386 intx arg_local() { return _arg_local; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1387 intx arg_stack() { return _arg_stack; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1388 intx arg_returned() { return _arg_returned; }
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1389 uint arg_modified(int a) { ArgInfoData *aid = arg_info();
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8000
diff changeset
1390 assert(aid != NULL, "arg_info must be not null");
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1391 assert(a >= 0 && a < aid->number_of_args(), "valid argument number");
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1392 return aid->arg_modified(a); }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1393
a61af66fc99e Initial load
duke
parents:
diff changeset
1394 void set_eflags(intx v) { _eflags = v; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1395 void set_arg_local(intx v) { _arg_local = v; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1396 void set_arg_stack(intx v) { _arg_stack = v; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1397 void set_arg_returned(intx v) { _arg_returned = v; }
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1398 void set_arg_modified(int a, uint v) { ArgInfoData *aid = arg_info();
9080
b84fd7d73702 8007288: Additional WB API for compiler's testing
iignatyev
parents: 8000
diff changeset
1399 assert(aid != NULL, "arg_info must be not null");
45
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1400 assert(a >= 0 && a < aid->number_of_args(), "valid argument number");
48a3fa21394b 6667615: (Escape Analysis) extend MDO to cache arguments escape state
kvn
parents: 0
diff changeset
1401 aid->set_arg_modified(a, v); }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1402
a61af66fc99e Initial load
duke
parents:
diff changeset
1403 void clear_escape_info() { _eflags = _arg_local = _arg_stack = _arg_returned = 0; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1404
a61af66fc99e Initial load
duke
parents:
diff changeset
1405 // Location and size of data area
a61af66fc99e Initial load
duke
parents:
diff changeset
1406 address data_base() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
1407 return (address) _data;
a61af66fc99e Initial load
duke
parents:
diff changeset
1408 }
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1409 int data_size() const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1410 return _data_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
1411 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1412
a61af66fc99e Initial load
duke
parents:
diff changeset
1413 // Accessors
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1414 Method* method() const { return _method; }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1415
a61af66fc99e Initial load
duke
parents:
diff changeset
1416 // Get the data at an arbitrary (sort of) data index.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1417 ProfileData* data_at(int data_index) const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1418
a61af66fc99e Initial load
duke
parents:
diff changeset
1419 // Walk through the data in order.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1420 ProfileData* first_data() const { return data_at(first_di()); }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1421 ProfileData* next_data(ProfileData* current) const;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1422 bool is_valid(ProfileData* current) const { return current != NULL; }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1423
a61af66fc99e Initial load
duke
parents:
diff changeset
1424 // Convert a dp (data pointer) to a di (data index).
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1425 int dp_to_di(address dp) const {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1426 return dp - ((address)_data);
a61af66fc99e Initial load
duke
parents:
diff changeset
1427 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1428
a61af66fc99e Initial load
duke
parents:
diff changeset
1429 address di_to_dp(int di) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1430 return (address)data_layout_at(di);
a61af66fc99e Initial load
duke
parents:
diff changeset
1431 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1432
a61af66fc99e Initial load
duke
parents:
diff changeset
1433 // bci to di/dp conversion.
a61af66fc99e Initial load
duke
parents:
diff changeset
1434 address bci_to_dp(int bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
1435 int bci_to_di(int bci) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1436 return dp_to_di(bci_to_dp(bci));
a61af66fc99e Initial load
duke
parents:
diff changeset
1437 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1438
a61af66fc99e Initial load
duke
parents:
diff changeset
1439 // Get the data at an arbitrary bci, or NULL if there is none.
a61af66fc99e Initial load
duke
parents:
diff changeset
1440 ProfileData* bci_to_data(int bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
1441
a61af66fc99e Initial load
duke
parents:
diff changeset
1442 // Same, but try to create an extra_data record if one is needed:
a61af66fc99e Initial load
duke
parents:
diff changeset
1443 ProfileData* allocate_bci_to_data(int bci) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1444 ProfileData* data = bci_to_data(bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
1445 return (data != NULL) ? data : bci_to_extra_data(bci, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
1446 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1447
a61af66fc99e Initial load
duke
parents:
diff changeset
1448 // Add a handful of extra data records, for trap tracking.
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1449 DataLayout* extra_data_base() const { return limit_data_position(); }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1450 DataLayout* extra_data_limit() const { return (DataLayout*)((address)this + size_in_bytes()); }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1451 int extra_data_size() const { return (address)extra_data_limit()
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1452 - (address)extra_data_base(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
1453 static DataLayout* next_extra(DataLayout* dp) { return (DataLayout*)((address)dp + in_bytes(DataLayout::cell_offset(0))); }
a61af66fc99e Initial load
duke
parents:
diff changeset
1454
a61af66fc99e Initial load
duke
parents:
diff changeset
1455 // Return (uint)-1 for overflow.
a61af66fc99e Initial load
duke
parents:
diff changeset
1456 uint trap_count(int reason) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
1457 assert((uint)reason < _trap_hist_limit, "oob");
a61af66fc99e Initial load
duke
parents:
diff changeset
1458 return (int)((_trap_hist._array[reason]+1) & _trap_hist_mask) - 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
1459 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1460 // For loops:
a61af66fc99e Initial load
duke
parents:
diff changeset
1461 static uint trap_reason_limit() { return _trap_hist_limit; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1462 static uint trap_count_limit() { return _trap_hist_mask; }
a61af66fc99e Initial load
duke
parents:
diff changeset
1463 uint inc_trap_count(int reason) {
a61af66fc99e Initial load
duke
parents:
diff changeset
1464 // Count another trap, anywhere in this method.
a61af66fc99e Initial load
duke
parents:
diff changeset
1465 assert(reason >= 0, "must be single trap");
5114
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1466 assert((uint)reason < _trap_hist_limit, "oob");
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1467 uint cnt1 = 1 + _trap_hist._array[reason];
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1468 if ((cnt1 & _trap_hist_mask) != 0) { // if no counter overflow...
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1469 _trap_hist._array[reason] = cnt1;
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1470 return cnt1;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1471 } else {
5114
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1472 return _trap_hist_mask + (++_nof_overflow_traps);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1473 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1474 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1475
a61af66fc99e Initial load
duke
parents:
diff changeset
1476 uint overflow_trap_count() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
1477 return _nof_overflow_traps;
a61af66fc99e Initial load
duke
parents:
diff changeset
1478 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1479 uint overflow_recompile_count() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
1480 return _nof_overflow_recompiles;
a61af66fc99e Initial load
duke
parents:
diff changeset
1481 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1482 void inc_overflow_recompile_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1483 _nof_overflow_recompiles += 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
1484 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1485 uint decompile_count() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
1486 return _nof_decompiles;
a61af66fc99e Initial load
duke
parents:
diff changeset
1487 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1488 void inc_decompile_count() {
a61af66fc99e Initial load
duke
parents:
diff changeset
1489 _nof_decompiles += 1;
1206
87684f1a88b5 6614597: Performance variability in jvm2008 xml.validation
kvn
parents: 948
diff changeset
1490 if (decompile_count() > (uint)PerMethodRecompilationCutoff) {
7998
6a51fc70a15e 8006613: adding reason to made_not_compilable
vlivanov
parents: 6725
diff changeset
1491 method()->set_not_compilable(CompLevel_full_optimization, true, "decompile_count > PerMethodRecompilationCutoff");
1206
87684f1a88b5 6614597: Performance variability in jvm2008 xml.validation
kvn
parents: 948
diff changeset
1492 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1493 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1494
a61af66fc99e Initial load
duke
parents:
diff changeset
1495 // Support for code generation
a61af66fc99e Initial load
duke
parents:
diff changeset
1496 static ByteSize data_offset() {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1497 return byte_offset_of(MethodData, _data[0]);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1498 }
a61af66fc99e Initial load
duke
parents:
diff changeset
1499
5114
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1500 static ByteSize trap_history_offset() {
6948
e522a00b91aa Merge with http://hg.openjdk.java.net/hsx/hsx25/hotspot/ after NPG - C++ build works
Doug Simon <doug.simon@oracle.com>
parents: 5114 6725
diff changeset
1501 return byte_offset_of(MethodData, _trap_hist._array);
5114
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1502 }
dad1ac9dba7d finished first implementation of disabling runtime feedback selectively based on deoptimization history
Christian Haeubl <christian.haeubl@oracle.com>
parents: 5111
diff changeset
1503
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1504 static ByteSize invocation_counter_offset() {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1505 return byte_offset_of(MethodData, _invocation_counter);
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1506 }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1507 static ByteSize backedge_counter_offset() {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1508 return byte_offset_of(MethodData, _backedge_counter);
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1509 }
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
1510
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1511 // Deallocation support - no pointer fields to deallocate
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1512 void deallocate_contents(ClassLoaderData* loader_data) {}
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1513
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1514 // GC support
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1515 void set_size(int object_size_in_bytes) { _size = object_size_in_bytes; }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1516
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1517 // Printing
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1518 #ifndef PRODUCT
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1519 void print_on (outputStream* st) const;
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1520 #endif
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1521 void print_value_on(outputStream* st) const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1522
a61af66fc99e Initial load
duke
parents:
diff changeset
1523 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
1524 // printing support for method data
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1525 void print_data_on(outputStream* st) const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1526 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
1527
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1528 const char* internal_name() const { return "{method data}"; }
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1529
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1530 // verification
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 3905
diff changeset
1531 void verify_on(outputStream* st);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1532 void verify_data_on(outputStream* st);
a61af66fc99e Initial load
duke
parents:
diff changeset
1533 };
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
1534
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1783
diff changeset
1535 #endif // SHARE_VM_OOPS_METHODDATAOOP_HPP