annotate src/share/vm/services/memoryPool.hpp @ 452:00b023ae2d78

6722113: CMS: Incorrect overflow handling during precleaning of Reference lists Summary: When we encounter marking stack overflow during precleaning of Reference lists, we were using the overflow list mechanism, which can cause problems on account of mutating the mark word of the header because of conflicts with mutator accesses and updates of that field. Instead we should use the usual mechanism for overflow handling in concurrent phases, namely dirtying of the card on which the overflowed object lies. Since precleaning effectively does a form of discovered list processing, albeit with discovery enabled, we needed to adjust some code to be correct in the face of interleaved processing and discovery. Reviewed-by: apetrusenko, jcoomes
author ysr
date Thu, 20 Nov 2008 12:27:41 -0800
parents a61af66fc99e
children c18cbe5936b8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
2 * Copyright 2003-2004 Sun Microsystems, Inc. All Rights Reserved.
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 *
a61af66fc99e Initial load
duke
parents:
diff changeset
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
a61af66fc99e Initial load
duke
parents:
diff changeset
20 * CA 95054 USA or visit www.sun.com if you need additional information or
a61af66fc99e Initial load
duke
parents:
diff changeset
21 * have any questions.
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 // A memory pool represents the memory area that the VM manages.
a61af66fc99e Initial load
duke
parents:
diff changeset
26 // The Java virtual machine has at least one memory pool
a61af66fc99e Initial load
duke
parents:
diff changeset
27 // and it may create or remove memory pools during execution.
a61af66fc99e Initial load
duke
parents:
diff changeset
28 // A memory pool can belong to the heap or the non-heap memory.
a61af66fc99e Initial load
duke
parents:
diff changeset
29 // A Java virtual machine may also have memory pools belonging to
a61af66fc99e Initial load
duke
parents:
diff changeset
30 // both heap and non-heap memory.
a61af66fc99e Initial load
duke
parents:
diff changeset
31
a61af66fc99e Initial load
duke
parents:
diff changeset
32 // Forward declaration
a61af66fc99e Initial load
duke
parents:
diff changeset
33 class MemoryManager;
a61af66fc99e Initial load
duke
parents:
diff changeset
34 class SensorInfo;
a61af66fc99e Initial load
duke
parents:
diff changeset
35 class Generation;
a61af66fc99e Initial load
duke
parents:
diff changeset
36 class DefNewGeneration;
a61af66fc99e Initial load
duke
parents:
diff changeset
37 class PSPermGen;
a61af66fc99e Initial load
duke
parents:
diff changeset
38 class PermGen;
a61af66fc99e Initial load
duke
parents:
diff changeset
39 class ThresholdSupport;
a61af66fc99e Initial load
duke
parents:
diff changeset
40
a61af66fc99e Initial load
duke
parents:
diff changeset
41 class MemoryPool : public CHeapObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
42 friend class MemoryManager;
a61af66fc99e Initial load
duke
parents:
diff changeset
43 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
44 enum PoolType {
a61af66fc99e Initial load
duke
parents:
diff changeset
45 Heap = 1,
a61af66fc99e Initial load
duke
parents:
diff changeset
46 NonHeap = 2
a61af66fc99e Initial load
duke
parents:
diff changeset
47 };
a61af66fc99e Initial load
duke
parents:
diff changeset
48
a61af66fc99e Initial load
duke
parents:
diff changeset
49 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
50 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
51 max_num_managers = 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 // We could make some of the following as performance counters
a61af66fc99e Initial load
duke
parents:
diff changeset
55 // for external monitoring.
a61af66fc99e Initial load
duke
parents:
diff changeset
56 const char* _name;
a61af66fc99e Initial load
duke
parents:
diff changeset
57 PoolType _type;
a61af66fc99e Initial load
duke
parents:
diff changeset
58 size_t _initial_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
59 size_t _max_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
60 bool _available_for_allocation; // Default is true
a61af66fc99e Initial load
duke
parents:
diff changeset
61 MemoryManager* _managers[max_num_managers];
a61af66fc99e Initial load
duke
parents:
diff changeset
62 int _num_managers;
a61af66fc99e Initial load
duke
parents:
diff changeset
63 MemoryUsage _peak_usage; // Peak memory usage
a61af66fc99e Initial load
duke
parents:
diff changeset
64 MemoryUsage _after_gc_usage; // After GC memory usage
a61af66fc99e Initial load
duke
parents:
diff changeset
65
a61af66fc99e Initial load
duke
parents:
diff changeset
66 ThresholdSupport* _usage_threshold;
a61af66fc99e Initial load
duke
parents:
diff changeset
67 ThresholdSupport* _gc_usage_threshold;
a61af66fc99e Initial load
duke
parents:
diff changeset
68
a61af66fc99e Initial load
duke
parents:
diff changeset
69 SensorInfo* _usage_sensor;
a61af66fc99e Initial load
duke
parents:
diff changeset
70 SensorInfo* _gc_usage_sensor;
a61af66fc99e Initial load
duke
parents:
diff changeset
71
a61af66fc99e Initial load
duke
parents:
diff changeset
72 volatile instanceOop _memory_pool_obj;
a61af66fc99e Initial load
duke
parents:
diff changeset
73
a61af66fc99e Initial load
duke
parents:
diff changeset
74 void add_manager(MemoryManager* mgr);
a61af66fc99e Initial load
duke
parents:
diff changeset
75
a61af66fc99e Initial load
duke
parents:
diff changeset
76 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
77 MemoryPool(const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
78 PoolType type,
a61af66fc99e Initial load
duke
parents:
diff changeset
79 size_t init_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
80 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
81 bool support_usage_threshold,
a61af66fc99e Initial load
duke
parents:
diff changeset
82 bool support_gc_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
83
a61af66fc99e Initial load
duke
parents:
diff changeset
84 const char* name() { return _name; }
a61af66fc99e Initial load
duke
parents:
diff changeset
85 bool is_heap() { return _type == Heap; }
a61af66fc99e Initial load
duke
parents:
diff changeset
86 bool is_non_heap() { return _type == NonHeap; }
a61af66fc99e Initial load
duke
parents:
diff changeset
87 size_t initial_size() const { return _initial_size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
88 int num_memory_managers() const { return _num_managers; }
a61af66fc99e Initial load
duke
parents:
diff changeset
89 // max size could be changed
a61af66fc99e Initial load
duke
parents:
diff changeset
90 virtual size_t max_size() const { return _max_size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
91
a61af66fc99e Initial load
duke
parents:
diff changeset
92 bool is_pool(instanceHandle pool) { return (pool() == _memory_pool_obj); }
a61af66fc99e Initial load
duke
parents:
diff changeset
93
a61af66fc99e Initial load
duke
parents:
diff changeset
94 bool available_for_allocation() { return _available_for_allocation; }
a61af66fc99e Initial load
duke
parents:
diff changeset
95 bool set_available_for_allocation(bool value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
96 bool prev = _available_for_allocation;
a61af66fc99e Initial load
duke
parents:
diff changeset
97 _available_for_allocation = value;
a61af66fc99e Initial load
duke
parents:
diff changeset
98 return prev;
a61af66fc99e Initial load
duke
parents:
diff changeset
99 }
a61af66fc99e Initial load
duke
parents:
diff changeset
100
a61af66fc99e Initial load
duke
parents:
diff changeset
101 MemoryManager* get_memory_manager(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
102 assert(index >= 0 && index < _num_managers, "Invalid index");
a61af66fc99e Initial load
duke
parents:
diff changeset
103 return _managers[index];
a61af66fc99e Initial load
duke
parents:
diff changeset
104 }
a61af66fc99e Initial load
duke
parents:
diff changeset
105
a61af66fc99e Initial load
duke
parents:
diff changeset
106 // Records current memory usage if it's a peak usage
a61af66fc99e Initial load
duke
parents:
diff changeset
107 void record_peak_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
108
a61af66fc99e Initial load
duke
parents:
diff changeset
109 MemoryUsage get_peak_memory_usage() {
a61af66fc99e Initial load
duke
parents:
diff changeset
110 // check current memory usage first and then return peak usage
a61af66fc99e Initial load
duke
parents:
diff changeset
111 record_peak_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
112 return _peak_usage;
a61af66fc99e Initial load
duke
parents:
diff changeset
113 }
a61af66fc99e Initial load
duke
parents:
diff changeset
114 void reset_peak_memory_usage() {
a61af66fc99e Initial load
duke
parents:
diff changeset
115 _peak_usage = get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
116 }
a61af66fc99e Initial load
duke
parents:
diff changeset
117
a61af66fc99e Initial load
duke
parents:
diff changeset
118 ThresholdSupport* usage_threshold() { return _usage_threshold; }
a61af66fc99e Initial load
duke
parents:
diff changeset
119 ThresholdSupport* gc_usage_threshold() { return _gc_usage_threshold; }
a61af66fc99e Initial load
duke
parents:
diff changeset
120
a61af66fc99e Initial load
duke
parents:
diff changeset
121 SensorInfo* usage_sensor() { return _usage_sensor; }
a61af66fc99e Initial load
duke
parents:
diff changeset
122 SensorInfo* gc_usage_sensor() { return _gc_usage_sensor; }
a61af66fc99e Initial load
duke
parents:
diff changeset
123
a61af66fc99e Initial load
duke
parents:
diff changeset
124 void set_usage_sensor_obj(instanceHandle s);
a61af66fc99e Initial load
duke
parents:
diff changeset
125 void set_gc_usage_sensor_obj(instanceHandle s);
a61af66fc99e Initial load
duke
parents:
diff changeset
126 void set_last_collection_usage(MemoryUsage u) { _after_gc_usage = u; }
a61af66fc99e Initial load
duke
parents:
diff changeset
127
a61af66fc99e Initial load
duke
parents:
diff changeset
128 virtual instanceOop get_memory_pool_instance(TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
129 virtual MemoryUsage get_memory_usage() = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
130 virtual size_t used_in_bytes() = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
131 virtual bool is_collected_pool() { return false; }
a61af66fc99e Initial load
duke
parents:
diff changeset
132 virtual MemoryUsage get_last_collection_usage() { return _after_gc_usage; }
a61af66fc99e Initial load
duke
parents:
diff changeset
133
a61af66fc99e Initial load
duke
parents:
diff changeset
134 // GC support
a61af66fc99e Initial load
duke
parents:
diff changeset
135 void oops_do(OopClosure* f);
a61af66fc99e Initial load
duke
parents:
diff changeset
136 };
a61af66fc99e Initial load
duke
parents:
diff changeset
137
a61af66fc99e Initial load
duke
parents:
diff changeset
138 class CollectedMemoryPool : public MemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
139 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
140 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
141 MemoryPool(name, type, init_size, max_size, support_usage_threshold, true) {};
a61af66fc99e Initial load
duke
parents:
diff changeset
142 bool is_collected_pool() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
143 };
a61af66fc99e Initial load
duke
parents:
diff changeset
144
a61af66fc99e Initial load
duke
parents:
diff changeset
145 class ContiguousSpacePool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
146 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
147 ContiguousSpace* _space;
a61af66fc99e Initial load
duke
parents:
diff changeset
148
a61af66fc99e Initial load
duke
parents:
diff changeset
149 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
150 ContiguousSpacePool(ContiguousSpace* space, const char* name, PoolType type, size_t max_size, bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
151
a61af66fc99e Initial load
duke
parents:
diff changeset
152 ContiguousSpace* space() { return _space; }
a61af66fc99e Initial load
duke
parents:
diff changeset
153 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
154 size_t used_in_bytes() { return space()->used(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
155 };
a61af66fc99e Initial load
duke
parents:
diff changeset
156
a61af66fc99e Initial load
duke
parents:
diff changeset
157 class SurvivorContiguousSpacePool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
158 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
159 DefNewGeneration* _gen;
a61af66fc99e Initial load
duke
parents:
diff changeset
160
a61af66fc99e Initial load
duke
parents:
diff changeset
161 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
162 SurvivorContiguousSpacePool(DefNewGeneration* gen,
a61af66fc99e Initial load
duke
parents:
diff changeset
163 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
164 PoolType type,
a61af66fc99e Initial load
duke
parents:
diff changeset
165 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
166 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
167
a61af66fc99e Initial load
duke
parents:
diff changeset
168 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
169
a61af66fc99e Initial load
duke
parents:
diff changeset
170 size_t used_in_bytes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
171 return _gen->from()->used();
a61af66fc99e Initial load
duke
parents:
diff changeset
172 }
a61af66fc99e Initial load
duke
parents:
diff changeset
173 size_t committed_in_bytes() {
a61af66fc99e Initial load
duke
parents:
diff changeset
174 return _gen->from()->capacity();
a61af66fc99e Initial load
duke
parents:
diff changeset
175 }
a61af66fc99e Initial load
duke
parents:
diff changeset
176 };
a61af66fc99e Initial load
duke
parents:
diff changeset
177
a61af66fc99e Initial load
duke
parents:
diff changeset
178 #ifndef SERIALGC
a61af66fc99e Initial load
duke
parents:
diff changeset
179 class CompactibleFreeListSpacePool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
180 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
181 CompactibleFreeListSpace* _space;
a61af66fc99e Initial load
duke
parents:
diff changeset
182 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
183 CompactibleFreeListSpacePool(CompactibleFreeListSpace* space,
a61af66fc99e Initial load
duke
parents:
diff changeset
184 const char* name,
a61af66fc99e Initial load
duke
parents:
diff changeset
185 PoolType type,
a61af66fc99e Initial load
duke
parents:
diff changeset
186 size_t max_size,
a61af66fc99e Initial load
duke
parents:
diff changeset
187 bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
188
a61af66fc99e Initial load
duke
parents:
diff changeset
189 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
190 size_t used_in_bytes() { return _space->used(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
191 };
a61af66fc99e Initial load
duke
parents:
diff changeset
192 #endif // SERIALGC
a61af66fc99e Initial load
duke
parents:
diff changeset
193
a61af66fc99e Initial load
duke
parents:
diff changeset
194
a61af66fc99e Initial load
duke
parents:
diff changeset
195 class GenerationPool : public CollectedMemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
196 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
197 Generation* _gen;
a61af66fc99e Initial load
duke
parents:
diff changeset
198 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
199 GenerationPool(Generation* gen, const char* name, PoolType type, bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
200
a61af66fc99e Initial load
duke
parents:
diff changeset
201 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
202 size_t used_in_bytes() { return _gen->used(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
203 };
a61af66fc99e Initial load
duke
parents:
diff changeset
204
a61af66fc99e Initial load
duke
parents:
diff changeset
205 class CodeHeapPool: public MemoryPool {
a61af66fc99e Initial load
duke
parents:
diff changeset
206 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
207 CodeHeap* _codeHeap;
a61af66fc99e Initial load
duke
parents:
diff changeset
208 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
209 CodeHeapPool(CodeHeap* codeHeap, const char* name, bool support_usage_threshold);
a61af66fc99e Initial load
duke
parents:
diff changeset
210 MemoryUsage get_memory_usage();
a61af66fc99e Initial load
duke
parents:
diff changeset
211 size_t used_in_bytes() { return _codeHeap->allocated_capacity(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
212 };