annotate src/share/vm/services/memoryPool.hpp @ 17524:89152779163c

Merge with jdk8-b132
author Gilles Duboscq <duboscq@ssw.jku.at>
date Wed, 15 Oct 2014 11:59:32 +0200
parents 4ca6dc0799b6
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
17524
89152779163c Merge with jdk8-b132
Gilles Duboscq <duboscq@ssw.jku.at>
parents: 14909
diff changeset
2 * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
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: 0
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 #ifndef SHARE_VM_SERVICES_MEMORYPOOL_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #define SHARE_VM_SERVICES_MEMORYPOOL_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 #include "gc_implementation/shared/mutableSpace.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #include "memory/defNewGeneration.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #include "memory/heap.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 #include "memory/space.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #include "services/memoryUsage.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/concurrentMarkSweep/compactibleFreeListSpace.hpp"
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
36 #endif // INCLUDE_ALL_GCS
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
37
0
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // A memory pool represents the memory area that the VM manages.
a61af66fc99e Initial load
duke
parents:
diff changeset
39 // The Java virtual machine has at least one memory pool
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // and it may create or remove memory pools during execution.
a61af66fc99e Initial load
duke
parents:
diff changeset
41 // A memory pool can belong to the heap or the non-heap memory.
a61af66fc99e Initial load
duke
parents:
diff changeset
42 // A Java virtual machine may also have memory pools belonging to
a61af66fc99e Initial load
duke
parents:
diff changeset
43 // both heap and non-heap memory.
a61af66fc99e Initial load
duke
parents:
diff changeset
44
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // Forward declaration
a61af66fc99e Initial load
duke
parents:
diff changeset
46 class MemoryManager;
a61af66fc99e Initial load
duke
parents:
diff changeset
47 class SensorInfo;
a61af66fc99e Initial load
duke
parents:
diff changeset
48 class Generation;
a61af66fc99e Initial load
duke
parents:
diff changeset
49 class DefNewGeneration;
a61af66fc99e Initial load
duke
parents:
diff changeset
50 class ThresholdSupport;
a61af66fc99e Initial load
duke
parents:
diff changeset
51
6197
d2a62e0f25eb 6995781: Native Memory Tracking (Phase 1)
zgu
parents: 1972
diff changeset
52 class MemoryPool : public CHeapObj<mtInternal> {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
53 friend class MemoryManager;
a61af66fc99e Initial load
duke
parents:
diff changeset
54 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
55 enum PoolType {
a61af66fc99e Initial load
duke
parents:
diff changeset
56 Heap = 1,
a61af66fc99e Initial load
duke
parents:
diff changeset
57 NonHeap = 2
a61af66fc99e Initial load
duke
parents:
diff changeset
58 };
a61af66fc99e Initial load
duke
parents:
diff changeset
59
a61af66fc99e Initial load
duke
parents:
diff changeset
60 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
61 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
62 max_num_managers = 5
a61af66fc99e Initial load
duke
parents:
diff changeset
63 };
a61af66fc99e Initial load
duke
parents:
diff changeset
64
a61af66fc99e Initial load
duke
parents:
diff changeset
65 // We could make some of the following as performance counters
a61af66fc99e Initial load
duke
parents:
diff changeset
66 // for external monitoring.
a61af66fc99e Initial load
duke
parents:
diff changeset
67 const char* _name;
a61af66fc99e Initial load
duke
parents:
diff changeset
68 PoolType _type;
a61af66fc99e Initial load
duke
parents:
diff changeset
69 size_t _initial_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
70 size_t _max_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
71 bool _available_for_allocation; // Default is true
a61af66fc99e Initial load
duke
parents:
diff changeset
72 MemoryManager* _managers[max_num_managers];
a61af66fc99e Initial load
duke
parents:
diff changeset
73 int _num_managers;
a61af66fc99e Initial load
duke
parents:
diff changeset
74 MemoryUsage _peak_usage; // Peak memory usage
a61af66fc99e Initial load
duke
parents:
diff changeset
75 MemoryUsage _after_gc_usage; // After GC memory usage
a61af66fc99e Initial load
duke
parents:
diff changeset
76
a61af66fc99e Initial load
duke
parents:
diff changeset
77 ThresholdSupport* _usage_threshold;
a61af66fc99e Initial load
duke
parents:
diff changeset
78 ThresholdSupport* _gc_usage_threshold;
a61af66fc99e Initial load
duke
parents:
diff changeset
79
a61af66fc99e Initial load
duke
parents:
diff changeset
80 SensorInfo* _usage_sensor;
a61af66fc99e Initial load
duke
parents:
diff changeset
81 SensorInfo* _gc_usage_sensor;
a61af66fc99e Initial load
duke
parents:
diff changeset
82
a61af66fc99e Initial load
duke
parents:
diff changeset
83 volatile instanceOop _memory_pool_obj;
a61af66fc99e Initial load
duke
parents:
diff changeset
84
a61af66fc99e Initial load
duke
parents:
diff changeset
85 void add_manager(MemoryManager* mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
86
a61af66fc99e Initial load
duke
parents:
diff changeset
87 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
88 MemoryPool(const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
89 PoolType type,
a61af66fc99e Initial load
duke
parents:
diff changeset
90 size_t init_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
91 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
92 bool support_usage_threshold,
a61af66fc99e Initial load
duke
parents:
diff changeset
93 bool support_gc_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
94
a61af66fc99e Initial load
duke
parents:
diff changeset
95 const char* name() { return _name; }
a61af66fc99e Initial load
duke
parents:
diff changeset
96 bool is_heap() { return _type == Heap; }
a61af66fc99e Initial load
duke
parents:
diff changeset
97 bool is_non_heap() { return _type == NonHeap; }
a61af66fc99e Initial load
duke
parents:
diff changeset
98 size_t initial_size() const { return _initial_size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
99 int num_memory_managers() const { return _num_managers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
100 // max size could be changed
a61af66fc99e Initial load
duke
parents:
diff changeset
101 virtual size_t max_size() const { return _max_size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
102
a61af66fc99e Initial load
duke
parents:
diff changeset
103 bool is_pool(instanceHandle pool) { return (pool() == _memory_pool_obj); }
a61af66fc99e Initial load
duke
parents:
diff changeset
104
a61af66fc99e Initial load
duke
parents:
diff changeset
105 bool available_for_allocation() { return _available_for_allocation; }
a61af66fc99e Initial load
duke
parents:
diff changeset
106 bool set_available_for_allocation(bool value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
107 bool prev = _available_for_allocation;
a61af66fc99e Initial load
duke
parents:
diff changeset
108 _available_for_allocation = value;
a61af66fc99e Initial load
duke
parents:
diff changeset
109 return prev;
a61af66fc99e Initial load
duke
parents:
diff changeset
110 }
a61af66fc99e Initial load
duke
parents:
diff changeset
111
a61af66fc99e Initial load
duke
parents:
diff changeset
112 MemoryManager* get_memory_manager(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
113 assert(index >= 0 && index < _num_managers, "Invalid index");
a61af66fc99e Initial load
duke
parents:
diff changeset
114 return _managers[index];
a61af66fc99e Initial load
duke
parents:
diff changeset
115 }
a61af66fc99e Initial load
duke
parents:
diff changeset
116
a61af66fc99e Initial load
duke
parents:
diff changeset
117 // Records current memory usage if it's a peak usage
a61af66fc99e Initial load
duke
parents:
diff changeset
118 void record_peak_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
119
a61af66fc99e Initial load
duke
parents:
diff changeset
120 MemoryUsage get_peak_memory_usage() {
a61af66fc99e Initial load
duke
parents:
diff changeset
121 // check current memory usage first and then return peak usage
a61af66fc99e Initial load
duke
parents:
diff changeset
122 record_peak_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
123 return _peak_usage;
a61af66fc99e Initial load
duke
parents:
diff changeset
124 }
a61af66fc99e Initial load
duke
parents:
diff changeset
125 void reset_peak_memory_usage() {
a61af66fc99e Initial load
duke
parents:
diff changeset
126 _peak_usage = get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
127 }
a61af66fc99e Initial load
duke
parents:
diff changeset
128
a61af66fc99e Initial load
duke
parents:
diff changeset
129 ThresholdSupport* usage_threshold() { return _usage_threshold; }
a61af66fc99e Initial load
duke
parents:
diff changeset
130 ThresholdSupport* gc_usage_threshold() { return _gc_usage_threshold; }
a61af66fc99e Initial load
duke
parents:
diff changeset
131
a61af66fc99e Initial load
duke
parents:
diff changeset
132 SensorInfo* usage_sensor() { return _usage_sensor; }
a61af66fc99e Initial load
duke
parents:
diff changeset
133 SensorInfo* gc_usage_sensor() { return _gc_usage_sensor; }
a61af66fc99e Initial load
duke
parents:
diff changeset
134
a61af66fc99e Initial load
duke
parents:
diff changeset
135 void set_usage_sensor_obj(instanceHandle s);
a61af66fc99e Initial load
duke
parents:
diff changeset
136 void set_gc_usage_sensor_obj(instanceHandle s);
a61af66fc99e Initial load
duke
parents:
diff changeset
137 void set_last_collection_usage(MemoryUsage u) { _after_gc_usage = u; }
a61af66fc99e Initial load
duke
parents:
diff changeset
138
a61af66fc99e Initial load
duke
parents:
diff changeset
139 virtual instanceOop get_memory_pool_instance(TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
140 virtual MemoryUsage get_memory_usage() = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
141 virtual size_t used_in_bytes() = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
142 virtual bool is_collected_pool() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
143 virtual MemoryUsage get_last_collection_usage() { return _after_gc_usage; }
a61af66fc99e Initial load
duke
parents:
diff changeset
144
a61af66fc99e Initial load
duke
parents:
diff changeset
145 // GC support
a61af66fc99e Initial load
duke
parents:
diff changeset
146 void oops_do(OopClosure* f);
a61af66fc99e Initial load
duke
parents:
diff changeset
147 };
a61af66fc99e Initial load
duke
parents:
diff changeset
148
a61af66fc99e Initial load
duke
parents:
diff changeset
149 class CollectedMemoryPool : public MemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
150 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
151 CollectedMemoryPool(const char* name, PoolType type, size_t init_size, size_t max_size, bool support_usage_threshold) :
a61af66fc99e Initial load
duke
parents:
diff changeset
152 MemoryPool(name, type, init_size, max_size, support_usage_threshold, true) {};
a61af66fc99e Initial load
duke
parents:
diff changeset
153 bool is_collected_pool() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
154 };
a61af66fc99e Initial load
duke
parents:
diff changeset
155
a61af66fc99e Initial load
duke
parents:
diff changeset
156 class ContiguousSpacePool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
157 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
158 ContiguousSpace* _space;
a61af66fc99e Initial load
duke
parents:
diff changeset
159
a61af66fc99e Initial load
duke
parents:
diff changeset
160 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
161 ContiguousSpacePool(ContiguousSpace* space, const char* name, PoolType type, size_t max_size, bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
162
a61af66fc99e Initial load
duke
parents:
diff changeset
163 ContiguousSpace* space() { return _space; }
a61af66fc99e Initial load
duke
parents:
diff changeset
164 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
165 size_t used_in_bytes() { return space()->used(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
166 };
a61af66fc99e Initial load
duke
parents:
diff changeset
167
a61af66fc99e Initial load
duke
parents:
diff changeset
168 class SurvivorContiguousSpacePool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
169 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
170 DefNewGeneration* _gen;
a61af66fc99e Initial load
duke
parents:
diff changeset
171
a61af66fc99e Initial load
duke
parents:
diff changeset
172 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
173 SurvivorContiguousSpacePool(DefNewGeneration* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
174 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
175 PoolType type,
a61af66fc99e Initial load
duke
parents:
diff changeset
176 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
177 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
178
a61af66fc99e Initial load
duke
parents:
diff changeset
179 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
180
a61af66fc99e Initial load
duke
parents:
diff changeset
181 size_t used_in_bytes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
182 return _gen->from()->used();
a61af66fc99e Initial load
duke
parents:
diff changeset
183 }
a61af66fc99e Initial load
duke
parents:
diff changeset
184 size_t committed_in_bytes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
185 return _gen->from()->capacity();
a61af66fc99e Initial load
duke
parents:
diff changeset
186 }
a61af66fc99e Initial load
duke
parents:
diff changeset
187 };
a61af66fc99e Initial load
duke
parents:
diff changeset
188
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
189 #if INCLUDE_ALL_GCS
0
a61af66fc99e Initial load
duke
parents:
diff changeset
190 class CompactibleFreeListSpacePool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
191 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
192 CompactibleFreeListSpace* _space;
a61af66fc99e Initial load
duke
parents:
diff changeset
193 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
194 CompactibleFreeListSpacePool(CompactibleFreeListSpace* space,
a61af66fc99e Initial load
duke
parents:
diff changeset
195 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
196 PoolType type,
a61af66fc99e Initial load
duke
parents:
diff changeset
197 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
198 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
199
a61af66fc99e Initial load
duke
parents:
diff changeset
200 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
201 size_t used_in_bytes() { return _space->used(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
202 };
8001
db9981fd3124 8005915: Unify SERIALGC and INCLUDE_ALTERNATE_GCS
jprovino
parents: 6725
diff changeset
203 #endif // INCLUDE_ALL_GCS
0
a61af66fc99e Initial load
duke
parents:
diff changeset
204
a61af66fc99e Initial load
duke
parents:
diff changeset
205
a61af66fc99e Initial load
duke
parents:
diff changeset
206 class GenerationPool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
207 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
208 Generation* _gen;
a61af66fc99e Initial load
duke
parents:
diff changeset
209 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
210 GenerationPool(Generation* gen, const char* name, PoolType type, bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
211
a61af66fc99e Initial load
duke
parents:
diff changeset
212 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
213 size_t used_in_bytes() { return _gen->used(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
214 };
a61af66fc99e Initial load
duke
parents:
diff changeset
215
a61af66fc99e Initial load
duke
parents:
diff changeset
216 class CodeHeapPool: public MemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
217 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
218 CodeHeap* _codeHeap;
a61af66fc99e Initial load
duke
parents:
diff changeset
219 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
220 CodeHeapPool(CodeHeap* codeHeap, const char* name, bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
221 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
222 size_t used_in_bytes() { return _codeHeap->allocated_capacity(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
223 };
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
224
11039
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
225 class MetaspacePool : public MemoryPool {
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
226 size_t calculate_max_size() const;
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
227 public:
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
228 MetaspacePool();
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
229 MemoryUsage get_memory_usage();
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
230 size_t used_in_bytes();
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
231 };
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
232
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
233 class CompressedKlassSpacePool : public MemoryPool {
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
234 public:
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
235 CompressedKlassSpacePool();
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
236 MemoryUsage get_memory_usage();
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
237 size_t used_in_bytes();
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
238 };
71963b3f802a 8013590: NPG: Add a memory pool MXBean for Metaspace
ehelin
parents: 8827
diff changeset
239
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
240 #endif // SHARE_VM_SERVICES_MEMORYPOOL_HPP