annotate src/share/vm/memory/heapInspection.cpp @ 20543:e7d0505c8a30

8059758: Footprint regressions with JDK-8038423 Summary: Changes in JDK-8038423 always initialize (zero out) virtual memory used for auxiliary data structures. This causes a footprint regression for G1 in startup benchmarks. This is because they do not touch that memory at all, so the operating system does not actually commit these pages. The fix is to, if the initialization value of the data structures matches the default value of just committed memory (=0), do not do anything. Reviewed-by: jwilhelm, brutisso
author tschatzl
date Fri, 10 Oct 2014 15:51:58 +0200
parents 833b0f92429a
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
2 * Copyright (c) 2002, 2014, 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: 1489
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1489
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: 1489
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: 1552
diff changeset
25 #include "precompiled.hpp"
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
26 #include "classfile/classLoaderData.hpp"
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #include "gc_interface/collectedHeap.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "memory/genCollectedHeap.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "memory/heapInspection.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "memory/resourceArea.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "runtime/os.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "utilities/globalDefinitions.hpp"
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
33 #include "utilities/macros.hpp"
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
34 #if INCLUDE_ALL_GCS
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
35 #include "gc_implementation/parallelScavenge/parallelScavengeHeap.hpp"
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
36 #endif // INCLUDE_ALL_GCS
0
a61af66fc99e Initial load
duke
parents:
diff changeset
37
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
38 PRAGMA_FORMAT_MUTE_WARNINGS_FOR_GCC
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
39
0
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // HeapInspection
a61af66fc99e Initial load
duke
parents:
diff changeset
41
a61af66fc99e Initial load
duke
parents:
diff changeset
42 int KlassInfoEntry::compare(KlassInfoEntry* e1, KlassInfoEntry* e2) {
a61af66fc99e Initial load
duke
parents:
diff changeset
43 if(e1->_instance_words > e2->_instance_words) {
a61af66fc99e Initial load
duke
parents:
diff changeset
44 return -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
45 } else if(e1->_instance_words < e2->_instance_words) {
a61af66fc99e Initial load
duke
parents:
diff changeset
46 return 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
47 }
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
48 // Sort alphabetically, note 'Z' < '[' < 'a', but it's better to group
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
49 // the array classes before all the instance classes.
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
50 ResourceMark rm;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
51 const char* name1 = e1->klass()->external_name();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
52 const char* name2 = e2->klass()->external_name();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
53 bool d1 = (name1[0] == '[');
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
54 bool d2 = (name2[0] == '[');
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
55 if (d1 && !d2) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
56 return -1;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
57 } else if (d2 && !d1) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
58 return 1;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
59 } else {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
60 return strcmp(name1, name2);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
61 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
62 }
a61af66fc99e Initial load
duke
parents:
diff changeset
63
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
64 const char* KlassInfoEntry::name() const {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
65 const char* name;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
66 if (_klass->name() != NULL) {
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
67 name = _klass->external_name();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
68 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
69 if (_klass == Universe::boolArrayKlassObj()) name = "<boolArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
70 if (_klass == Universe::charArrayKlassObj()) name = "<charArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
71 if (_klass == Universe::singleArrayKlassObj()) name = "<singleArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
72 if (_klass == Universe::doubleArrayKlassObj()) name = "<doubleArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
73 if (_klass == Universe::byteArrayKlassObj()) name = "<byteArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
74 if (_klass == Universe::shortArrayKlassObj()) name = "<shortArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
75 if (_klass == Universe::intArrayKlassObj()) name = "<intArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
76 if (_klass == Universe::longArrayKlassObj()) name = "<longArrayKlass>"; else
a61af66fc99e Initial load
duke
parents:
diff changeset
77 name = "<no name>";
a61af66fc99e Initial load
duke
parents:
diff changeset
78 }
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
79 return name;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
80 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
81
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
82 void KlassInfoEntry::print_on(outputStream* st) const {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
83 ResourceMark rm;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
84
0
a61af66fc99e Initial load
duke
parents:
diff changeset
85 // simplify the formatting (ILP32 vs LP64) - always cast the numbers to 64-bit
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
86 st->print_cr(INT64_FORMAT_W(13) " " UINT64_FORMAT_W(13) " %s",
0
a61af66fc99e Initial load
duke
parents:
diff changeset
87 (jlong) _instance_count,
a61af66fc99e Initial load
duke
parents:
diff changeset
88 (julong) _instance_words * HeapWordSize,
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
89 name());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
90 }
a61af66fc99e Initial load
duke
parents:
diff changeset
91
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
92 KlassInfoEntry* KlassInfoBucket::lookup(Klass* const k) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
93 KlassInfoEntry* elt = _list;
a61af66fc99e Initial load
duke
parents:
diff changeset
94 while (elt != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
95 if (elt->is_equal(k)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
96 return elt;
a61af66fc99e Initial load
duke
parents:
diff changeset
97 }
a61af66fc99e Initial load
duke
parents:
diff changeset
98 elt = elt->next();
a61af66fc99e Initial load
duke
parents:
diff changeset
99 }
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
100 elt = new (std::nothrow) KlassInfoEntry(k, list());
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
101 // We may be out of space to allocate the new entry.
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
102 if (elt != NULL) {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
103 set_list(elt);
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
104 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
105 return elt;
a61af66fc99e Initial load
duke
parents:
diff changeset
106 }
a61af66fc99e Initial load
duke
parents:
diff changeset
107
a61af66fc99e Initial load
duke
parents:
diff changeset
108 void KlassInfoBucket::iterate(KlassInfoClosure* cic) {
a61af66fc99e Initial load
duke
parents:
diff changeset
109 KlassInfoEntry* elt = _list;
a61af66fc99e Initial load
duke
parents:
diff changeset
110 while (elt != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
111 cic->do_cinfo(elt);
a61af66fc99e Initial load
duke
parents:
diff changeset
112 elt = elt->next();
a61af66fc99e Initial load
duke
parents:
diff changeset
113 }
a61af66fc99e Initial load
duke
parents:
diff changeset
114 }
a61af66fc99e Initial load
duke
parents:
diff changeset
115
a61af66fc99e Initial load
duke
parents:
diff changeset
116 void KlassInfoBucket::empty() {
a61af66fc99e Initial load
duke
parents:
diff changeset
117 KlassInfoEntry* elt = _list;
a61af66fc99e Initial load
duke
parents:
diff changeset
118 _list = NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
119 while (elt != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
120 KlassInfoEntry* next = elt->next();
a61af66fc99e Initial load
duke
parents:
diff changeset
121 delete elt;
a61af66fc99e Initial load
duke
parents:
diff changeset
122 elt = next;
a61af66fc99e Initial load
duke
parents:
diff changeset
123 }
a61af66fc99e Initial load
duke
parents:
diff changeset
124 }
a61af66fc99e Initial load
duke
parents:
diff changeset
125
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
126 void KlassInfoTable::AllClassesFinder::do_klass(Klass* k) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
127 // This has the SIDE EFFECT of creating a KlassInfoEntry
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
128 // for <k>, if one doesn't exist yet.
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
129 _table->lookup(k);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
130 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
131
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
132 KlassInfoTable::KlassInfoTable(bool need_class_stats) {
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
133 _size_of_instances_in_words = 0;
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
134 _size = 0;
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
135 _ref = (HeapWord*) Universe::boolArrayKlassObj();
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
136 _buckets =
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
137 (KlassInfoBucket*) AllocateHeap(sizeof(KlassInfoBucket) * _num_buckets,
20360
833b0f92429a 8046598: Scalable Native memory tracking development
zgu
parents: 17937
diff changeset
138 mtInternal, CURRENT_PC, AllocFailStrategy::RETURN_NULL);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
139 if (_buckets != NULL) {
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
140 _size = _num_buckets;
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
141 for (int index = 0; index < _size; index++) {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
142 _buckets[index].initialize();
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
143 }
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
144 if (need_class_stats) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
145 AllClassesFinder finder(this);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
146 ClassLoaderDataGraph::classes_do(&finder);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
147 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
148 }
a61af66fc99e Initial load
duke
parents:
diff changeset
149 }
a61af66fc99e Initial load
duke
parents:
diff changeset
150
a61af66fc99e Initial load
duke
parents:
diff changeset
151 KlassInfoTable::~KlassInfoTable() {
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
152 if (_buckets != NULL) {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
153 for (int index = 0; index < _size; index++) {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
154 _buckets[index].empty();
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
155 }
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 2426
diff changeset
156 FREE_C_HEAP_ARRAY(KlassInfoBucket, _buckets, mtInternal);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
157 _size = 0;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
158 }
a61af66fc99e Initial load
duke
parents:
diff changeset
159 }
a61af66fc99e Initial load
duke
parents:
diff changeset
160
10265
92ef81e2f571 8003557: NPG: Klass* const k should be const Klass* k.
minqi
parents: 8003
diff changeset
161 uint KlassInfoTable::hash(const Klass* p) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
162 return (uint)(((uintptr_t)p - (uintptr_t)_ref) >> 2);
a61af66fc99e Initial load
duke
parents:
diff changeset
163 }
a61af66fc99e Initial load
duke
parents:
diff changeset
164
10265
92ef81e2f571 8003557: NPG: Klass* const k should be const Klass* k.
minqi
parents: 8003
diff changeset
165 KlassInfoEntry* KlassInfoTable::lookup(Klass* k) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
166 uint idx = hash(k) % _size;
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
167 assert(_buckets != NULL, "Allocation failure should have been caught");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
168 KlassInfoEntry* e = _buckets[idx].lookup(k);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
169 // Lookup may fail if this is a new klass for which we
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
170 // could not allocate space for an new entry.
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
171 assert(e == NULL || k == e->klass(), "must be equal");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
172 return e;
a61af66fc99e Initial load
duke
parents:
diff changeset
173 }
a61af66fc99e Initial load
duke
parents:
diff changeset
174
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
175 // Return false if the entry could not be recorded on account
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
176 // of running out of space required to create a new entry.
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
177 bool KlassInfoTable::record_instance(const oop obj) {
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
178 Klass* k = obj->klass();
0
a61af66fc99e Initial load
duke
parents:
diff changeset
179 KlassInfoEntry* elt = lookup(k);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
180 // elt may be NULL if it's a new klass for which we
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
181 // could not allocate space for a new entry in the hashtable.
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
182 if (elt != NULL) {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
183 elt->set_count(elt->count() + 1);
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
184 elt->set_words(elt->words() + obj->size());
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
185 _size_of_instances_in_words += obj->size();
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
186 return true;
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
187 } else {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
188 return false;
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
189 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
190 }
a61af66fc99e Initial load
duke
parents:
diff changeset
191
a61af66fc99e Initial load
duke
parents:
diff changeset
192 void KlassInfoTable::iterate(KlassInfoClosure* cic) {
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
193 assert(_size == 0 || _buckets != NULL, "Allocation failure should have been caught");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
194 for (int index = 0; index < _size; index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
195 _buckets[index].iterate(cic);
a61af66fc99e Initial load
duke
parents:
diff changeset
196 }
a61af66fc99e Initial load
duke
parents:
diff changeset
197 }
a61af66fc99e Initial load
duke
parents:
diff changeset
198
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
199 size_t KlassInfoTable::size_of_instances_in_words() const {
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
200 return _size_of_instances_in_words;
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
201 }
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
202
0
a61af66fc99e Initial load
duke
parents:
diff changeset
203 int KlassInfoHisto::sort_helper(KlassInfoEntry** e1, KlassInfoEntry** e2) {
a61af66fc99e Initial load
duke
parents:
diff changeset
204 return (*e1)->compare(*e1,*e2);
a61af66fc99e Initial load
duke
parents:
diff changeset
205 }
a61af66fc99e Initial load
duke
parents:
diff changeset
206
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
207 KlassInfoHisto::KlassInfoHisto(KlassInfoTable* cit, const char* title) :
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
208 _cit(cit),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
209 _title(title) {
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
210 _elements = new (ResourceObj::C_HEAP, mtInternal) GrowableArray<KlassInfoEntry*>(_histo_initial_size, true);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
211 }
a61af66fc99e Initial load
duke
parents:
diff changeset
212
a61af66fc99e Initial load
duke
parents:
diff changeset
213 KlassInfoHisto::~KlassInfoHisto() {
a61af66fc99e Initial load
duke
parents:
diff changeset
214 delete _elements;
a61af66fc99e Initial load
duke
parents:
diff changeset
215 }
a61af66fc99e Initial load
duke
parents:
diff changeset
216
a61af66fc99e Initial load
duke
parents:
diff changeset
217 void KlassInfoHisto::add(KlassInfoEntry* cie) {
a61af66fc99e Initial load
duke
parents:
diff changeset
218 elements()->append(cie);
a61af66fc99e Initial load
duke
parents:
diff changeset
219 }
a61af66fc99e Initial load
duke
parents:
diff changeset
220
a61af66fc99e Initial load
duke
parents:
diff changeset
221 void KlassInfoHisto::sort() {
a61af66fc99e Initial load
duke
parents:
diff changeset
222 elements()->sort(KlassInfoHisto::sort_helper);
a61af66fc99e Initial load
duke
parents:
diff changeset
223 }
a61af66fc99e Initial load
duke
parents:
diff changeset
224
a61af66fc99e Initial load
duke
parents:
diff changeset
225 void KlassInfoHisto::print_elements(outputStream* st) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
226 // simplify the formatting (ILP32 vs LP64) - store the sum in 64-bit
a61af66fc99e Initial load
duke
parents:
diff changeset
227 jlong total = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
228 julong totalw = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
229 for(int i=0; i < elements()->length(); i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
230 st->print("%4d: ", i+1);
a61af66fc99e Initial load
duke
parents:
diff changeset
231 elements()->at(i)->print_on(st);
a61af66fc99e Initial load
duke
parents:
diff changeset
232 total += elements()->at(i)->count();
a61af66fc99e Initial load
duke
parents:
diff changeset
233 totalw += elements()->at(i)->words();
a61af66fc99e Initial load
duke
parents:
diff changeset
234 }
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
235 st->print_cr("Total " INT64_FORMAT_W(13) " " UINT64_FORMAT_W(13),
0
a61af66fc99e Initial load
duke
parents:
diff changeset
236 total, totalw * HeapWordSize);
a61af66fc99e Initial load
duke
parents:
diff changeset
237 }
a61af66fc99e Initial load
duke
parents:
diff changeset
238
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
239 #define MAKE_COL_NAME(field, name, help) #name,
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
240 #define MAKE_COL_HELP(field, name, help) help,
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
241
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
242 static const char *name_table[] = {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
243 HEAP_INSPECTION_COLUMNS_DO(MAKE_COL_NAME)
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
244 };
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
245
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
246 static const char *help_table[] = {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
247 HEAP_INSPECTION_COLUMNS_DO(MAKE_COL_HELP)
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
248 };
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
249
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
250 bool KlassInfoHisto::is_selected(const char *col_name) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
251 if (_selected_columns == NULL) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
252 return true;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
253 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
254 if (strcmp(_selected_columns, col_name) == 0) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
255 return true;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
256 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
257
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
258 const char *start = strstr(_selected_columns, col_name);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
259 if (start == NULL) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
260 return false;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
261 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
262
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
263 // The following must be true, because _selected_columns != col_name
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
264 if (start > _selected_columns && start[-1] != ',') {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
265 return false;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
266 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
267 char x = start[strlen(col_name)];
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
268 if (x != ',' && x != '\0') {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
269 return false;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
270 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
271
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
272 return true;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
273 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
274
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
275 PRAGMA_FORMAT_NONLITERAL_IGNORED_EXTERNAL
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
276 void KlassInfoHisto::print_title(outputStream* st, bool csv_format,
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
277 bool selected[], int width_table[],
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
278 const char *name_table[]) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
279 if (csv_format) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
280 st->print("Index,Super");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
281 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
282 if (selected[c]) {st->print(",%s", name_table[c]);}
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
283 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
284 st->print(",ClassName");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
285 } else {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
286 st->print("Index Super");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
287 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
288 PRAGMA_DIAG_PUSH
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
289 PRAGMA_FORMAT_NONLITERAL_IGNORED_INTERNAL
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
290 if (selected[c]) {st->print(str_fmt(width_table[c]), name_table[c]);}
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
291 PRAGMA_DIAG_POP
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
292 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
293 st->print(" ClassName");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
294 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
295
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
296 if (is_selected("ClassLoader")) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
297 st->print(",ClassLoader");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
298 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
299 st->cr();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
300 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
301
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
302 void KlassInfoHisto::print_class_stats(outputStream* st,
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
303 bool csv_format, const char *columns) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
304 ResourceMark rm;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
305 KlassSizeStats sz, sz_sum;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
306 int i;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
307 julong *col_table = (julong*)(&sz);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
308 julong *colsum_table = (julong*)(&sz_sum);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
309 int width_table[KlassSizeStats::_num_columns];
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
310 bool selected[KlassSizeStats::_num_columns];
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
311
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
312 _selected_columns = columns;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
313
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
314 memset(&sz_sum, 0, sizeof(sz_sum));
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
315 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
316 selected[c] = is_selected(name_table[c]);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
317 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
318
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
319 for(i=0; i < elements()->length(); i++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
320 elements()->at(i)->set_index(i+1);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
321 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
322
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
323 for (int pass=1; pass<=2; pass++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
324 if (pass == 2) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
325 print_title(st, csv_format, selected, width_table, name_table);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
326 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
327 for(i=0; i < elements()->length(); i++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
328 KlassInfoEntry* e = (KlassInfoEntry*)elements()->at(i);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
329 const Klass* k = e->klass();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
330
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
331 memset(&sz, 0, sizeof(sz));
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
332 sz._inst_count = e->count();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
333 sz._inst_bytes = HeapWordSize * e->words();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
334 k->collect_statistics(&sz);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
335 sz._total_bytes = sz._ro_bytes + sz._rw_bytes;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
336
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
337 if (pass == 1) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
338 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
339 colsum_table[c] += col_table[c];
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
340 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
341 } else {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
342 int super_index = -1;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
343 if (k->oop_is_instance()) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
344 Klass* super = ((InstanceKlass*)k)->java_super();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
345 if (super) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
346 KlassInfoEntry* super_e = _cit->lookup(super);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
347 if (super_e) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
348 super_index = super_e->index();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
349 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
350 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
351 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
352
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
353 if (csv_format) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
354 st->print("%d,%d", e->index(), super_index);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
355 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
356 if (selected[c]) {st->print("," JULONG_FORMAT, col_table[c]);}
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
357 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
358 st->print(",%s",e->name());
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
359 } else {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
360 st->print("%5d %5d", e->index(), super_index);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
361 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
362 if (selected[c]) {print_julong(st, width_table[c], col_table[c]);}
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
363 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
364 st->print(" %s", e->name());
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
365 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
366 if (is_selected("ClassLoader")) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
367 ClassLoaderData* loader_data = k->class_loader_data();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
368 st->print(",");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
369 loader_data->print_value_on(st);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
370 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
371 st->cr();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
372 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
373 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
374
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
375 if (pass == 1) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
376 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
377 width_table[c] = col_width(colsum_table[c], name_table[c]);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
378 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
379 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
380 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
381
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
382 sz_sum._inst_size = 0;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
383
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
384 if (csv_format) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
385 st->print(",");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
386 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
387 if (selected[c]) {st->print("," JULONG_FORMAT, colsum_table[c]);}
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
388 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
389 } else {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
390 st->print(" ");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
391 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
392 if (selected[c]) {print_julong(st, width_table[c], colsum_table[c]);}
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
393 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
394 st->print(" Total");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
395 if (sz_sum._total_bytes > 0) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
396 st->cr();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
397 st->print(" ");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
398 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
399 if (selected[c]) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
400 switch (c) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
401 case KlassSizeStats::_index_inst_size:
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
402 case KlassSizeStats::_index_inst_count:
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
403 case KlassSizeStats::_index_method_count:
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
404 PRAGMA_DIAG_PUSH
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
405 PRAGMA_FORMAT_NONLITERAL_IGNORED_INTERNAL
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
406 st->print(str_fmt(width_table[c]), "-");
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
407 PRAGMA_DIAG_POP
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
408 break;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
409 default:
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
410 {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
411 double perc = (double)(100) * (double)(colsum_table[c]) / (double)sz_sum._total_bytes;
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
412 PRAGMA_DIAG_PUSH
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
413 PRAGMA_FORMAT_NONLITERAL_IGNORED_INTERNAL
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
414 st->print(perc_fmt(width_table[c]), perc);
17937
78bbf4d43a14 8037816: Fix for 8036122 breaks build with Xcode5/clang
drchase
parents: 11034
diff changeset
415 PRAGMA_DIAG_POP
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
416 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
417 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
418 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
419 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
420 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
421 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
422 st->cr();
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
423
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
424 if (!csv_format) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
425 print_title(st, csv_format, selected, width_table, name_table);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
426 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
427 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
428
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
429 julong KlassInfoHisto::annotations_bytes(Array<AnnotationArray*>* p) const {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
430 julong bytes = 0;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
431 if (p != NULL) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
432 for (int i = 0; i < p->length(); i++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
433 bytes += count_bytes_array(p->at(i));
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
434 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
435 bytes += count_bytes_array(p);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
436 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
437 return bytes;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
438 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
439
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
440 void KlassInfoHisto::print_histo_on(outputStream* st, bool print_stats,
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
441 bool csv_format, const char *columns) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
442 if (print_stats) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
443 print_class_stats(st, csv_format, columns);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
444 } else {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
445 st->print_cr("%s",title());
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
446 print_elements(st);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
447 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
448 }
a61af66fc99e Initial load
duke
parents:
diff changeset
449
a61af66fc99e Initial load
duke
parents:
diff changeset
450 class HistoClosure : public KlassInfoClosure {
a61af66fc99e Initial load
duke
parents:
diff changeset
451 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
452 KlassInfoHisto* _cih;
a61af66fc99e Initial load
duke
parents:
diff changeset
453 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
454 HistoClosure(KlassInfoHisto* cih) : _cih(cih) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
455
a61af66fc99e Initial load
duke
parents:
diff changeset
456 void do_cinfo(KlassInfoEntry* cie) {
a61af66fc99e Initial load
duke
parents:
diff changeset
457 _cih->add(cie);
a61af66fc99e Initial load
duke
parents:
diff changeset
458 }
a61af66fc99e Initial load
duke
parents:
diff changeset
459 };
a61af66fc99e Initial load
duke
parents:
diff changeset
460
a61af66fc99e Initial load
duke
parents:
diff changeset
461 class RecordInstanceClosure : public ObjectClosure {
a61af66fc99e Initial load
duke
parents:
diff changeset
462 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
463 KlassInfoTable* _cit;
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
464 size_t _missed_count;
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
465 BoolObjectClosure* _filter;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
466 public:
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
467 RecordInstanceClosure(KlassInfoTable* cit, BoolObjectClosure* filter) :
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
468 _cit(cit), _missed_count(0), _filter(filter) {}
0
a61af66fc99e Initial load
duke
parents:
diff changeset
469
a61af66fc99e Initial load
duke
parents:
diff changeset
470 void do_object(oop obj) {
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
471 if (should_visit(obj)) {
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
472 if (!_cit->record_instance(obj)) {
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
473 _missed_count++;
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
474 }
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
475 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
476 }
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
477
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
478 size_t missed_count() { return _missed_count; }
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
479
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
480 private:
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
481 bool should_visit(oop obj) {
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
482 return _filter == NULL || _filter->do_object_b(obj);
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
483 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
484 };
a61af66fc99e Initial load
duke
parents:
diff changeset
485
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
486 size_t HeapInspection::populate_table(KlassInfoTable* cit, BoolObjectClosure *filter) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
487 ResourceMark rm;
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
488
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
489 RecordInstanceClosure ric(cit, filter);
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
490 Universe::heap()->object_iterate(&ric);
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
491 return ric.missed_count();
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
492 }
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
493
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
494 void HeapInspection::heap_inspection(outputStream* st) {
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
495 ResourceMark rm;
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
496
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
497 if (_print_help) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
498 for (int c=0; c<KlassSizeStats::_num_columns; c++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
499 st->print("%s:\n\t", name_table[c]);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
500 const int max_col = 60;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
501 int col = 0;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
502 for (const char *p = help_table[c]; *p; p++,col++) {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
503 if (col >= max_col && *p == ' ') {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
504 st->print("\n\t");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
505 col = 0;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
506 } else {
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
507 st->print("%c", *p);
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
508 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
509 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
510 st->print_cr(".\n");
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
511 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
512 return;
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
513 }
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
514
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
515 KlassInfoTable cit(_print_class_stats);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
516 if (!cit.allocation_failed()) {
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
517 size_t missed_count = populate_table(&cit);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
518 if (missed_count != 0) {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
519 st->print_cr("WARNING: Ran out of C-heap; undercounted " SIZE_FORMAT
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
520 " total instances in data below",
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
521 missed_count);
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
522 }
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
523
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
524 // Sort and print klass instance info
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
525 const char *title = "\n"
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
526 " num #instances #bytes class name\n"
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
527 "----------------------------------------------";
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
528 KlassInfoHisto histo(&cit, title);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
529 HistoClosure hc(&histo);
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
530
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
531 cit.iterate(&hc);
10405
f2110083203d 8005849: JEP 167: Event-Based JVM Tracing
sla
parents: 10265
diff changeset
532
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
533 histo.sort();
7956
16fb9f942703 6479360: PrintClassHistogram improvements
acorn
parents: 6725
diff changeset
534 histo.print_histo_on(st, _print_class_stats, _csv_format, _columns);
11
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
535 } else {
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
536 st->print_cr("WARNING: Ran out of C-heap; histogram not generated");
3c1dbcaaab1d 6621728: Heap inspection should not crash in the face of C-heap exhaustion
ysr
parents: 0
diff changeset
537 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
538 st->flush();
a61af66fc99e Initial load
duke
parents:
diff changeset
539 }
a61af66fc99e Initial load
duke
parents:
diff changeset
540
a61af66fc99e Initial load
duke
parents:
diff changeset
541 class FindInstanceClosure : public ObjectClosure {
a61af66fc99e Initial load
duke
parents:
diff changeset
542 private:
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
543 Klass* _klass;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
544 GrowableArray<oop>* _result;
a61af66fc99e Initial load
duke
parents:
diff changeset
545
a61af66fc99e Initial load
duke
parents:
diff changeset
546 public:
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
547 FindInstanceClosure(Klass* k, GrowableArray<oop>* result) : _klass(k), _result(result) {};
0
a61af66fc99e Initial load
duke
parents:
diff changeset
548
a61af66fc99e Initial load
duke
parents:
diff changeset
549 void do_object(oop obj) {
a61af66fc99e Initial load
duke
parents:
diff changeset
550 if (obj->is_a(_klass)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
551 _result->append(obj);
a61af66fc99e Initial load
duke
parents:
diff changeset
552 }
a61af66fc99e Initial load
duke
parents:
diff changeset
553 }
a61af66fc99e Initial load
duke
parents:
diff changeset
554 };
a61af66fc99e Initial load
duke
parents:
diff changeset
555
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
556 void HeapInspection::find_instances_at_safepoint(Klass* k, GrowableArray<oop>* result) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
557 assert(SafepointSynchronize::is_at_safepoint(), "all threads are stopped");
1489
cff162798819 6888953: some calls to function-like macros are missing semicolons
jcoomes
parents: 628
diff changeset
558 assert(Heap_lock->is_locked(), "should have the Heap_lock");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
559
a61af66fc99e Initial load
duke
parents:
diff changeset
560 // Ensure that the heap is parsable
a61af66fc99e Initial load
duke
parents:
diff changeset
561 Universe::heap()->ensure_parsability(false); // no need to retire TALBs
a61af66fc99e Initial load
duke
parents:
diff changeset
562
a61af66fc99e Initial load
duke
parents:
diff changeset
563 // Iterate over objects in the heap
a61af66fc99e Initial load
duke
parents:
diff changeset
564 FindInstanceClosure fic(k, result);
517
e9be0e04635a 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 356
diff changeset
565 // If this operation encounters a bad object when using CMS,
6725
da91efe96a93 6964458: Reimplement class meta-data storage to use native memory
coleenp
parents: 6197
diff changeset
566 // consider using safe_object_iterate() which avoids metadata
517
e9be0e04635a 6689653: JMapPerm fails with UseConcMarkSweepIncGC and compressed oops off
jmasa
parents: 356
diff changeset
567 // objects that may contain bad references.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
568 Universe::heap()->object_iterate(&fic);
a61af66fc99e Initial load
duke
parents:
diff changeset
569 }