annotate src/share/vm/services/memoryService.hpp @ 1703:f6f3eef8a521

6581734: CMS Old Gen's collection usage is zero after GC which is incorrect Summary: Management code enabled for use by a concurrent collector. Reviewed-by: mchung, ysr
author kevinw
date Fri, 30 Jul 2010 22:43:50 +0100
parents c18cbe5936b8
children f95d63e2154a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1089
diff changeset
2 * Copyright (c) 2003, 2006, 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: 1089
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1089
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: 1089
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
a61af66fc99e Initial load
duke
parents:
diff changeset
25 // Forward declaration
a61af66fc99e Initial load
duke
parents:
diff changeset
26 class MemoryPool;
a61af66fc99e Initial load
duke
parents:
diff changeset
27 class MemoryManager;
a61af66fc99e Initial load
duke
parents:
diff changeset
28 class GCMemoryManager;
a61af66fc99e Initial load
duke
parents:
diff changeset
29 class CollectedHeap;
a61af66fc99e Initial load
duke
parents:
diff changeset
30 class Generation;
a61af66fc99e Initial load
duke
parents:
diff changeset
31 class DefNewGeneration;
a61af66fc99e Initial load
duke
parents:
diff changeset
32 class PSYoungGen;
a61af66fc99e Initial load
duke
parents:
diff changeset
33 class PSOldGen;
a61af66fc99e Initial load
duke
parents:
diff changeset
34 class PSPermGen;
a61af66fc99e Initial load
duke
parents:
diff changeset
35 class CodeHeap;
a61af66fc99e Initial load
duke
parents:
diff changeset
36 class ContiguousSpace;
a61af66fc99e Initial load
duke
parents:
diff changeset
37 class CompactibleFreeListSpace;
a61af66fc99e Initial load
duke
parents:
diff changeset
38 class PermanentGenerationSpec;
a61af66fc99e Initial load
duke
parents:
diff changeset
39 class GenCollectedHeap;
a61af66fc99e Initial load
duke
parents:
diff changeset
40 class ParallelScavengeHeap;
a61af66fc99e Initial load
duke
parents:
diff changeset
41 class CompactingPermGenGen;
a61af66fc99e Initial load
duke
parents:
diff changeset
42 class CMSPermGenGen;
1089
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
43 class G1CollectedHeap;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
44
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // VM Monitoring and Management Support
a61af66fc99e Initial load
duke
parents:
diff changeset
46
a61af66fc99e Initial load
duke
parents:
diff changeset
47 class MemoryService : public AllStatic {
a61af66fc99e Initial load
duke
parents:
diff changeset
48 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
49 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
50 init_pools_list_size = 10,
a61af66fc99e Initial load
duke
parents:
diff changeset
51 init_managers_list_size = 5
a61af66fc99e Initial load
duke
parents:
diff changeset
52 };
a61af66fc99e Initial load
duke
parents:
diff changeset
53
a61af66fc99e Initial load
duke
parents:
diff changeset
54 // index for minor and major generations
a61af66fc99e Initial load
duke
parents:
diff changeset
55 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
56 minor = 0,
a61af66fc99e Initial load
duke
parents:
diff changeset
57 major = 1,
a61af66fc99e Initial load
duke
parents:
diff changeset
58 n_gens = 2
a61af66fc99e Initial load
duke
parents:
diff changeset
59 };
a61af66fc99e Initial load
duke
parents:
diff changeset
60
a61af66fc99e Initial load
duke
parents:
diff changeset
61 static GrowableArray<MemoryPool*>* _pools_list;
a61af66fc99e Initial load
duke
parents:
diff changeset
62 static GrowableArray<MemoryManager*>* _managers_list;
a61af66fc99e Initial load
duke
parents:
diff changeset
63
a61af66fc99e Initial load
duke
parents:
diff changeset
64 // memory managers for minor and major GC statistics
a61af66fc99e Initial load
duke
parents:
diff changeset
65 static GCMemoryManager* _major_gc_manager;
a61af66fc99e Initial load
duke
parents:
diff changeset
66 static GCMemoryManager* _minor_gc_manager;
a61af66fc99e Initial load
duke
parents:
diff changeset
67
a61af66fc99e Initial load
duke
parents:
diff changeset
68 // Code heap memory pool
a61af66fc99e Initial load
duke
parents:
diff changeset
69 static MemoryPool* _code_heap_pool;
a61af66fc99e Initial load
duke
parents:
diff changeset
70
a61af66fc99e Initial load
duke
parents:
diff changeset
71 static void add_generation_memory_pool(Generation* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
72 MemoryManager* major_mgr,
a61af66fc99e Initial load
duke
parents:
diff changeset
73 MemoryManager* minor_mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
74 static void add_generation_memory_pool(Generation* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
75 MemoryManager* major_mgr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
76 add_generation_memory_pool(gen, major_mgr, NULL);
a61af66fc99e Initial load
duke
parents:
diff changeset
77 }
a61af66fc99e Initial load
duke
parents:
diff changeset
78
a61af66fc99e Initial load
duke
parents:
diff changeset
79 static void add_compact_perm_gen_memory_pool(CompactingPermGenGen* perm_gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
80 MemoryManager* mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
81 static void add_cms_perm_gen_memory_pool(CMSPermGenGen* perm_gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
82 MemoryManager* mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
83
a61af66fc99e Initial load
duke
parents:
diff changeset
84 static void add_psYoung_memory_pool(PSYoungGen* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
85 MemoryManager* major_mgr,
a61af66fc99e Initial load
duke
parents:
diff changeset
86 MemoryManager* minor_mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
87 static void add_psOld_memory_pool(PSOldGen* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
88 MemoryManager* mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
89 static void add_psPerm_memory_pool(PSPermGen* perm,
a61af66fc99e Initial load
duke
parents:
diff changeset
90 MemoryManager* mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
91
1089
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
92 static void add_g1YoungGen_memory_pool(G1CollectedHeap* g1h,
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
93 MemoryManager* major_mgr,
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
94 MemoryManager* minor_mgr);
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
95 static void add_g1OldGen_memory_pool(G1CollectedHeap* g1h,
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
96 MemoryManager* mgr);
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
97 static void add_g1PermGen_memory_pool(G1CollectedHeap* g1h,
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
98 MemoryManager* mgr);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
99
a61af66fc99e Initial load
duke
parents:
diff changeset
100 static MemoryPool* add_space(ContiguousSpace* space,
a61af66fc99e Initial load
duke
parents:
diff changeset
101 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
102 bool is_heap,
a61af66fc99e Initial load
duke
parents:
diff changeset
103 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
104 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
105 static MemoryPool* add_survivor_spaces(DefNewGeneration* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
106 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
107 bool is_heap,
a61af66fc99e Initial load
duke
parents:
diff changeset
108 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
109 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
110 static MemoryPool* add_gen(Generation* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
111 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
112 bool is_heap,
a61af66fc99e Initial load
duke
parents:
diff changeset
113 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
114 static MemoryPool* add_cms_space(CompactibleFreeListSpace* space,
a61af66fc99e Initial load
duke
parents:
diff changeset
115 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
116 bool is_heap,
a61af66fc99e Initial load
duke
parents:
diff changeset
117 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
118 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
119
a61af66fc99e Initial load
duke
parents:
diff changeset
120 static void add_gen_collected_heap_info(GenCollectedHeap* heap);
a61af66fc99e Initial load
duke
parents:
diff changeset
121 static void add_parallel_scavenge_heap_info(ParallelScavengeHeap* heap);
1089
db0d5eba9d20 6815790: G1: Missing MemoryPoolMXBeans with -XX:+UseG1GC
tonyp
parents: 0
diff changeset
122 static void add_g1_heap_info(G1CollectedHeap* g1h);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
123
a61af66fc99e Initial load
duke
parents:
diff changeset
124 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
125 static void set_universe_heap(CollectedHeap* heap);
a61af66fc99e Initial load
duke
parents:
diff changeset
126 static void add_code_heap_memory_pool(CodeHeap* heap);
a61af66fc99e Initial load
duke
parents:
diff changeset
127
a61af66fc99e Initial load
duke
parents:
diff changeset
128 static MemoryPool* get_memory_pool(instanceHandle pool);
a61af66fc99e Initial load
duke
parents:
diff changeset
129 static MemoryManager* get_memory_manager(instanceHandle mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
130
a61af66fc99e Initial load
duke
parents:
diff changeset
131 static const int num_memory_pools() {
a61af66fc99e Initial load
duke
parents:
diff changeset
132 return _pools_list->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
133 }
a61af66fc99e Initial load
duke
parents:
diff changeset
134 static const int num_memory_managers() {
a61af66fc99e Initial load
duke
parents:
diff changeset
135 return _managers_list->length();
a61af66fc99e Initial load
duke
parents:
diff changeset
136 }
a61af66fc99e Initial load
duke
parents:
diff changeset
137
a61af66fc99e Initial load
duke
parents:
diff changeset
138 static MemoryPool* get_memory_pool(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
139 return _pools_list->at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
140 }
a61af66fc99e Initial load
duke
parents:
diff changeset
141
a61af66fc99e Initial load
duke
parents:
diff changeset
142 static MemoryManager* get_memory_manager(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
143 return _managers_list->at(index);
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 void track_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
147 static void track_code_cache_memory_usage() {
a61af66fc99e Initial load
duke
parents:
diff changeset
148 track_memory_pool_usage(_code_heap_pool);
a61af66fc99e Initial load
duke
parents:
diff changeset
149 }
a61af66fc99e Initial load
duke
parents:
diff changeset
150 static void track_memory_pool_usage(MemoryPool* pool);
a61af66fc99e Initial load
duke
parents:
diff changeset
151
1703
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
152 static void gc_begin(bool fullGC, bool recordGCBeginTime,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
153 bool recordAccumulatedGCTime,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
154 bool recordPreGCUsage, bool recordPeakUsage);
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
155 static void gc_end(bool fullGC, bool recordPostGCUsage,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
156 bool recordAccumulatedGCTime,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
157 bool recordGCEndTime, bool countCollection);
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
158
0
a61af66fc99e Initial load
duke
parents:
diff changeset
159
a61af66fc99e Initial load
duke
parents:
diff changeset
160 static void oops_do(OopClosure* f);
a61af66fc99e Initial load
duke
parents:
diff changeset
161
a61af66fc99e Initial load
duke
parents:
diff changeset
162 static bool get_verbose() { return PrintGC; }
a61af66fc99e Initial load
duke
parents:
diff changeset
163 static bool set_verbose(bool verbose);
a61af66fc99e Initial load
duke
parents:
diff changeset
164
a61af66fc99e Initial load
duke
parents:
diff changeset
165 // Create an instance of java/lang/management/MemoryUsage
a61af66fc99e Initial load
duke
parents:
diff changeset
166 static Handle create_MemoryUsage_obj(MemoryUsage usage, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
167 };
a61af66fc99e Initial load
duke
parents:
diff changeset
168
a61af66fc99e Initial load
duke
parents:
diff changeset
169 class TraceMemoryManagerStats : public StackObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
170 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
171 bool _fullGC;
1703
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
172 bool _recordGCBeginTime;
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
173 bool _recordPreGCUsage;
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
174 bool _recordPeakUsage;
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
175 bool _recordPostGCUsage;
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
176 bool _recordAccumulatedGCTime;
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
177 bool _recordGCEndTime;
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
178 bool _countCollection;
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
179
0
a61af66fc99e Initial load
duke
parents:
diff changeset
180 public:
1703
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
181 TraceMemoryManagerStats() {}
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
182 TraceMemoryManagerStats(bool fullGC,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
183 bool recordGCBeginTime = true,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
184 bool recordPreGCUsage = true,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
185 bool recordPeakUsage = true,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
186 bool recordPostGCUsage = true,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
187 bool recordAccumulatedGCTime = true,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
188 bool recordGCEndTime = true,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
189 bool countCollection = true);
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
190
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
191 void initialize(bool fullGC,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
192 bool recordGCBeginTime,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
193 bool recordPreGCUsage,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
194 bool recordPeakUsage,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
195 bool recordPostGCUsage,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
196 bool recordAccumulatedGCTime,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
197 bool recordGCEndTime,
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
198 bool countCollection);
f6f3eef8a521 6581734: CMS Old Gen's collection usage is zero after GC which is incorrect
kevinw
parents: 1552
diff changeset
199
0
a61af66fc99e Initial load
duke
parents:
diff changeset
200 TraceMemoryManagerStats(Generation::Name kind);
a61af66fc99e Initial load
duke
parents:
diff changeset
201 ~TraceMemoryManagerStats();
a61af66fc99e Initial load
duke
parents:
diff changeset
202 };