Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openjdk-multiarch-jdk8u
Path: blob/aarch64-shenandoah-jdk8u272-b10/hotspot/src/share/vm/ci/ciMethodData.cpp
32285 views
1
/*
2
* Copyright (c) 2001, 2014, Oracle and/or its affiliates. All rights reserved.
3
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4
*
5
* This code is free software; you can redistribute it and/or modify it
6
* under the terms of the GNU General Public License version 2 only, as
7
* published by the Free Software Foundation.
8
*
9
* This code is distributed in the hope that it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12
* version 2 for more details (a copy is included in the LICENSE file that
13
* accompanied this code).
14
*
15
* You should have received a copy of the GNU General Public License version
16
* 2 along with this work; if not, write to the Free Software Foundation,
17
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18
*
19
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20
* or visit www.oracle.com if you need additional information or have any
21
* questions.
22
*
23
*/
24
25
#include "precompiled.hpp"
26
#include "ci/ciMetadata.hpp"
27
#include "ci/ciMethodData.hpp"
28
#include "ci/ciReplay.hpp"
29
#include "ci/ciUtilities.hpp"
30
#include "memory/allocation.inline.hpp"
31
#include "memory/resourceArea.hpp"
32
#include "runtime/deoptimization.hpp"
33
#include "utilities/copy.hpp"
34
35
// ciMethodData
36
37
// ------------------------------------------------------------------
38
// ciMethodData::ciMethodData
39
//
40
ciMethodData::ciMethodData(MethodData* md) : ciMetadata(md) {
41
assert(md != NULL, "no null method data");
42
Copy::zero_to_words((HeapWord*) &_orig, sizeof(_orig) / sizeof(HeapWord));
43
_data = NULL;
44
_data_size = 0;
45
_extra_data_size = 0;
46
_current_mileage = 0;
47
_invocation_counter = 0;
48
_backedge_counter = 0;
49
_state = empty_state;
50
_saw_free_extra_data = false;
51
// Set an initial hint. Don't use set_hint_di() because
52
// first_di() may be out of bounds if data_size is 0.
53
_hint_di = first_di();
54
// Initialize the escape information (to "don't know.");
55
_eflags = _arg_local = _arg_stack = _arg_returned = 0;
56
_parameters = NULL;
57
}
58
59
// ------------------------------------------------------------------
60
// ciMethodData::ciMethodData
61
//
62
// No MethodData*.
63
ciMethodData::ciMethodData() : ciMetadata(NULL) {
64
Copy::zero_to_words((HeapWord*) &_orig, sizeof(_orig) / sizeof(HeapWord));
65
_data = NULL;
66
_data_size = 0;
67
_extra_data_size = 0;
68
_current_mileage = 0;
69
_invocation_counter = 0;
70
_backedge_counter = 0;
71
_state = empty_state;
72
_saw_free_extra_data = false;
73
// Set an initial hint. Don't use set_hint_di() because
74
// first_di() may be out of bounds if data_size is 0.
75
_hint_di = first_di();
76
// Initialize the escape information (to "don't know.");
77
_eflags = _arg_local = _arg_stack = _arg_returned = 0;
78
_parameters = NULL;
79
}
80
81
void ciMethodData::load_extra_data() {
82
MethodData* mdo = get_MethodData();
83
84
// speculative trap entries also hold a pointer to a Method so need to be translated
85
DataLayout* dp_src = mdo->extra_data_base();
86
DataLayout* end_src = mdo->extra_data_limit();
87
DataLayout* dp_dst = extra_data_base();
88
for (;; dp_src = MethodData::next_extra(dp_src), dp_dst = MethodData::next_extra(dp_dst)) {
89
assert(dp_src < end_src, "moved past end of extra data");
90
// New traps in the MDO can be added as we translate the copy so
91
// look at the entries in the copy.
92
switch(dp_dst->tag()) {
93
case DataLayout::speculative_trap_data_tag: {
94
ciSpeculativeTrapData* data_dst = new ciSpeculativeTrapData(dp_dst);
95
SpeculativeTrapData* data_src = new SpeculativeTrapData(dp_src);
96
data_dst->translate_from(data_src);
97
break;
98
}
99
case DataLayout::bit_data_tag:
100
break;
101
case DataLayout::no_tag:
102
case DataLayout::arg_info_data_tag:
103
// An empty slot or ArgInfoData entry marks the end of the trap data
104
return;
105
default:
106
fatal(err_msg("bad tag = %d", dp_dst->tag()));
107
}
108
}
109
}
110
111
void ciMethodData::load_data() {
112
MethodData* mdo = get_MethodData();
113
if (mdo == NULL) {
114
return;
115
}
116
117
// To do: don't copy the data if it is not "ripe" -- require a minimum #
118
// of invocations.
119
120
// Snapshot the data -- actually, take an approximate snapshot of
121
// the data. Any concurrently executing threads may be changing the
122
// data as we copy it.
123
Copy::disjoint_words_atomic((HeapWord*) mdo,
124
(HeapWord*) &_orig,
125
sizeof(_orig) / HeapWordSize);
126
Arena* arena = CURRENT_ENV->arena();
127
_data_size = mdo->data_size();
128
_extra_data_size = mdo->extra_data_size();
129
int total_size = _data_size + _extra_data_size;
130
_data = (intptr_t *) arena->Amalloc(total_size);
131
Copy::disjoint_words_atomic((HeapWord*) mdo->data_base(),
132
(HeapWord*) _data,
133
total_size / HeapWordSize);
134
135
// Traverse the profile data, translating any oops into their
136
// ci equivalents.
137
ResourceMark rm;
138
ciProfileData* ci_data = first_data();
139
ProfileData* data = mdo->first_data();
140
while (is_valid(ci_data)) {
141
ci_data->translate_from(data);
142
ci_data = next_data(ci_data);
143
data = mdo->next_data(data);
144
}
145
if (mdo->parameters_type_data() != NULL) {
146
_parameters = data_layout_at(mdo->parameters_type_data_di());
147
ciParametersTypeData* parameters = new ciParametersTypeData(_parameters);
148
parameters->translate_from(mdo->parameters_type_data());
149
}
150
151
load_extra_data();
152
153
// Note: Extra data are all BitData, and do not need translation.
154
_current_mileage = MethodData::mileage_of(mdo->method());
155
_invocation_counter = mdo->invocation_count();
156
_backedge_counter = mdo->backedge_count();
157
_state = mdo->is_mature()? mature_state: immature_state;
158
159
_eflags = mdo->eflags();
160
_arg_local = mdo->arg_local();
161
_arg_stack = mdo->arg_stack();
162
_arg_returned = mdo->arg_returned();
163
#ifndef PRODUCT
164
if (ReplayCompiles) {
165
ciReplay::initialize(this);
166
}
167
#endif
168
}
169
170
void ciReceiverTypeData::translate_receiver_data_from(const ProfileData* data) {
171
for (uint row = 0; row < row_limit(); row++) {
172
Klass* k = data->as_ReceiverTypeData()->receiver(row);
173
if (k != NULL) {
174
ciKlass* klass = CURRENT_ENV->get_klass(k);
175
CURRENT_ENV->ensure_metadata_alive(klass);
176
set_receiver(row, klass);
177
}
178
}
179
}
180
181
182
void ciTypeStackSlotEntries::translate_type_data_from(const TypeStackSlotEntries* entries) {
183
for (int i = 0; i < _number_of_entries; i++) {
184
intptr_t k = entries->type(i);
185
TypeStackSlotEntries::set_type(i, translate_klass(k));
186
}
187
}
188
189
void ciReturnTypeEntry::translate_type_data_from(const ReturnTypeEntry* ret) {
190
intptr_t k = ret->type();
191
set_type(translate_klass(k));
192
}
193
194
void ciSpeculativeTrapData::translate_from(const ProfileData* data) {
195
Method* m = data->as_SpeculativeTrapData()->method();
196
ciMethod* ci_m = CURRENT_ENV->get_method(m);
197
CURRENT_ENV->ensure_metadata_alive(ci_m);
198
set_method(ci_m);
199
}
200
201
// Get the data at an arbitrary (sort of) data index.
202
ciProfileData* ciMethodData::data_at(int data_index) {
203
if (out_of_bounds(data_index)) {
204
return NULL;
205
}
206
DataLayout* data_layout = data_layout_at(data_index);
207
208
switch (data_layout->tag()) {
209
case DataLayout::no_tag:
210
default:
211
ShouldNotReachHere();
212
return NULL;
213
case DataLayout::bit_data_tag:
214
return new ciBitData(data_layout);
215
case DataLayout::counter_data_tag:
216
return new ciCounterData(data_layout);
217
case DataLayout::jump_data_tag:
218
return new ciJumpData(data_layout);
219
case DataLayout::receiver_type_data_tag:
220
return new ciReceiverTypeData(data_layout);
221
case DataLayout::virtual_call_data_tag:
222
return new ciVirtualCallData(data_layout);
223
case DataLayout::ret_data_tag:
224
return new ciRetData(data_layout);
225
case DataLayout::branch_data_tag:
226
return new ciBranchData(data_layout);
227
case DataLayout::multi_branch_data_tag:
228
return new ciMultiBranchData(data_layout);
229
case DataLayout::arg_info_data_tag:
230
return new ciArgInfoData(data_layout);
231
case DataLayout::call_type_data_tag:
232
return new ciCallTypeData(data_layout);
233
case DataLayout::virtual_call_type_data_tag:
234
return new ciVirtualCallTypeData(data_layout);
235
case DataLayout::parameters_type_data_tag:
236
return new ciParametersTypeData(data_layout);
237
};
238
}
239
240
// Iteration over data.
241
ciProfileData* ciMethodData::next_data(ciProfileData* current) {
242
int current_index = dp_to_di(current->dp());
243
int next_index = current_index + current->size_in_bytes();
244
ciProfileData* next = data_at(next_index);
245
return next;
246
}
247
248
ciProfileData* ciMethodData::bci_to_extra_data(int bci, ciMethod* m, bool& two_free_slots) {
249
// bci_to_extra_data(bci) ...
250
DataLayout* dp = data_layout_at(data_size());
251
DataLayout* end = data_layout_at(data_size() + extra_data_size());
252
two_free_slots = false;
253
for (;dp < end; dp = MethodData::next_extra(dp)) {
254
switch(dp->tag()) {
255
case DataLayout::no_tag:
256
_saw_free_extra_data = true; // observed an empty slot (common case)
257
two_free_slots = (MethodData::next_extra(dp)->tag() == DataLayout::no_tag);
258
return NULL;
259
case DataLayout::arg_info_data_tag:
260
return NULL; // ArgInfoData is at the end of extra data section.
261
case DataLayout::bit_data_tag:
262
if (m == NULL && dp->bci() == bci) {
263
return new ciBitData(dp);
264
}
265
break;
266
case DataLayout::speculative_trap_data_tag: {
267
ciSpeculativeTrapData* data = new ciSpeculativeTrapData(dp);
268
// data->method() might be null if the MDO is snapshotted
269
// concurrently with a trap
270
if (m != NULL && data->method() == m && dp->bci() == bci) {
271
return data;
272
}
273
break;
274
}
275
default:
276
fatal(err_msg("bad tag = %d", dp->tag()));
277
}
278
}
279
return NULL;
280
}
281
282
// Translate a bci to its corresponding data, or NULL.
283
ciProfileData* ciMethodData::bci_to_data(int bci, ciMethod* m) {
284
// If m is not NULL we look for a SpeculativeTrapData entry
285
if (m == NULL) {
286
ciProfileData* data = data_before(bci);
287
for ( ; is_valid(data); data = next_data(data)) {
288
if (data->bci() == bci) {
289
set_hint_di(dp_to_di(data->dp()));
290
return data;
291
} else if (data->bci() > bci) {
292
break;
293
}
294
}
295
}
296
bool two_free_slots = false;
297
ciProfileData* result = bci_to_extra_data(bci, m, two_free_slots);
298
if (result != NULL) {
299
return result;
300
}
301
if (m != NULL && !two_free_slots) {
302
// We were looking for a SpeculativeTrapData entry we didn't
303
// find. Room is not available for more SpeculativeTrapData
304
// entries, look in the non SpeculativeTrapData entries.
305
return bci_to_data(bci, NULL);
306
}
307
return NULL;
308
}
309
310
// Conservatively decode the trap_state of a ciProfileData.
311
int ciMethodData::has_trap_at(ciProfileData* data, int reason) {
312
typedef Deoptimization::DeoptReason DR_t;
313
int per_bc_reason
314
= Deoptimization::reason_recorded_per_bytecode_if_any((DR_t) reason);
315
if (trap_count(reason) == 0) {
316
// Impossible for this trap to have occurred, regardless of trap_state.
317
// Note: This happens if the MDO is empty.
318
return 0;
319
} else if (per_bc_reason == Deoptimization::Reason_none) {
320
// We cannot conclude anything; a trap happened somewhere, maybe here.
321
return -1;
322
} else if (data == NULL) {
323
// No profile here, not even an extra_data record allocated on the fly.
324
// If there are empty extra_data records, and there had been a trap,
325
// there would have been a non-null data pointer. If there are no
326
// free extra_data records, we must return a conservative -1.
327
if (_saw_free_extra_data)
328
return 0; // Q.E.D.
329
else
330
return -1; // bail with a conservative answer
331
} else {
332
return Deoptimization::trap_state_has_reason(data->trap_state(), per_bc_reason);
333
}
334
}
335
336
int ciMethodData::trap_recompiled_at(ciProfileData* data) {
337
if (data == NULL) {
338
return (_saw_free_extra_data? 0: -1); // (see previous method)
339
} else {
340
return Deoptimization::trap_state_is_recompiled(data->trap_state())? 1: 0;
341
}
342
}
343
344
void ciMethodData::clear_escape_info() {
345
VM_ENTRY_MARK;
346
MethodData* mdo = get_MethodData();
347
if (mdo != NULL) {
348
mdo->clear_escape_info();
349
ArgInfoData *aid = arg_info();
350
int arg_count = (aid == NULL) ? 0 : aid->number_of_args();
351
for (int i = 0; i < arg_count; i++) {
352
set_arg_modified(i, 0);
353
}
354
}
355
_eflags = _arg_local = _arg_stack = _arg_returned = 0;
356
}
357
358
// copy our escape info to the MethodData* if it exists
359
void ciMethodData::update_escape_info() {
360
VM_ENTRY_MARK;
361
MethodData* mdo = get_MethodData();
362
if ( mdo != NULL) {
363
mdo->set_eflags(_eflags);
364
mdo->set_arg_local(_arg_local);
365
mdo->set_arg_stack(_arg_stack);
366
mdo->set_arg_returned(_arg_returned);
367
int arg_count = mdo->method()->size_of_parameters();
368
for (int i = 0; i < arg_count; i++) {
369
mdo->set_arg_modified(i, arg_modified(i));
370
}
371
}
372
}
373
374
void ciMethodData::set_compilation_stats(short loops, short blocks) {
375
VM_ENTRY_MARK;
376
MethodData* mdo = get_MethodData();
377
if (mdo != NULL) {
378
mdo->set_num_loops(loops);
379
mdo->set_num_blocks(blocks);
380
}
381
}
382
383
void ciMethodData::set_would_profile(bool p) {
384
VM_ENTRY_MARK;
385
MethodData* mdo = get_MethodData();
386
if (mdo != NULL) {
387
mdo->set_would_profile(p);
388
}
389
}
390
391
void ciMethodData::set_argument_type(int bci, int i, ciKlass* k) {
392
VM_ENTRY_MARK;
393
MethodData* mdo = get_MethodData();
394
if (mdo != NULL) {
395
ProfileData* data = mdo->bci_to_data(bci);
396
if (data != NULL) {
397
if (data->is_CallTypeData()) {
398
data->as_CallTypeData()->set_argument_type(i, k->get_Klass());
399
} else {
400
assert(data->is_VirtualCallTypeData(), "no arguments!");
401
data->as_VirtualCallTypeData()->set_argument_type(i, k->get_Klass());
402
}
403
}
404
}
405
}
406
407
void ciMethodData::set_parameter_type(int i, ciKlass* k) {
408
VM_ENTRY_MARK;
409
MethodData* mdo = get_MethodData();
410
if (mdo != NULL) {
411
mdo->parameters_type_data()->set_type(i, k->get_Klass());
412
}
413
}
414
415
void ciMethodData::set_return_type(int bci, ciKlass* k) {
416
VM_ENTRY_MARK;
417
MethodData* mdo = get_MethodData();
418
if (mdo != NULL) {
419
ProfileData* data = mdo->bci_to_data(bci);
420
if (data != NULL) {
421
if (data->is_CallTypeData()) {
422
data->as_CallTypeData()->set_return_type(k->get_Klass());
423
} else {
424
assert(data->is_VirtualCallTypeData(), "no arguments!");
425
data->as_VirtualCallTypeData()->set_return_type(k->get_Klass());
426
}
427
}
428
}
429
}
430
431
bool ciMethodData::has_escape_info() {
432
return eflag_set(MethodData::estimated);
433
}
434
435
void ciMethodData::set_eflag(MethodData::EscapeFlag f) {
436
set_bits(_eflags, f);
437
}
438
439
void ciMethodData::clear_eflag(MethodData::EscapeFlag f) {
440
clear_bits(_eflags, f);
441
}
442
443
bool ciMethodData::eflag_set(MethodData::EscapeFlag f) const {
444
return mask_bits(_eflags, f) != 0;
445
}
446
447
void ciMethodData::set_arg_local(int i) {
448
set_nth_bit(_arg_local, i);
449
}
450
451
void ciMethodData::set_arg_stack(int i) {
452
set_nth_bit(_arg_stack, i);
453
}
454
455
void ciMethodData::set_arg_returned(int i) {
456
set_nth_bit(_arg_returned, i);
457
}
458
459
void ciMethodData::set_arg_modified(int arg, uint val) {
460
ArgInfoData *aid = arg_info();
461
if (aid == NULL)
462
return;
463
assert(arg >= 0 && arg < aid->number_of_args(), "valid argument number");
464
aid->set_arg_modified(arg, val);
465
}
466
467
bool ciMethodData::is_arg_local(int i) const {
468
return is_set_nth_bit(_arg_local, i);
469
}
470
471
bool ciMethodData::is_arg_stack(int i) const {
472
return is_set_nth_bit(_arg_stack, i);
473
}
474
475
bool ciMethodData::is_arg_returned(int i) const {
476
return is_set_nth_bit(_arg_returned, i);
477
}
478
479
uint ciMethodData::arg_modified(int arg) const {
480
ArgInfoData *aid = arg_info();
481
if (aid == NULL)
482
return 0;
483
assert(arg >= 0 && arg < aid->number_of_args(), "valid argument number");
484
return aid->arg_modified(arg);
485
}
486
487
ByteSize ciMethodData::offset_of_slot(ciProfileData* data, ByteSize slot_offset_in_data) {
488
// Get offset within MethodData* of the data array
489
ByteSize data_offset = MethodData::data_offset();
490
491
// Get cell offset of the ProfileData within data array
492
int cell_offset = dp_to_di(data->dp());
493
494
// Add in counter_offset, the # of bytes into the ProfileData of counter or flag
495
int offset = in_bytes(data_offset) + cell_offset + in_bytes(slot_offset_in_data);
496
497
return in_ByteSize(offset);
498
}
499
500
ciArgInfoData *ciMethodData::arg_info() const {
501
// Should be last, have to skip all traps.
502
DataLayout* dp = data_layout_at(data_size());
503
DataLayout* end = data_layout_at(data_size() + extra_data_size());
504
for (; dp < end; dp = MethodData::next_extra(dp)) {
505
if (dp->tag() == DataLayout::arg_info_data_tag)
506
return new ciArgInfoData(dp);
507
}
508
return NULL;
509
}
510
511
512
// Implementation of the print method.
513
void ciMethodData::print_impl(outputStream* st) {
514
ciMetadata::print_impl(st);
515
}
516
517
void ciMethodData::dump_replay_data(outputStream* out) {
518
ResourceMark rm;
519
MethodData* mdo = get_MethodData();
520
Method* method = mdo->method();
521
Klass* holder = method->method_holder();
522
out->print("ciMethodData %s %s %s %d %d",
523
holder->name()->as_quoted_ascii(),
524
method->name()->as_quoted_ascii(),
525
method->signature()->as_quoted_ascii(),
526
_state,
527
current_mileage());
528
529
// dump the contents of the MDO header as raw data
530
unsigned char* orig = (unsigned char*)&_orig;
531
int length = sizeof(_orig);
532
out->print(" orig %d", length);
533
for (int i = 0; i < length; i++) {
534
out->print(" %d", orig[i]);
535
}
536
537
// dump the MDO data as raw data
538
int elements = data_size() / sizeof(intptr_t);
539
out->print(" data %d", elements);
540
for (int i = 0; i < elements; i++) {
541
// We could use INTPTR_FORMAT here but that's a zero justified
542
// which makes comparing it with the SA version of this output
543
// harder.
544
#ifdef _LP64
545
out->print(" 0x%" FORMAT64_MODIFIER "x", data()[i]);
546
#else
547
out->print(" 0x%x", data()[i]);
548
#endif
549
}
550
551
// The MDO contained oop references as ciObjects, so scan for those
552
// and emit pairs of offset and klass name so that they can be
553
// reconstructed at runtime. The first round counts the number of
554
// oop references and the second actually emits them.
555
int count = 0;
556
for (int round = 0; round < 2; round++) {
557
if (round == 1) out->print(" oops %d", count);
558
ProfileData* pdata = first_data();
559
for ( ; is_valid(pdata); pdata = next_data(pdata)) {
560
if (pdata->is_ReceiverTypeData()) {
561
ciReceiverTypeData* vdata = (ciReceiverTypeData*)pdata;
562
for (uint i = 0; i < vdata->row_limit(); i++) {
563
ciKlass* k = vdata->receiver(i);
564
if (k != NULL) {
565
if (round == 0) {
566
count++;
567
} else {
568
out->print(" %d %s", (int)(dp_to_di(vdata->dp() + in_bytes(vdata->receiver_offset(i))) / sizeof(intptr_t)), k->name()->as_quoted_ascii());
569
}
570
}
571
}
572
} else if (pdata->is_VirtualCallData()) {
573
ciVirtualCallData* vdata = (ciVirtualCallData*)pdata;
574
for (uint i = 0; i < vdata->row_limit(); i++) {
575
ciKlass* k = vdata->receiver(i);
576
if (k != NULL) {
577
if (round == 0) {
578
count++;
579
} else {
580
out->print(" %d %s", (int)(dp_to_di(vdata->dp() + in_bytes(vdata->receiver_offset(i))) / sizeof(intptr_t)), k->name()->as_quoted_ascii());
581
}
582
}
583
}
584
}
585
}
586
}
587
out->cr();
588
}
589
590
#ifndef PRODUCT
591
void ciMethodData::print() {
592
print_data_on(tty);
593
}
594
595
void ciMethodData::print_data_on(outputStream* st) {
596
ResourceMark rm;
597
ciProfileData* data;
598
for (data = first_data(); is_valid(data); data = next_data(data)) {
599
st->print("%d", dp_to_di(data->dp()));
600
st->fill_to(6);
601
data->print_data_on(st);
602
}
603
st->print_cr("--- Extra data:");
604
DataLayout* dp = data_layout_at(data_size());
605
DataLayout* end = data_layout_at(data_size() + extra_data_size());
606
for (;; dp = MethodData::next_extra(dp)) {
607
assert(dp < end, "moved past end of extra data");
608
switch (dp->tag()) {
609
case DataLayout::no_tag:
610
continue;
611
case DataLayout::bit_data_tag:
612
data = new BitData(dp);
613
break;
614
case DataLayout::arg_info_data_tag:
615
data = new ciArgInfoData(dp);
616
dp = end; // ArgInfoData is at the end of extra data section.
617
break;
618
default:
619
fatal(err_msg("unexpected tag %d", dp->tag()));
620
}
621
st->print("%d", dp_to_di(data->dp()));
622
st->fill_to(6);
623
data->print_data_on(st);
624
if (dp >= end) return;
625
}
626
}
627
628
void ciTypeEntries::print_ciklass(outputStream* st, intptr_t k) {
629
if (TypeEntries::is_type_none(k)) {
630
st->print("none");
631
} else if (TypeEntries::is_type_unknown(k)) {
632
st->print("unknown");
633
} else {
634
valid_ciklass(k)->print_name_on(st);
635
}
636
if (TypeEntries::was_null_seen(k)) {
637
st->print(" (null seen)");
638
}
639
}
640
641
void ciTypeStackSlotEntries::print_data_on(outputStream* st) const {
642
for (int i = 0; i < _number_of_entries; i++) {
643
_pd->tab(st);
644
st->print("%d: stack (%u) ", i, stack_slot(i));
645
print_ciklass(st, type(i));
646
st->cr();
647
}
648
}
649
650
void ciReturnTypeEntry::print_data_on(outputStream* st) const {
651
_pd->tab(st);
652
st->print("ret ");
653
print_ciklass(st, type());
654
st->cr();
655
}
656
657
void ciCallTypeData::print_data_on(outputStream* st, const char* extra) const {
658
print_shared(st, "ciCallTypeData", extra);
659
if (has_arguments()) {
660
tab(st, true);
661
st->print("argument types");
662
args()->print_data_on(st);
663
}
664
if (has_return()) {
665
tab(st, true);
666
st->print("return type");
667
ret()->print_data_on(st);
668
}
669
}
670
671
void ciReceiverTypeData::print_receiver_data_on(outputStream* st) const {
672
uint row;
673
int entries = 0;
674
for (row = 0; row < row_limit(); row++) {
675
if (receiver(row) != NULL) entries++;
676
}
677
st->print_cr("count(%u) entries(%u)", count(), entries);
678
for (row = 0; row < row_limit(); row++) {
679
if (receiver(row) != NULL) {
680
tab(st);
681
receiver(row)->print_name_on(st);
682
st->print_cr("(%u)", receiver_count(row));
683
}
684
}
685
}
686
687
void ciReceiverTypeData::print_data_on(outputStream* st, const char* extra) const {
688
print_shared(st, "ciReceiverTypeData", extra);
689
print_receiver_data_on(st);
690
}
691
692
void ciVirtualCallData::print_data_on(outputStream* st, const char* extra) const {
693
print_shared(st, "ciVirtualCallData", extra);
694
rtd_super()->print_receiver_data_on(st);
695
}
696
697
void ciVirtualCallTypeData::print_data_on(outputStream* st, const char* extra) const {
698
print_shared(st, "ciVirtualCallTypeData", extra);
699
rtd_super()->print_receiver_data_on(st);
700
if (has_arguments()) {
701
tab(st, true);
702
st->print("argument types");
703
args()->print_data_on(st);
704
}
705
if (has_return()) {
706
tab(st, true);
707
st->print("return type");
708
ret()->print_data_on(st);
709
}
710
}
711
712
void ciParametersTypeData::print_data_on(outputStream* st, const char* extra) const {
713
st->print_cr("ciParametersTypeData");
714
parameters()->print_data_on(st);
715
}
716
717
void ciSpeculativeTrapData::print_data_on(outputStream* st, const char* extra) const {
718
st->print_cr("ciSpeculativeTrapData");
719
tab(st);
720
method()->print_short_name(st);
721
st->cr();
722
}
723
#endif
724
725