Mercurial > hg > truffle
annotate src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp @ 10293:2958af1d8c5a
Merge
author | jwilhelm |
---|---|
date | Fri, 17 May 2013 06:01:10 +0200 |
parents | 48391ab0687e |
children | f2110083203d |
rev | line source |
---|---|
342 | 1 /* |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
2 * Copyright (c) 2001, 2013, Oracle and/or its affiliates. All rights reserved. |
342 | 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 * | |
5 * This code is free software; you can redistribute it and/or modify it | |
6 * under the terms of the GNU General Public License version 2 only, as | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * This code is distributed in the hope that it will be useful, but WITHOUT | |
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 * version 2 for more details (a copy is included in the LICENSE file that | |
13 * accompanied this code). | |
14 * | |
15 * You should have received a copy of the GNU General Public License version | |
16 * 2 along with this work; if not, write to the Free Software Foundation, | |
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 * | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1394
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1394
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:
1394
diff
changeset
|
21 * questions. |
342 | 22 * |
23 */ | |
24 | |
1972 | 25 #ifndef SHARE_VM_GC_IMPLEMENTATION_G1_G1COLLECTORPOLICY_HPP |
26 #define SHARE_VM_GC_IMPLEMENTATION_G1_G1COLLECTORPOLICY_HPP | |
27 | |
28 #include "gc_implementation/g1/collectionSetChooser.hpp" | |
29 #include "gc_implementation/g1/g1MMUTracker.hpp" | |
30 #include "memory/collectorPolicy.hpp" | |
31 | |
342 | 32 // A G1CollectorPolicy makes policy decisions that determine the |
33 // characteristics of the collector. Examples include: | |
34 // * choice of collection set. | |
35 // * when to collect. | |
36 | |
37 class HeapRegion; | |
38 class CollectionSetChooser; | |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
39 class G1GCPhaseTimes; |
342 | 40 |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
41 // TraceGen0Time collects data on _both_ young and mixed evacuation pauses |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
42 // (the latter may contain non-young regions - i.e. regions that are |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
43 // technically in Gen1) while TraceGen1Time collects data about full GCs. |
6197 | 44 class TraceGen0TimeData : public CHeapObj<mtGC> { |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
45 private: |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
46 unsigned _young_pause_num; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
47 unsigned _mixed_pause_num; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
48 |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
49 NumberSeq _all_stop_world_times_ms; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
50 NumberSeq _all_yield_times_ms; |
342 | 51 |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
52 NumberSeq _total; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
53 NumberSeq _other; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
54 NumberSeq _root_region_scan_wait; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
55 NumberSeq _parallel; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
56 NumberSeq _ext_root_scan; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
57 NumberSeq _satb_filtering; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
58 NumberSeq _update_rs; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
59 NumberSeq _scan_rs; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
60 NumberSeq _obj_copy; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
61 NumberSeq _termination; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
62 NumberSeq _parallel_other; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
63 NumberSeq _clear_ct; |
342 | 64 |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
65 void print_summary(const char* str, const NumberSeq* seq) const; |
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
66 void print_summary_sd(const char* str, const NumberSeq* seq) const; |
342 | 67 |
68 public: | |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
69 TraceGen0TimeData() : _young_pause_num(0), _mixed_pause_num(0) {}; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
70 void record_start_collection(double time_to_stop_the_world_ms); |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
71 void record_yield_time(double yield_time_ms); |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
72 void record_end_collection(double pause_time_ms, G1GCPhaseTimes* phase_times); |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
73 void increment_young_collection_count(); |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
74 void increment_mixed_collection_count(); |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
75 void print() const; |
342 | 76 }; |
77 | |
6197 | 78 class TraceGen1TimeData : public CHeapObj<mtGC> { |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
79 private: |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
80 NumberSeq _all_full_gc_times; |
342 | 81 |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
82 public: |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
83 void record_full_collection(double full_gc_time_ms); |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
84 void print() const; |
342 | 85 }; |
86 | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
87 // There are three command line options related to the young gen size: |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
88 // NewSize, MaxNewSize and NewRatio (There is also -Xmn, but that is |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
89 // just a short form for NewSize==MaxNewSize). G1 will use its internal |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
90 // heuristics to calculate the actual young gen size, so these options |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
91 // basically only limit the range within which G1 can pick a young gen |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
92 // size. Also, these are general options taking byte sizes. G1 will |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
93 // internally work with a number of regions instead. So, some rounding |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
94 // will occur. |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
95 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
96 // If nothing related to the the young gen size is set on the command |
7449 | 97 // line we should allow the young gen to be between G1NewSizePercent |
98 // and G1MaxNewSizePercent of the heap size. This means that every time | |
99 // the heap size changes, the limits for the young gen size will be | |
100 // recalculated. | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
101 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
102 // If only -XX:NewSize is set we should use the specified value as the |
7449 | 103 // minimum size for young gen. Still using G1MaxNewSizePercent of the |
104 // heap as maximum. | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
105 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
106 // If only -XX:MaxNewSize is set we should use the specified value as the |
7449 | 107 // maximum size for young gen. Still using G1NewSizePercent of the heap |
108 // as minimum. | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
109 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
110 // If -XX:NewSize and -XX:MaxNewSize are both specified we use these values. |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
111 // No updates when the heap size changes. There is a special case when |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
112 // NewSize==MaxNewSize. This is interpreted as "fixed" and will use a |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
113 // different heuristic for calculating the collection set when we do mixed |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
114 // collection. |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
115 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
116 // If only -XX:NewRatio is set we should use the specified ratio of the heap |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
117 // as both min and max. This will be interpreted as "fixed" just like the |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
118 // NewSize==MaxNewSize case above. But we will update the min and max |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
119 // everytime the heap size changes. |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
120 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
121 // NewSize and MaxNewSize override NewRatio. So, NewRatio is ignored if it is |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
122 // combined with either NewSize or MaxNewSize. (A warning message is printed.) |
6197 | 123 class G1YoungGenSizer : public CHeapObj<mtGC> { |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
124 private: |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
125 enum SizerKind { |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
126 SizerDefaults, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
127 SizerNewSizeOnly, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
128 SizerMaxNewSizeOnly, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
129 SizerMaxAndNewSize, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
130 SizerNewRatio |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
131 }; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
132 SizerKind _sizer_kind; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
133 uint _min_desired_young_length; |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
134 uint _max_desired_young_length; |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
135 bool _adaptive_size; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
136 uint calculate_default_min_length(uint new_number_of_heap_regions); |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
137 uint calculate_default_max_length(uint new_number_of_heap_regions); |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
138 |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
139 public: |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
140 G1YoungGenSizer(); |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
141 void heap_size_changed(uint new_number_of_heap_regions); |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
142 uint min_desired_young_length() { |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
143 return _min_desired_young_length; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
144 } |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
145 uint max_desired_young_length() { |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
146 return _max_desired_young_length; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
147 } |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
148 bool adaptive_young_list_length() { |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
149 return _adaptive_size; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
150 } |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
151 }; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
152 |
342 | 153 class G1CollectorPolicy: public CollectorPolicy { |
4013 | 154 private: |
342 | 155 // either equal to the number of parallel threads, if ParallelGCThreads |
156 // has been set, or 1 otherwise | |
157 int _parallel_gc_threads; | |
158 | |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
159 // The number of GC threads currently active. |
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
160 uintx _no_of_gc_threads; |
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
161 |
342 | 162 enum SomePrivateConstants { |
942
2c79770d1f6e
6819085: G1: use larger and/or user settable region size
tonyp
parents:
936
diff
changeset
|
163 NumPrevPausesForHeuristics = 10 |
342 | 164 }; |
165 | |
166 G1MMUTracker* _mmu_tracker; | |
167 | |
168 void initialize_flags(); | |
169 | |
170 void initialize_all() { | |
171 initialize_flags(); | |
172 initialize_size_info(); | |
173 } | |
174 | |
4013 | 175 CollectionSetChooser* _collectionSetChooser; |
342 | 176 |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
177 double _full_collection_start_sec; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
178 uint _cur_collection_pause_used_regions_at_start; |
890
6cb8e9df7174
6819077: G1: first GC thread coming late into the GC.
johnc
parents:
838
diff
changeset
|
179 |
342 | 180 // These exclude marking times. |
181 TruncatedSeq* _recent_gc_times_ms; | |
182 | |
183 TruncatedSeq* _concurrent_mark_remark_times_ms; | |
184 TruncatedSeq* _concurrent_mark_cleanup_times_ms; | |
185 | |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
186 TraceGen0TimeData _trace_gen0_time_data; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
187 TraceGen1TimeData _trace_gen1_time_data; |
342 | 188 |
189 double _stop_world_start; | |
190 | |
4710 | 191 // indicates whether we are in young or mixed GC mode |
192 bool _gcs_are_young; | |
342 | 193 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
194 uint _young_list_target_length; |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
195 uint _young_list_fixed_length; |
342 | 196 |
1991
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
197 // The max number of regions we can extend the eden by while the GC |
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
198 // locker is active. This should be >= _young_list_target_length; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
199 uint _young_list_max_length; |
1991
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
200 |
4710 | 201 bool _last_gc_was_young; |
342 | 202 |
203 bool _during_marking; | |
204 bool _in_marking_window; | |
205 bool _in_marking_window_im; | |
206 | |
207 SurvRateGroup* _short_lived_surv_rate_group; | |
208 SurvRateGroup* _survivor_surv_rate_group; | |
209 // add here any more surv rate groups | |
210 | |
1356 | 211 double _gc_overhead_perc; |
212 | |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
213 double _reserve_factor; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
214 uint _reserve_regions; |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
215 |
342 | 216 bool during_marking() { |
217 return _during_marking; | |
218 } | |
219 | |
220 private: | |
221 enum PredictionConstants { | |
222 TruncatedSeqLength = 10 | |
223 }; | |
224 | |
225 TruncatedSeq* _alloc_rate_ms_seq; | |
226 double _prev_collection_pause_end_ms; | |
227 | |
228 TruncatedSeq* _rs_length_diff_seq; | |
229 TruncatedSeq* _cost_per_card_ms_seq; | |
4710 | 230 TruncatedSeq* _young_cards_per_entry_ratio_seq; |
231 TruncatedSeq* _mixed_cards_per_entry_ratio_seq; | |
342 | 232 TruncatedSeq* _cost_per_entry_ms_seq; |
4710 | 233 TruncatedSeq* _mixed_cost_per_entry_ms_seq; |
342 | 234 TruncatedSeq* _cost_per_byte_ms_seq; |
235 TruncatedSeq* _constant_other_time_ms_seq; | |
236 TruncatedSeq* _young_other_cost_per_region_ms_seq; | |
237 TruncatedSeq* _non_young_other_cost_per_region_ms_seq; | |
238 | |
239 TruncatedSeq* _pending_cards_seq; | |
240 TruncatedSeq* _rs_lengths_seq; | |
241 | |
242 TruncatedSeq* _cost_per_byte_ms_during_cm_seq; | |
243 | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
244 G1YoungGenSizer* _young_gen_sizer; |
3920
af2ab04e0038
6929868: G1: introduce min / max young gen size bounds
brutisso
parents:
3919
diff
changeset
|
245 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
246 uint _eden_cset_region_length; |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
247 uint _survivor_cset_region_length; |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
248 uint _old_cset_region_length; |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
249 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
250 void init_cset_region_lengths(uint eden_cset_region_length, |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
251 uint survivor_cset_region_length); |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
252 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
253 uint eden_cset_region_length() { return _eden_cset_region_length; } |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
254 uint survivor_cset_region_length() { return _survivor_cset_region_length; } |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
255 uint old_cset_region_length() { return _old_cset_region_length; } |
342 | 256 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
257 uint _free_regions_at_end_of_collection; |
342 | 258 |
259 size_t _recorded_rs_lengths; | |
260 size_t _max_rs_lengths; | |
261 double _sigma; | |
262 | |
263 size_t _rs_lengths_prediction; | |
264 | |
4912
a9647476d1a4
7132029: G1: mixed GC phase lasts for longer than it should
tonyp
parents:
4837
diff
changeset
|
265 double sigma() { return _sigma; } |
342 | 266 |
267 // A function that prevents us putting too much stock in small sample | |
268 // sets. Returns a number between 2.0 and 1.0, depending on the number | |
269 // of samples. 5 or more samples yields one; fewer scales linearly from | |
270 // 2.0 at 1 sample to 1.0 at 5. | |
271 double confidence_factor(int samples) { | |
272 if (samples > 4) return 1.0; | |
273 else return 1.0 + sigma() * ((double)(5 - samples))/2.0; | |
274 } | |
275 | |
276 double get_new_neg_prediction(TruncatedSeq* seq) { | |
277 return seq->davg() - sigma() * seq->dsd(); | |
278 } | |
279 | |
280 #ifndef PRODUCT | |
281 bool verify_young_ages(HeapRegion* head, SurvRateGroup *surv_rate_group); | |
282 #endif // PRODUCT | |
283 | |
1111 | 284 void adjust_concurrent_refinement(double update_rs_time, |
285 double update_rs_processed_buffers, | |
286 double goal_ms); | |
287 | |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
288 uintx no_of_gc_threads() { return _no_of_gc_threads; } |
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
289 void set_no_of_gc_threads(uintx v) { _no_of_gc_threads = v; } |
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
290 |
342 | 291 double _pause_time_target_ms; |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
292 |
342 | 293 size_t _pending_cards; |
294 | |
295 public: | |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
296 // Accessors |
342 | 297 |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
298 void set_region_eden(HeapRegion* hr, int young_index_in_cset) { |
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
299 hr->set_young(); |
342 | 300 hr->install_surv_rate_group(_short_lived_surv_rate_group); |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
301 hr->set_young_index_in_cset(young_index_in_cset); |
342 | 302 } |
303 | |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
304 void set_region_survivor(HeapRegion* hr, int young_index_in_cset) { |
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
305 assert(hr->is_young() && hr->is_survivor(), "pre-condition"); |
342 | 306 hr->install_surv_rate_group(_survivor_surv_rate_group); |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
307 hr->set_young_index_in_cset(young_index_in_cset); |
342 | 308 } |
309 | |
310 #ifndef PRODUCT | |
311 bool verify_young_ages(); | |
312 #endif // PRODUCT | |
313 | |
314 double get_new_prediction(TruncatedSeq* seq) { | |
315 return MAX2(seq->davg() + sigma() * seq->dsd(), | |
316 seq->davg() * confidence_factor(seq->num())); | |
317 } | |
318 | |
319 void record_max_rs_lengths(size_t rs_lengths) { | |
320 _max_rs_lengths = rs_lengths; | |
321 } | |
322 | |
323 size_t predict_rs_length_diff() { | |
324 return (size_t) get_new_prediction(_rs_length_diff_seq); | |
325 } | |
326 | |
327 double predict_alloc_rate_ms() { | |
328 return get_new_prediction(_alloc_rate_ms_seq); | |
329 } | |
330 | |
331 double predict_cost_per_card_ms() { | |
332 return get_new_prediction(_cost_per_card_ms_seq); | |
333 } | |
334 | |
335 double predict_rs_update_time_ms(size_t pending_cards) { | |
336 return (double) pending_cards * predict_cost_per_card_ms(); | |
337 } | |
338 | |
4710 | 339 double predict_young_cards_per_entry_ratio() { |
340 return get_new_prediction(_young_cards_per_entry_ratio_seq); | |
342 | 341 } |
342 | |
4710 | 343 double predict_mixed_cards_per_entry_ratio() { |
344 if (_mixed_cards_per_entry_ratio_seq->num() < 2) { | |
345 return predict_young_cards_per_entry_ratio(); | |
346 } else { | |
347 return get_new_prediction(_mixed_cards_per_entry_ratio_seq); | |
348 } | |
342 | 349 } |
350 | |
351 size_t predict_young_card_num(size_t rs_length) { | |
352 return (size_t) ((double) rs_length * | |
4710 | 353 predict_young_cards_per_entry_ratio()); |
342 | 354 } |
355 | |
356 size_t predict_non_young_card_num(size_t rs_length) { | |
357 return (size_t) ((double) rs_length * | |
4710 | 358 predict_mixed_cards_per_entry_ratio()); |
342 | 359 } |
360 | |
361 double predict_rs_scan_time_ms(size_t card_num) { | |
4710 | 362 if (gcs_are_young()) { |
342 | 363 return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq); |
4710 | 364 } else { |
365 return predict_mixed_rs_scan_time_ms(card_num); | |
366 } | |
342 | 367 } |
368 | |
4710 | 369 double predict_mixed_rs_scan_time_ms(size_t card_num) { |
370 if (_mixed_cost_per_entry_ms_seq->num() < 3) { | |
342 | 371 return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq); |
4710 | 372 } else { |
373 return (double) (card_num * | |
374 get_new_prediction(_mixed_cost_per_entry_ms_seq)); | |
375 } | |
342 | 376 } |
377 | |
378 double predict_object_copy_time_ms_during_cm(size_t bytes_to_copy) { | |
4710 | 379 if (_cost_per_byte_ms_during_cm_seq->num() < 3) { |
380 return (1.1 * (double) bytes_to_copy) * | |
381 get_new_prediction(_cost_per_byte_ms_seq); | |
382 } else { | |
342 | 383 return (double) bytes_to_copy * |
4710 | 384 get_new_prediction(_cost_per_byte_ms_during_cm_seq); |
385 } | |
342 | 386 } |
387 | |
388 double predict_object_copy_time_ms(size_t bytes_to_copy) { | |
4710 | 389 if (_in_marking_window && !_in_marking_window_im) { |
342 | 390 return predict_object_copy_time_ms_during_cm(bytes_to_copy); |
4710 | 391 } else { |
342 | 392 return (double) bytes_to_copy * |
4710 | 393 get_new_prediction(_cost_per_byte_ms_seq); |
394 } | |
342 | 395 } |
396 | |
397 double predict_constant_other_time_ms() { | |
398 return get_new_prediction(_constant_other_time_ms_seq); | |
399 } | |
400 | |
401 double predict_young_other_time_ms(size_t young_num) { | |
4710 | 402 return (double) young_num * |
403 get_new_prediction(_young_other_cost_per_region_ms_seq); | |
342 | 404 } |
405 | |
406 double predict_non_young_other_time_ms(size_t non_young_num) { | |
4710 | 407 return (double) non_young_num * |
408 get_new_prediction(_non_young_other_cost_per_region_ms_seq); | |
342 | 409 } |
410 | |
411 double predict_base_elapsed_time_ms(size_t pending_cards); | |
412 double predict_base_elapsed_time_ms(size_t pending_cards, | |
413 size_t scanned_cards); | |
414 size_t predict_bytes_to_copy(HeapRegion* hr); | |
6611 | 415 double predict_region_elapsed_time_ms(HeapRegion* hr, bool for_young_gc); |
342 | 416 |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
417 void set_recorded_rs_lengths(size_t rs_lengths); |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
418 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
419 uint cset_region_length() { return young_cset_region_length() + |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
420 old_cset_region_length(); } |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
421 uint young_cset_region_length() { return eden_cset_region_length() + |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
422 survivor_cset_region_length(); } |
342 | 423 |
545 | 424 double predict_survivor_regions_evac_time(); |
425 | |
342 | 426 void cset_regions_freed() { |
4710 | 427 bool propagate = _last_gc_was_young && !_in_marking_window; |
342 | 428 _short_lived_surv_rate_group->all_surviving_words_recorded(propagate); |
429 _survivor_surv_rate_group->all_surviving_words_recorded(propagate); | |
430 // also call it on any more surv rate groups | |
431 } | |
432 | |
433 G1MMUTracker* mmu_tracker() { | |
434 return _mmu_tracker; | |
435 } | |
436 | |
1656
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
437 double max_pause_time_ms() { |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
438 return _mmu_tracker->max_gc_time() * 1000.0; |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
439 } |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
440 |
342 | 441 double predict_remark_time_ms() { |
442 return get_new_prediction(_concurrent_mark_remark_times_ms); | |
443 } | |
444 | |
445 double predict_cleanup_time_ms() { | |
446 return get_new_prediction(_concurrent_mark_cleanup_times_ms); | |
447 } | |
448 | |
449 // Returns an estimate of the survival rate of the region at yg-age | |
450 // "yg_age". | |
545 | 451 double predict_yg_surv_rate(int age, SurvRateGroup* surv_rate_group) { |
452 TruncatedSeq* seq = surv_rate_group->get_seq(age); | |
342 | 453 if (seq->num() == 0) |
454 gclog_or_tty->print("BARF! age is %d", age); | |
455 guarantee( seq->num() > 0, "invariant" ); | |
456 double pred = get_new_prediction(seq); | |
457 if (pred > 1.0) | |
458 pred = 1.0; | |
459 return pred; | |
460 } | |
461 | |
545 | 462 double predict_yg_surv_rate(int age) { |
463 return predict_yg_surv_rate(age, _short_lived_surv_rate_group); | |
464 } | |
465 | |
342 | 466 double accum_yg_surv_rate_pred(int age) { |
467 return _short_lived_surv_rate_group->accum_surv_rate_pred(age); | |
468 } | |
469 | |
4013 | 470 private: |
342 | 471 // Statistics kept per GC stoppage, pause or full. |
472 TruncatedSeq* _recent_prev_end_times_for_all_gcs_sec; | |
473 | |
474 // Add a new GC of the given duration and end time to the record. | |
475 void update_recent_gc_times(double end_time_sec, double elapsed_ms); | |
476 | |
477 // The head of the list (via "next_in_collection_set()") representing the | |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
478 // current collection set. Set from the incrementally built collection |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
479 // set at the start of the pause. |
342 | 480 HeapRegion* _collection_set; |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
481 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
482 // The number of bytes in the collection set before the pause. Set from |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
483 // the incrementally built collection set at the start of an evacuation |
6611 | 484 // pause, and incremented in finalize_cset() when adding old regions |
485 // (if any) to the collection set. | |
342 | 486 size_t _collection_set_bytes_used_before; |
487 | |
6611 | 488 // The number of bytes copied during the GC. |
489 size_t _bytes_copied_during_gc; | |
490 | |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
491 // The associated information that is maintained while the incremental |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
492 // collection set is being built with young regions. Used to populate |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
493 // the recorded info for the evacuation pause. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
494 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
495 enum CSetBuildType { |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
496 Active, // We are actively building the collection set |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
497 Inactive // We are not actively building the collection set |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
498 }; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
499 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
500 CSetBuildType _inc_cset_build_state; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
501 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
502 // The head of the incrementally built collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
503 HeapRegion* _inc_cset_head; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
504 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
505 // The tail of the incrementally built collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
506 HeapRegion* _inc_cset_tail; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
507 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
508 // The number of bytes in the incrementally built collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
509 // Used to set _collection_set_bytes_used_before at the start of |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
510 // an evacuation pause. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
511 size_t _inc_cset_bytes_used_before; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
512 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
513 // Used to record the highest end of heap region in collection set |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
514 HeapWord* _inc_cset_max_finger; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
515 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
516 // The RSet lengths recorded for regions in the CSet. It is updated |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
517 // by the thread that adds a new region to the CSet. We assume that |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
518 // only one thread can be allocating a new CSet region (currently, |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
519 // it does so after taking the Heap_lock) hence no need to |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
520 // synchronize updates to this field. |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
521 size_t _inc_cset_recorded_rs_lengths; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
522 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
523 // A concurrent refinement thread periodcially samples the young |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
524 // region RSets and needs to update _inc_cset_recorded_rs_lengths as |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
525 // the RSets grow. Instead of having to syncronize updates to that |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
526 // field we accumulate them in this field and add it to |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
527 // _inc_cset_recorded_rs_lengths_diffs at the start of a GC. |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
528 ssize_t _inc_cset_recorded_rs_lengths_diffs; |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
529 |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
530 // The predicted elapsed time it will take to collect the regions in |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
531 // the CSet. This is updated by the thread that adds a new region to |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
532 // the CSet. See the comment for _inc_cset_recorded_rs_lengths about |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
533 // MT-safety assumptions. |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
534 double _inc_cset_predicted_elapsed_time_ms; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
535 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
536 // See the comment for _inc_cset_recorded_rs_lengths_diffs. |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
537 double _inc_cset_predicted_elapsed_time_ms_diffs; |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
538 |
342 | 539 // Stash a pointer to the g1 heap. |
540 G1CollectedHeap* _g1; | |
541 | |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
542 G1GCPhaseTimes* _phase_times; |
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
543 |
342 | 544 // The ratio of gc time to elapsed time, computed over recent pauses. |
545 double _recent_avg_pause_time_ratio; | |
546 | |
547 double recent_avg_pause_time_ratio() { | |
548 return _recent_avg_pause_time_ratio; | |
549 } | |
550 | |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
551 // At the end of a pause we check the heap occupancy and we decide |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
552 // whether we will start a marking cycle during the next pause. If |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
553 // we decide that we want to do that, we will set this parameter to |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
554 // true. So, this parameter will stay true between the end of a |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
555 // pause and the beginning of a subsequent pause (not necessarily |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
556 // the next one, see the comments on the next field) when we decide |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
557 // that we will indeed start a marking cycle and do the initial-mark |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
558 // work. |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
559 volatile bool _initiate_conc_mark_if_possible; |
342 | 560 |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
561 // If initiate_conc_mark_if_possible() is set at the beginning of a |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
562 // pause, it is a suggestion that the pause should start a marking |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
563 // cycle by doing the initial-mark work. However, it is possible |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
564 // that the concurrent marking thread is still finishing up the |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
565 // previous marking cycle (e.g., clearing the next marking |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
566 // bitmap). If that is the case we cannot start a new cycle and |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
567 // we'll have to wait for the concurrent marking thread to finish |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
568 // what it is doing. In this case we will postpone the marking cycle |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
569 // initiation decision for the next pause. When we eventually decide |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
570 // to start a cycle, we will set _during_initial_mark_pause which |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
571 // will stay true until the end of the initial-mark pause and it's |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
572 // the condition that indicates that a pause is doing the |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
573 // initial-mark work. |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
574 volatile bool _during_initial_mark_pause; |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
575 |
4710 | 576 bool _last_young_gc; |
342 | 577 |
578 // This set of variables tracks the collector efficiency, in order to | |
579 // determine whether we should initiate a new marking. | |
580 double _cur_mark_stop_world_time_ms; | |
581 double _mark_remark_start_sec; | |
582 double _mark_cleanup_start_sec; | |
583 | |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
584 // Update the young list target length either by setting it to the |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
585 // desired fixed value or by calculating it using G1's pause |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
586 // prediction model. If no rs_lengths parameter is passed, predict |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
587 // the RS lengths using the prediction model, otherwise use the |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
588 // given rs_lengths as the prediction. |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
589 void update_young_list_target_length(size_t rs_lengths = (size_t) -1); |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
590 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
591 // Calculate and return the minimum desired young list target |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
592 // length. This is the minimum desired young list length according |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
593 // to the user's inputs. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
594 uint calculate_young_list_desired_min_length(uint base_min_length); |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
595 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
596 // Calculate and return the maximum desired young list target |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
597 // length. This is the maximum desired young list length according |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
598 // to the user's inputs. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
599 uint calculate_young_list_desired_max_length(); |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
600 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
601 // Calculate and return the maximum young list target length that |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
602 // can fit into the pause time goal. The parameters are: rs_lengths |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
603 // represent the prediction of how large the young RSet lengths will |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
604 // be, base_min_length is the alreay existing number of regions in |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
605 // the young list, min_length and max_length are the desired min and |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
606 // max young list length according to the user's inputs. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
607 uint calculate_young_list_target_length(size_t rs_lengths, |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
608 uint base_min_length, |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
609 uint desired_min_length, |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
610 uint desired_max_length); |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
611 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
612 // Check whether a given young length (young_length) fits into the |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
613 // given target pause time and whether the prediction for the amount |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
614 // of objects to be copied for the given length will fit into the |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
615 // given free space (expressed by base_free_regions). It is used by |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
616 // calculate_young_list_target_length(). |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
617 bool predict_will_fit(uint young_length, double base_time_ms, |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
618 uint base_free_regions, double target_pause_time_ms); |
342 | 619 |
8681
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
620 // Calculate the minimum number of old regions we'll add to the CSet |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
621 // during a mixed GC. |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
622 uint calc_min_old_cset_length(); |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
623 |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
624 // Calculate the maximum number of old regions we'll add to the CSet |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
625 // during a mixed GC. |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
626 uint calc_max_old_cset_length(); |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
627 |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
628 // Returns the given amount of uncollected reclaimable space |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
629 // as a percentage of the current heap capacity. |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
630 double reclaimable_bytes_perc(size_t reclaimable_bytes); |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
631 |
342 | 632 public: |
633 | |
634 G1CollectorPolicy(); | |
635 | |
636 virtual G1CollectorPolicy* as_g1_policy() { return this; } | |
637 | |
638 virtual CollectorPolicy::Name kind() { | |
639 return CollectorPolicy::G1CollectorPolicyKind; | |
640 } | |
641 | |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
642 G1GCPhaseTimes* phase_times() const { return _phase_times; } |
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
643 |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
644 // Check the current value of the young list RSet lengths and |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
645 // compare it against the last prediction. If the current value is |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
646 // higher, recalculate the young list target length prediction. |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
647 void revise_young_list_target_length_if_necessary(); |
342 | 648 |
3920
af2ab04e0038
6929868: G1: introduce min / max young gen size bounds
brutisso
parents:
3919
diff
changeset
|
649 // This should be called after the heap is resized. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
650 void record_new_heap_size(uint new_number_of_regions); |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
651 |
4013 | 652 void init(); |
342 | 653 |
545 | 654 // Create jstat counters for the policy. |
655 virtual void initialize_gc_policy_counters(); | |
656 | |
342 | 657 virtual HeapWord* mem_allocate_work(size_t size, |
658 bool is_tlab, | |
659 bool* gc_overhead_limit_was_exceeded); | |
660 | |
661 // This method controls how a collector handles one or more | |
662 // of its generations being fully allocated. | |
663 virtual HeapWord* satisfy_failed_allocation(size_t size, | |
664 bool is_tlab); | |
665 | |
666 BarrierSet::Name barrier_set_name() { return BarrierSet::G1SATBCTLogging; } | |
667 | |
668 GenRemSet::Name rem_set_name() { return GenRemSet::CardTable; } | |
669 | |
4834
6a78aa6ac1ff
7132311: G1: assert((s == klass->oop_size(this)) || (Universe::heap()->is_gc_active() && ((is_typeArray()...
brutisso
parents:
4829
diff
changeset
|
670 bool need_to_start_conc_mark(const char* source, size_t alloc_word_size = 0); |
4829
9509c20bba28
6976060: G1: humongous object allocations should initiate marking cycles when necessary
brutisso
parents:
4787
diff
changeset
|
671 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
672 // Record the start and end of an evacuation pause. |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
673 void record_collection_pause_start(double start_time_sec); |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
674 void record_collection_pause_end(double pause_time_ms); |
342 | 675 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
676 // Record the start and end of a full collection. |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
677 void record_full_collection_start(); |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
678 void record_full_collection_end(); |
342 | 679 |
680 // Must currently be called while the world is stopped. | |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
681 void record_concurrent_mark_init_end(double mark_init_elapsed_time_ms); |
342 | 682 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
683 // Record start and end of remark. |
4013 | 684 void record_concurrent_mark_remark_start(); |
685 void record_concurrent_mark_remark_end(); | |
342 | 686 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
687 // Record start, end, and completion of cleanup. |
4013 | 688 void record_concurrent_mark_cleanup_start(); |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
689 void record_concurrent_mark_cleanup_end(int no_of_gc_threads); |
4013 | 690 void record_concurrent_mark_cleanup_completed(); |
342 | 691 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
692 // Records the information about the heap size for reporting in |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
693 // print_detailed_heap_transition |
10291
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
694 void record_heap_size_info_at_start(bool full); |
342 | 695 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
696 // Print heap sizing transition (with less and more detail). |
3764
053d84a76d3d
7032531: G1: enhance GC logging to include more accurate eden / survivor size transitions
tonyp
parents:
2430
diff
changeset
|
697 void print_heap_transition(); |
10291
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
698 void print_detailed_heap_transition(bool full = false); |
342 | 699 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
700 void record_stop_world_start(); |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
701 void record_concurrent_pause(); |
342 | 702 |
3830
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
703 // Record how much space we copied during a GC. This is typically |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
704 // called when a GC alloc region is being retired. |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
705 void record_bytes_copied_during_gc(size_t bytes) { |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
706 _bytes_copied_during_gc += bytes; |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
707 } |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
708 |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
709 // The amount of space we copied during a GC. |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
710 size_t bytes_copied_during_gc() { |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
711 return _bytes_copied_during_gc; |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
712 } |
342 | 713 |
5972
9a9bb0010c91
7156764: Remove unused size parameter from some CollectedHeap methods
brutisso
parents:
4912
diff
changeset
|
714 // Determine whether there are candidate regions so that the |
9a9bb0010c91
7156764: Remove unused size parameter from some CollectedHeap methods
brutisso
parents:
4912
diff
changeset
|
715 // next GC should be mixed. The two action strings are used |
9a9bb0010c91
7156764: Remove unused size parameter from some CollectedHeap methods
brutisso
parents:
4912
diff
changeset
|
716 // in the ergo output when the method returns true or false. |
4912
a9647476d1a4
7132029: G1: mixed GC phase lasts for longer than it should
tonyp
parents:
4837
diff
changeset
|
717 bool next_gc_should_be_mixed(const char* true_action_str, |
a9647476d1a4
7132029: G1: mixed GC phase lasts for longer than it should
tonyp
parents:
4837
diff
changeset
|
718 const char* false_action_str); |
a9647476d1a4
7132029: G1: mixed GC phase lasts for longer than it should
tonyp
parents:
4837
diff
changeset
|
719 |
342 | 720 // Choose a new collection set. Marks the chosen regions as being |
721 // "in_collection_set", and links them together. The head and number of | |
722 // the collection set are available via access methods. | |
4912
a9647476d1a4
7132029: G1: mixed GC phase lasts for longer than it should
tonyp
parents:
4837
diff
changeset
|
723 void finalize_cset(double target_pause_time_ms); |
342 | 724 |
725 // The head of the list (via "next_in_collection_set()") representing the | |
726 // current collection set. | |
727 HeapRegion* collection_set() { return _collection_set; } | |
728 | |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
729 void clear_collection_set() { _collection_set = NULL; } |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
730 |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
731 // Add old region "hr" to the CSet. |
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
732 void add_old_region_to_cset(HeapRegion* hr); |
342 | 733 |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
734 // Incremental CSet Support |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
735 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
736 // The head of the incrementally built collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
737 HeapRegion* inc_cset_head() { return _inc_cset_head; } |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
738 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
739 // The tail of the incrementally built collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
740 HeapRegion* inc_set_tail() { return _inc_cset_tail; } |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
741 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
742 // Initialize incremental collection set info. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
743 void start_incremental_cset_building(); |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
744 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
745 // Perform any final calculations on the incremental CSet fields |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
746 // before we can use them. |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
747 void finalize_incremental_cset_building(); |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
748 |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
749 void clear_incremental_cset() { |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
750 _inc_cset_head = NULL; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
751 _inc_cset_tail = NULL; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
752 } |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
753 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
754 // Stop adding regions to the incremental collection set |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
755 void stop_incremental_cset_building() { _inc_cset_build_state = Inactive; } |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
756 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
757 // Add information about hr to the aggregated information for the |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
758 // incrementally built collection set. |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
759 void add_to_incremental_cset_info(HeapRegion* hr, size_t rs_length); |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
760 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
761 // Update information about hr in the aggregated information for |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
762 // the incrementally built collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
763 void update_incremental_cset_info(HeapRegion* hr, size_t new_rs_length); |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
764 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
765 private: |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
766 // Update the incremental cset information when adding a region |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
767 // (should not be called directly). |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
768 void add_region_to_incremental_cset_common(HeapRegion* hr); |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
769 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
770 public: |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
771 // Add hr to the LHS of the incremental collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
772 void add_region_to_incremental_cset_lhs(HeapRegion* hr); |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
773 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
774 // Add hr to the RHS of the incremental collection set. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
775 void add_region_to_incremental_cset_rhs(HeapRegion* hr); |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
776 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
777 #ifndef PRODUCT |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
778 void print_collection_set(HeapRegion* list_head, outputStream* st); |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
779 #endif // !PRODUCT |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
780 |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
781 bool initiate_conc_mark_if_possible() { return _initiate_conc_mark_if_possible; } |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
782 void set_initiate_conc_mark_if_possible() { _initiate_conc_mark_if_possible = true; } |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
783 void clear_initiate_conc_mark_if_possible() { _initiate_conc_mark_if_possible = false; } |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
784 |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
785 bool during_initial_mark_pause() { return _during_initial_mark_pause; } |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
786 void set_during_initial_mark_pause() { _during_initial_mark_pause = true; } |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
787 void clear_during_initial_mark_pause(){ _during_initial_mark_pause = false; } |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
788 |
1656
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
789 // This sets the initiate_conc_mark_if_possible() flag to start a |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
790 // new cycle, as long as we are not already in one. It's best if it |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
791 // is called during a safepoint when the test whether a cycle is in |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
792 // progress or not is stable. |
3914
20213c8a3c40
7050392: G1: Introduce flag to generate a log of the G1 ergonomic decisions
tonyp
parents:
3868
diff
changeset
|
793 bool force_initial_mark_if_outside_cycle(GCCause::Cause gc_cause); |
1656
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
794 |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
795 // This is called at the very beginning of an evacuation pause (it |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
796 // has to be the first thing that the pause does). If |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
797 // initiate_conc_mark_if_possible() is true, and the concurrent |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
798 // marking thread has completed its work during the previous cycle, |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
799 // it will set during_initial_mark_pause() to so that the pause does |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
800 // the initial-mark work and start a marking cycle. |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
801 void decide_on_conc_mark_initiation(); |
342 | 802 |
803 // If an expansion would be appropriate, because recent GC overhead had | |
804 // exceeded the desired limit, return an amount to expand by. | |
4013 | 805 size_t expansion_amount(); |
342 | 806 |
807 // Print tracing information. | |
808 void print_tracing_info() const; | |
809 | |
810 // Print stats on young survival ratio | |
811 void print_yg_surv_rate_info() const; | |
812 | |
545 | 813 void finished_recalculating_age_indexes(bool is_survivors) { |
814 if (is_survivors) { | |
815 _survivor_surv_rate_group->finished_recalculating_age_indexes(); | |
816 } else { | |
817 _short_lived_surv_rate_group->finished_recalculating_age_indexes(); | |
818 } | |
342 | 819 // do that for any other surv rate groups |
820 } | |
821 | |
1973 | 822 bool is_young_list_full() { |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
823 uint young_list_length = _g1->young_list()->length(); |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
824 uint young_list_target_length = _young_list_target_length; |
1991
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
825 return young_list_length >= young_list_target_length; |
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
826 } |
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
827 |
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
828 bool can_expand_young_list() { |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
829 uint young_list_length = _g1->young_list()->length(); |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
830 uint young_list_max_length = _young_list_max_length; |
1991
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
831 return young_list_length < young_list_max_length; |
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
832 } |
1973 | 833 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
834 uint young_list_max_length() { |
3980
8229bd737950
7075646: G1: fix inconsistencies in the monitoring data
tonyp
parents:
3979
diff
changeset
|
835 return _young_list_max_length; |
8229bd737950
7075646: G1: fix inconsistencies in the monitoring data
tonyp
parents:
3979
diff
changeset
|
836 } |
8229bd737950
7075646: G1: fix inconsistencies in the monitoring data
tonyp
parents:
3979
diff
changeset
|
837 |
4710 | 838 bool gcs_are_young() { |
839 return _gcs_are_young; | |
342 | 840 } |
4710 | 841 void set_gcs_are_young(bool gcs_are_young) { |
842 _gcs_are_young = gcs_are_young; | |
342 | 843 } |
844 | |
845 bool adaptive_young_list_length() { | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
846 return _young_gen_sizer->adaptive_young_list_length(); |
342 | 847 } |
848 | |
4013 | 849 private: |
342 | 850 // |
851 // Survivor regions policy. | |
852 // | |
853 | |
854 // Current tenuring threshold, set to 0 if the collector reaches the | |
6818 | 855 // maximum amount of survivors regions. |
856 uint _tenuring_threshold; | |
342 | 857 |
545 | 858 // The limit on the number of regions allocated for survivors. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
859 uint _max_survivor_regions; |
545 | 860 |
3764
053d84a76d3d
7032531: G1: enhance GC logging to include more accurate eden / survivor size transitions
tonyp
parents:
2430
diff
changeset
|
861 // For reporting purposes. |
10291
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
862 // The value of _heap_bytes_before_gc is also used to calculate |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
863 // the cost of copying. |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
864 |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
865 size_t _eden_used_bytes_before_gc; // Eden occupancy before GC |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
866 size_t _survivor_used_bytes_before_gc; // Survivor occupancy before GC |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
867 size_t _heap_used_bytes_before_gc; // Heap occupancy before GC |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
868 size_t _metaspace_used_bytes_before_gc; // Metaspace occupancy before GC |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
869 |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
870 size_t _eden_capacity_bytes_before_gc; // Eden capacity before GC |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
871 size_t _heap_capacity_bytes_before_gc; // Heap capacity before GC |
3764
053d84a76d3d
7032531: G1: enhance GC logging to include more accurate eden / survivor size transitions
tonyp
parents:
2430
diff
changeset
|
872 |
6818 | 873 // The amount of survivor regions after a collection. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
874 uint _recorded_survivor_regions; |
545 | 875 // List of survivor regions. |
876 HeapRegion* _recorded_survivor_head; | |
877 HeapRegion* _recorded_survivor_tail; | |
878 | |
879 ageTable _survivors_age_table; | |
880 | |
342 | 881 public: |
882 | |
883 inline GCAllocPurpose | |
6818 | 884 evacuation_destination(HeapRegion* src_region, uint age, size_t word_sz) { |
342 | 885 if (age < _tenuring_threshold && src_region->is_young()) { |
886 return GCAllocForSurvived; | |
887 } else { | |
888 return GCAllocForTenured; | |
889 } | |
890 } | |
891 | |
892 inline bool track_object_age(GCAllocPurpose purpose) { | |
893 return purpose == GCAllocForSurvived; | |
894 } | |
895 | |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
896 static const uint REGIONS_UNLIMITED = (uint) -1; |
545 | 897 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
898 uint max_regions(int purpose); |
342 | 899 |
900 // The limit on regions for a particular purpose is reached. | |
901 void note_alloc_region_limit_reached(int purpose) { | |
902 if (purpose == GCAllocForSurvived) { | |
903 _tenuring_threshold = 0; | |
904 } | |
905 } | |
906 | |
907 void note_start_adding_survivor_regions() { | |
908 _survivor_surv_rate_group->start_adding_regions(); | |
909 } | |
910 | |
911 void note_stop_adding_survivor_regions() { | |
912 _survivor_surv_rate_group->stop_adding_regions(); | |
913 } | |
545 | 914 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
915 void record_survivor_regions(uint regions, |
545 | 916 HeapRegion* head, |
917 HeapRegion* tail) { | |
918 _recorded_survivor_regions = regions; | |
919 _recorded_survivor_head = head; | |
920 _recorded_survivor_tail = tail; | |
921 } | |
922 | |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
923 uint recorded_survivor_regions() { |
838
0316eac49d5a
6855834: G1: minimize the output when -XX:+PrintHeapAtGC is set
tonyp
parents:
794
diff
changeset
|
924 return _recorded_survivor_regions; |
0316eac49d5a
6855834: G1: minimize the output when -XX:+PrintHeapAtGC is set
tonyp
parents:
794
diff
changeset
|
925 } |
0316eac49d5a
6855834: G1: minimize the output when -XX:+PrintHeapAtGC is set
tonyp
parents:
794
diff
changeset
|
926 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
927 void record_thread_age_table(ageTable* age_table) { |
545 | 928 _survivors_age_table.merge_par(age_table); |
929 } | |
930 | |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
931 void update_max_gc_locker_expansion(); |
1991
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
932 |
545 | 933 // Calculates survivor space parameters. |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
934 void update_survivors_policy(); |
545 | 935 |
342 | 936 }; |
937 | |
938 // This should move to some place more general... | |
939 | |
940 // If we have "n" measurements, and we've kept track of their "sum" and the | |
941 // "sum_of_squares" of the measurements, this returns the variance of the | |
942 // sequence. | |
943 inline double variance(int n, double sum_of_squares, double sum) { | |
944 double n_d = (double)n; | |
945 double avg = sum/n_d; | |
946 return (sum_of_squares - 2.0 * avg * sum + n_d * avg * avg) / n_d; | |
947 } | |
948 | |
1972 | 949 #endif // SHARE_VM_GC_IMPLEMENTATION_G1_G1COLLECTORPOLICY_HPP |