Mercurial > hg > graal-jvmci-8
annotate src/share/vm/gc_implementation/g1/g1CollectorPolicy.hpp @ 23027:2e5e058881f4
8075466: SATB queue pre-filter verify found reclaimed humongous object
Summary: Removed pre-filter verify, and made filtering more careful.
Reviewed-by: brutisso, tschatzl
author | kbarrett |
---|---|
date | Wed, 15 Apr 2015 16:37:57 -0400 |
parents | c132be0fb74d |
children | dd9cc155639c |
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" | |
20655
b840813adfcc
8065305: Make it possible to extend the G1CollectorPolicy
jwilhelm
parents:
20481
diff
changeset
|
29 #include "gc_implementation/g1/g1Allocator.hpp" |
1972 | 30 #include "gc_implementation/g1/g1MMUTracker.hpp" |
31 #include "memory/collectorPolicy.hpp" | |
32 | |
342 | 33 // A G1CollectorPolicy makes policy decisions that determine the |
34 // characteristics of the collector. Examples include: | |
35 // * choice of collection set. | |
36 // * when to collect. | |
37 | |
38 class HeapRegion; | |
39 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
|
40 class G1GCPhaseTimes; |
342 | 41 |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
42 // 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
|
43 // (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
|
44 // technically in Gen1) while TraceGen1Time collects data about full GCs. |
6197 | 45 class TraceGen0TimeData : public CHeapObj<mtGC> { |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
46 private: |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
47 unsigned _young_pause_num; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
48 unsigned _mixed_pause_num; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
49 |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
50 NumberSeq _all_stop_world_times_ms; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
51 NumberSeq _all_yield_times_ms; |
342 | 52 |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
53 NumberSeq _total; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
54 NumberSeq _other; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
55 NumberSeq _root_region_scan_wait; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
56 NumberSeq _parallel; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
57 NumberSeq _ext_root_scan; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
58 NumberSeq _satb_filtering; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
59 NumberSeq _update_rs; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
60 NumberSeq _scan_rs; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
61 NumberSeq _obj_copy; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
62 NumberSeq _termination; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
63 NumberSeq _parallel_other; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
64 NumberSeq _clear_ct; |
342 | 65 |
6219
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(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
|
67 void print_summary_sd(const char* str, const NumberSeq* seq) const; |
342 | 68 |
69 public: | |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
70 TraceGen0TimeData() : _young_pause_num(0), _mixed_pause_num(0) {}; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
71 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
|
72 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
|
73 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
|
74 void increment_young_collection_count(); |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
75 void increment_mixed_collection_count(); |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
76 void print() const; |
342 | 77 }; |
78 | |
6197 | 79 class TraceGen1TimeData : public CHeapObj<mtGC> { |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
80 private: |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
81 NumberSeq _all_full_gc_times; |
342 | 82 |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
83 public: |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
84 void record_full_collection(double full_gc_time_ms); |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
85 void print() const; |
342 | 86 }; |
87 | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
88 // 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
|
89 // 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
|
90 // 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
|
91 // 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
|
92 // 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
|
93 // 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
|
94 // 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
|
95 // will occur. |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
96 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
97 // If nothing related to the the young gen size is set on the command |
7449 | 98 // line we should allow the young gen to be between G1NewSizePercent |
99 // and G1MaxNewSizePercent of the heap size. This means that every time | |
100 // the heap size changes, the limits for the young gen size will be | |
101 // recalculated. | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
102 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
103 // If only -XX:NewSize is set we should use the specified value as the |
7449 | 104 // minimum size for young gen. Still using G1MaxNewSizePercent of the |
105 // heap as maximum. | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
106 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
107 // If only -XX:MaxNewSize is set we should use the specified value as the |
7449 | 108 // maximum size for young gen. Still using G1NewSizePercent of the heap |
109 // as minimum. | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
110 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
111 // 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
|
112 // 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
|
113 // 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
|
114 // 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
|
115 // collection. |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
116 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
117 // 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
|
118 // 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
|
119 // 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
|
120 // everytime the heap size changes. |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
121 // |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
122 // 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
|
123 // combined with either NewSize or MaxNewSize. (A warning message is printed.) |
6197 | 124 class G1YoungGenSizer : public CHeapObj<mtGC> { |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
125 private: |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
126 enum SizerKind { |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
127 SizerDefaults, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
128 SizerNewSizeOnly, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
129 SizerMaxNewSizeOnly, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
130 SizerMaxAndNewSize, |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
131 SizerNewRatio |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
132 }; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
133 SizerKind _sizer_kind; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
134 uint _min_desired_young_length; |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
135 uint _max_desired_young_length; |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
136 bool _adaptive_size; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
137 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
|
138 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
|
139 |
13060
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
140 // Update the given values for minimum and maximum young gen length in regions |
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
141 // given the number of heap regions depending on the kind of sizing algorithm. |
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
142 void recalculate_min_max_young_length(uint number_of_heap_regions, uint* min_young_length, uint* max_young_length); |
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
143 |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
144 public: |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
145 G1YoungGenSizer(); |
13060
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
146 // Calculate the maximum length of the young gen given the number of regions |
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
147 // depending on the sizing algorithm. |
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
148 uint max_young_length(uint number_of_heap_regions); |
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
149 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
150 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
|
151 uint min_desired_young_length() { |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
152 return _min_desired_young_length; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
153 } |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
154 uint max_desired_young_length() { |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
155 return _max_desired_young_length; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
156 } |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
157 bool adaptive_young_list_length() { |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
158 return _adaptive_size; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
159 } |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
160 }; |
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
161 |
342 | 162 class G1CollectorPolicy: public CollectorPolicy { |
4013 | 163 private: |
342 | 164 // either equal to the number of parallel threads, if ParallelGCThreads |
165 // has been set, or 1 otherwise | |
166 int _parallel_gc_threads; | |
167 | |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
168 // The number of GC threads currently active. |
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
169 uintx _no_of_gc_threads; |
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
170 |
342 | 171 enum SomePrivateConstants { |
942
2c79770d1f6e
6819085: G1: use larger and/or user settable region size
tonyp
parents:
936
diff
changeset
|
172 NumPrevPausesForHeuristics = 10 |
342 | 173 }; |
174 | |
175 G1MMUTracker* _mmu_tracker; | |
176 | |
13060
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
177 void initialize_alignments(); |
342 | 178 void initialize_flags(); |
179 | |
4013 | 180 CollectionSetChooser* _collectionSetChooser; |
342 | 181 |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
182 double _full_collection_start_sec; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
183 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
|
184 |
342 | 185 // These exclude marking times. |
186 TruncatedSeq* _recent_gc_times_ms; | |
187 | |
188 TruncatedSeq* _concurrent_mark_remark_times_ms; | |
189 TruncatedSeq* _concurrent_mark_cleanup_times_ms; | |
190 | |
6109
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
191 TraceGen0TimeData _trace_gen0_time_data; |
bbc900c2482a
7172279: G1: Clean up TraceGen0Time and TraceGen1Time data gathering
brutisso
parents:
6059
diff
changeset
|
192 TraceGen1TimeData _trace_gen1_time_data; |
342 | 193 |
194 double _stop_world_start; | |
195 | |
4710 | 196 // indicates whether we are in young or mixed GC mode |
197 bool _gcs_are_young; | |
342 | 198 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
199 uint _young_list_target_length; |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
200 uint _young_list_fixed_length; |
342 | 201 |
1991
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
202 // 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
|
203 // 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
|
204 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
|
205 |
4710 | 206 bool _last_gc_was_young; |
342 | 207 |
208 bool _during_marking; | |
209 bool _in_marking_window; | |
210 bool _in_marking_window_im; | |
211 | |
212 SurvRateGroup* _short_lived_surv_rate_group; | |
213 SurvRateGroup* _survivor_surv_rate_group; | |
214 // add here any more surv rate groups | |
215 | |
1356 | 216 double _gc_overhead_perc; |
217 | |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
218 double _reserve_factor; |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
219 uint _reserve_regions; |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
220 |
342 | 221 bool during_marking() { |
222 return _during_marking; | |
223 } | |
224 | |
225 enum PredictionConstants { | |
226 TruncatedSeqLength = 10 | |
227 }; | |
228 | |
229 TruncatedSeq* _alloc_rate_ms_seq; | |
230 double _prev_collection_pause_end_ms; | |
231 | |
232 TruncatedSeq* _rs_length_diff_seq; | |
233 TruncatedSeq* _cost_per_card_ms_seq; | |
4710 | 234 TruncatedSeq* _young_cards_per_entry_ratio_seq; |
235 TruncatedSeq* _mixed_cards_per_entry_ratio_seq; | |
342 | 236 TruncatedSeq* _cost_per_entry_ms_seq; |
4710 | 237 TruncatedSeq* _mixed_cost_per_entry_ms_seq; |
342 | 238 TruncatedSeq* _cost_per_byte_ms_seq; |
239 TruncatedSeq* _constant_other_time_ms_seq; | |
240 TruncatedSeq* _young_other_cost_per_region_ms_seq; | |
241 TruncatedSeq* _non_young_other_cost_per_region_ms_seq; | |
242 | |
243 TruncatedSeq* _pending_cards_seq; | |
244 TruncatedSeq* _rs_lengths_seq; | |
245 | |
246 TruncatedSeq* _cost_per_byte_ms_during_cm_seq; | |
247 | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
248 G1YoungGenSizer* _young_gen_sizer; |
3920
af2ab04e0038
6929868: G1: introduce min / max young gen size bounds
brutisso
parents:
3919
diff
changeset
|
249 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
250 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; |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
252 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
|
253 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
254 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
|
255 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
|
256 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
257 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
|
258 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
|
259 uint old_cset_region_length() { return _old_cset_region_length; } |
342 | 260 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
261 uint _free_regions_at_end_of_collection; |
342 | 262 |
263 size_t _recorded_rs_lengths; | |
264 size_t _max_rs_lengths; | |
265 double _sigma; | |
266 | |
267 size_t _rs_lengths_prediction; | |
268 | |
4912
a9647476d1a4
7132029: G1: mixed GC phase lasts for longer than it should
tonyp
parents:
4837
diff
changeset
|
269 double sigma() { return _sigma; } |
342 | 270 |
271 // A function that prevents us putting too much stock in small sample | |
272 // sets. Returns a number between 2.0 and 1.0, depending on the number | |
273 // of samples. 5 or more samples yields one; fewer scales linearly from | |
274 // 2.0 at 1 sample to 1.0 at 5. | |
275 double confidence_factor(int samples) { | |
276 if (samples > 4) return 1.0; | |
277 else return 1.0 + sigma() * ((double)(5 - samples))/2.0; | |
278 } | |
279 | |
280 double get_new_neg_prediction(TruncatedSeq* seq) { | |
281 return seq->davg() - sigma() * seq->dsd(); | |
282 } | |
283 | |
284 #ifndef PRODUCT | |
285 bool verify_young_ages(HeapRegion* head, SurvRateGroup *surv_rate_group); | |
286 #endif // PRODUCT | |
287 | |
1111 | 288 void adjust_concurrent_refinement(double update_rs_time, |
289 double update_rs_processed_buffers, | |
290 double goal_ms); | |
291 | |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
292 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
|
293 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
|
294 |
342 | 295 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
|
296 |
342 | 297 size_t _pending_cards; |
298 | |
299 public: | |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
300 // Accessors |
342 | 301 |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
302 void set_region_eden(HeapRegion* hr, int young_index_in_cset) { |
20481
c02ec279b062
8057768: Make heap region region type in G1 HeapRegion explicit
brutisso
parents:
17727
diff
changeset
|
303 hr->set_eden(); |
342 | 304 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
|
305 hr->set_young_index_in_cset(young_index_in_cset); |
342 | 306 } |
307 | |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
308 void set_region_survivor(HeapRegion* hr, int young_index_in_cset) { |
20481
c02ec279b062
8057768: Make heap region region type in G1 HeapRegion explicit
brutisso
parents:
17727
diff
changeset
|
309 assert(hr->is_survivor(), "pre-condition"); |
342 | 310 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
|
311 hr->set_young_index_in_cset(young_index_in_cset); |
342 | 312 } |
313 | |
314 #ifndef PRODUCT | |
315 bool verify_young_ages(); | |
316 #endif // PRODUCT | |
317 | |
318 double get_new_prediction(TruncatedSeq* seq) { | |
319 return MAX2(seq->davg() + sigma() * seq->dsd(), | |
320 seq->davg() * confidence_factor(seq->num())); | |
321 } | |
322 | |
323 void record_max_rs_lengths(size_t rs_lengths) { | |
324 _max_rs_lengths = rs_lengths; | |
325 } | |
326 | |
327 size_t predict_rs_length_diff() { | |
328 return (size_t) get_new_prediction(_rs_length_diff_seq); | |
329 } | |
330 | |
331 double predict_alloc_rate_ms() { | |
332 return get_new_prediction(_alloc_rate_ms_seq); | |
333 } | |
334 | |
335 double predict_cost_per_card_ms() { | |
336 return get_new_prediction(_cost_per_card_ms_seq); | |
337 } | |
338 | |
339 double predict_rs_update_time_ms(size_t pending_cards) { | |
340 return (double) pending_cards * predict_cost_per_card_ms(); | |
341 } | |
342 | |
4710 | 343 double predict_young_cards_per_entry_ratio() { |
344 return get_new_prediction(_young_cards_per_entry_ratio_seq); | |
342 | 345 } |
346 | |
4710 | 347 double predict_mixed_cards_per_entry_ratio() { |
348 if (_mixed_cards_per_entry_ratio_seq->num() < 2) { | |
349 return predict_young_cards_per_entry_ratio(); | |
350 } else { | |
351 return get_new_prediction(_mixed_cards_per_entry_ratio_seq); | |
352 } | |
342 | 353 } |
354 | |
355 size_t predict_young_card_num(size_t rs_length) { | |
356 return (size_t) ((double) rs_length * | |
4710 | 357 predict_young_cards_per_entry_ratio()); |
342 | 358 } |
359 | |
360 size_t predict_non_young_card_num(size_t rs_length) { | |
361 return (size_t) ((double) rs_length * | |
4710 | 362 predict_mixed_cards_per_entry_ratio()); |
342 | 363 } |
364 | |
365 double predict_rs_scan_time_ms(size_t card_num) { | |
4710 | 366 if (gcs_are_young()) { |
342 | 367 return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq); |
4710 | 368 } else { |
369 return predict_mixed_rs_scan_time_ms(card_num); | |
370 } | |
342 | 371 } |
372 | |
4710 | 373 double predict_mixed_rs_scan_time_ms(size_t card_num) { |
374 if (_mixed_cost_per_entry_ms_seq->num() < 3) { | |
342 | 375 return (double) card_num * get_new_prediction(_cost_per_entry_ms_seq); |
4710 | 376 } else { |
377 return (double) (card_num * | |
378 get_new_prediction(_mixed_cost_per_entry_ms_seq)); | |
379 } | |
342 | 380 } |
381 | |
382 double predict_object_copy_time_ms_during_cm(size_t bytes_to_copy) { | |
4710 | 383 if (_cost_per_byte_ms_during_cm_seq->num() < 3) { |
384 return (1.1 * (double) bytes_to_copy) * | |
385 get_new_prediction(_cost_per_byte_ms_seq); | |
386 } else { | |
342 | 387 return (double) bytes_to_copy * |
4710 | 388 get_new_prediction(_cost_per_byte_ms_during_cm_seq); |
389 } | |
342 | 390 } |
391 | |
392 double predict_object_copy_time_ms(size_t bytes_to_copy) { | |
4710 | 393 if (_in_marking_window && !_in_marking_window_im) { |
342 | 394 return predict_object_copy_time_ms_during_cm(bytes_to_copy); |
4710 | 395 } else { |
342 | 396 return (double) bytes_to_copy * |
4710 | 397 get_new_prediction(_cost_per_byte_ms_seq); |
398 } | |
342 | 399 } |
400 | |
401 double predict_constant_other_time_ms() { | |
402 return get_new_prediction(_constant_other_time_ms_seq); | |
403 } | |
404 | |
405 double predict_young_other_time_ms(size_t young_num) { | |
4710 | 406 return (double) young_num * |
407 get_new_prediction(_young_other_cost_per_region_ms_seq); | |
342 | 408 } |
409 | |
410 double predict_non_young_other_time_ms(size_t non_young_num) { | |
4710 | 411 return (double) non_young_num * |
412 get_new_prediction(_non_young_other_cost_per_region_ms_seq); | |
342 | 413 } |
414 | |
415 double predict_base_elapsed_time_ms(size_t pending_cards); | |
416 double predict_base_elapsed_time_ms(size_t pending_cards, | |
417 size_t scanned_cards); | |
418 size_t predict_bytes_to_copy(HeapRegion* hr); | |
6611 | 419 double predict_region_elapsed_time_ms(HeapRegion* hr, bool for_young_gc); |
342 | 420 |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
421 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
|
422 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
423 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
|
424 old_cset_region_length(); } |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
425 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
|
426 survivor_cset_region_length(); } |
342 | 427 |
545 | 428 double predict_survivor_regions_evac_time(); |
429 | |
342 | 430 void cset_regions_freed() { |
4710 | 431 bool propagate = _last_gc_was_young && !_in_marking_window; |
342 | 432 _short_lived_surv_rate_group->all_surviving_words_recorded(propagate); |
433 _survivor_surv_rate_group->all_surviving_words_recorded(propagate); | |
434 // also call it on any more surv rate groups | |
435 } | |
436 | |
437 G1MMUTracker* mmu_tracker() { | |
438 return _mmu_tracker; | |
439 } | |
440 | |
1656
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
441 double max_pause_time_ms() { |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
442 return _mmu_tracker->max_gc_time() * 1000.0; |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
443 } |
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
444 |
342 | 445 double predict_remark_time_ms() { |
446 return get_new_prediction(_concurrent_mark_remark_times_ms); | |
447 } | |
448 | |
449 double predict_cleanup_time_ms() { | |
450 return get_new_prediction(_concurrent_mark_cleanup_times_ms); | |
451 } | |
452 | |
453 // Returns an estimate of the survival rate of the region at yg-age | |
454 // "yg_age". | |
545 | 455 double predict_yg_surv_rate(int age, SurvRateGroup* surv_rate_group) { |
456 TruncatedSeq* seq = surv_rate_group->get_seq(age); | |
342 | 457 if (seq->num() == 0) |
458 gclog_or_tty->print("BARF! age is %d", age); | |
459 guarantee( seq->num() > 0, "invariant" ); | |
460 double pred = get_new_prediction(seq); | |
461 if (pred > 1.0) | |
462 pred = 1.0; | |
463 return pred; | |
464 } | |
465 | |
545 | 466 double predict_yg_surv_rate(int age) { |
467 return predict_yg_surv_rate(age, _short_lived_surv_rate_group); | |
468 } | |
469 | |
342 | 470 double accum_yg_surv_rate_pred(int age) { |
471 return _short_lived_surv_rate_group->accum_surv_rate_pred(age); | |
472 } | |
473 | |
4013 | 474 private: |
342 | 475 // Statistics kept per GC stoppage, pause or full. |
476 TruncatedSeq* _recent_prev_end_times_for_all_gcs_sec; | |
477 | |
478 // Add a new GC of the given duration and end time to the record. | |
479 void update_recent_gc_times(double end_time_sec, double elapsed_ms); | |
480 | |
481 // 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
|
482 // 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
|
483 // set at the start of the pause. |
342 | 484 HeapRegion* _collection_set; |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
485 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
486 // 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
|
487 // the incrementally built collection set at the start of an evacuation |
6611 | 488 // pause, and incremented in finalize_cset() when adding old regions |
489 // (if any) to the collection set. | |
342 | 490 size_t _collection_set_bytes_used_before; |
491 | |
6611 | 492 // The number of bytes copied during the GC. |
493 size_t _bytes_copied_during_gc; | |
494 | |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
495 // 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
|
496 // 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
|
497 // 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
|
498 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
499 enum CSetBuildType { |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
500 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
|
501 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
|
502 }; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
503 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
504 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
|
505 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
506 // 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
|
507 HeapRegion* _inc_cset_head; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
508 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
509 // 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
|
510 HeapRegion* _inc_cset_tail; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
511 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
512 // 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
|
513 // 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
|
514 // an evacuation pause. |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
515 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
|
516 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
517 // 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
|
518 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
|
519 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
520 // 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
|
521 // 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
|
522 // 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
|
523 // 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
|
524 // 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
|
525 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
|
526 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
527 // 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
|
528 // 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
|
529 // 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
|
530 // 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
|
531 // _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
|
532 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
|
533 |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
534 // 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
|
535 // 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
|
536 // 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
|
537 // MT-safety assumptions. |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
538 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
|
539 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
540 // 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
|
541 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
|
542 |
342 | 543 // Stash a pointer to the g1 heap. |
544 G1CollectedHeap* _g1; | |
545 | |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
546 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
|
547 |
342 | 548 // The ratio of gc time to elapsed time, computed over recent pauses. |
549 double _recent_avg_pause_time_ratio; | |
550 | |
551 double recent_avg_pause_time_ratio() { | |
552 return _recent_avg_pause_time_ratio; | |
553 } | |
554 | |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
555 // 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
|
556 // 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
|
557 // 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
|
558 // 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
|
559 // 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
|
560 // 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
|
561 // 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
|
562 // work. |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
563 volatile bool _initiate_conc_mark_if_possible; |
342 | 564 |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
565 // 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
|
566 // 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
|
567 // 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
|
568 // 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
|
569 // previous marking cycle (e.g., clearing the next marking |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
570 // 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
|
571 // 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
|
572 // 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
|
573 // 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
|
574 // 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
|
575 // 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
|
576 // 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
|
577 // initial-mark work. |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
578 volatile bool _during_initial_mark_pause; |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
579 |
4710 | 580 bool _last_young_gc; |
342 | 581 |
582 // This set of variables tracks the collector efficiency, in order to | |
583 // determine whether we should initiate a new marking. | |
584 double _cur_mark_stop_world_time_ms; | |
585 double _mark_remark_start_sec; | |
586 double _mark_cleanup_start_sec; | |
587 | |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
588 // 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
|
589 // 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
|
590 // 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
|
591 // 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
|
592 // 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
|
593 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
|
594 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
595 // 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
|
596 // 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
|
597 // to the user's inputs. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
598 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
|
599 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
600 // 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
|
601 // 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
|
602 // to the user's inputs. |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
603 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
|
604 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
605 // 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
|
606 // 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
|
607 // 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
|
608 // 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
|
609 // 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
|
610 // 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
|
611 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
|
612 uint base_min_length, |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
613 uint desired_min_length, |
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
614 uint desired_max_length); |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
615 |
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
616 // 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
|
617 // 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
|
618 // 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
|
619 // 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
|
620 // calculate_young_list_target_length(). |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
621 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
|
622 uint base_free_regions, double target_pause_time_ms); |
342 | 623 |
8681
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
624 // 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
|
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_min_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 // 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
|
629 // during a mixed GC. |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
630 uint calc_max_old_cset_length(); |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
631 |
27714220e50e
8007036: G1: Too many old regions added to last mixed GC
johnc
parents:
7449
diff
changeset
|
632 // 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
|
633 // 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
|
634 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
|
635 |
342 | 636 public: |
637 | |
638 G1CollectorPolicy(); | |
639 | |
640 virtual G1CollectorPolicy* as_g1_policy() { return this; } | |
641 | |
642 virtual CollectorPolicy::Name kind() { | |
643 return CollectorPolicy::G1CollectorPolicyKind; | |
644 } | |
645 | |
6219
922993931b3d
7178361: G1: Make sure that PrintGC and PrintGCDetails use the same timing for the GC pause
brutisso
parents:
6109
diff
changeset
|
646 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
|
647 |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
648 // 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
|
649 // 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
|
650 // 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
|
651 void revise_young_list_target_length_if_necessary(); |
342 | 652 |
3920
af2ab04e0038
6929868: G1: introduce min / max young gen size bounds
brutisso
parents:
3919
diff
changeset
|
653 // 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
|
654 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
|
655 |
4013 | 656 void init(); |
342 | 657 |
545 | 658 // Create jstat counters for the policy. |
659 virtual void initialize_gc_policy_counters(); | |
660 | |
342 | 661 virtual HeapWord* mem_allocate_work(size_t size, |
662 bool is_tlab, | |
663 bool* gc_overhead_limit_was_exceeded); | |
664 | |
665 // This method controls how a collector handles one or more | |
666 // of its generations being fully allocated. | |
667 virtual HeapWord* satisfy_failed_allocation(size_t size, | |
668 bool is_tlab); | |
669 | |
670 BarrierSet::Name barrier_set_name() { return BarrierSet::G1SATBCTLogging; } | |
671 | |
4834
6a78aa6ac1ff
7132311: G1: assert((s == klass->oop_size(this)) || (Universe::heap()->is_gc_active() && ((is_typeArray()...
brutisso
parents:
4829
diff
changeset
|
672 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
|
673 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
674 // 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
|
675 void record_collection_pause_start(double start_time_sec); |
10405 | 676 void record_collection_pause_end(double pause_time_ms, EvacuationInfo& evacuation_info); |
342 | 677 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
678 // 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
|
679 void record_full_collection_start(); |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
680 void record_full_collection_end(); |
342 | 681 |
682 // 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
|
683 void record_concurrent_mark_init_end(double mark_init_elapsed_time_ms); |
342 | 684 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
685 // Record start and end of remark. |
4013 | 686 void record_concurrent_mark_remark_start(); |
687 void record_concurrent_mark_remark_end(); | |
342 | 688 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
689 // Record start, end, and completion of cleanup. |
4013 | 690 void record_concurrent_mark_cleanup_start(); |
4095
bca17e38de00
6593758: RFE: Enhance GC ergonomics to dynamically choose ParallelGCThreads
jmasa
parents:
4090
diff
changeset
|
691 void record_concurrent_mark_cleanup_end(int no_of_gc_threads); |
4013 | 692 void record_concurrent_mark_cleanup_completed(); |
342 | 693 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
694 // 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
|
695 // 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
|
696 void record_heap_size_info_at_start(bool full); |
342 | 697 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
698 // 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
|
699 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
|
700 void print_detailed_heap_transition(bool full = false); |
342 | 701 |
10098
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
702 void record_stop_world_start(); |
71013d764f6e
8010780: G1: Eden occupancy/capacity output wrong after a full GC
johnc
parents:
8681
diff
changeset
|
703 void record_concurrent_pause(); |
342 | 704 |
3830
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
705 // 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
|
706 // 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
|
707 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
|
708 _bytes_copied_during_gc += bytes; |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
709 } |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
710 |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
711 // 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
|
712 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
|
713 return _bytes_copied_during_gc; |
f44782f04dd4
7039627: G1: avoid BOT updates for survivor allocations and dirty survivor regions incrementally
tonyp
parents:
3823
diff
changeset
|
714 } |
342 | 715 |
5972
9a9bb0010c91
7156764: Remove unused size parameter from some CollectedHeap methods
brutisso
parents:
4912
diff
changeset
|
716 // Determine whether there are candidate regions so that the |
9a9bb0010c91
7156764: Remove unused size parameter from some CollectedHeap methods
brutisso
parents:
4912
diff
changeset
|
717 // 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
|
718 // 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
|
719 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
|
720 const char* false_action_str); |
a9647476d1a4
7132029: G1: mixed GC phase lasts for longer than it should
tonyp
parents:
4837
diff
changeset
|
721 |
342 | 722 // Choose a new collection set. Marks the chosen regions as being |
723 // "in_collection_set", and links them together. The head and number of | |
724 // the collection set are available via access methods. | |
10405 | 725 void finalize_cset(double target_pause_time_ms, EvacuationInfo& evacuation_info); |
342 | 726 |
727 // The head of the list (via "next_in_collection_set()") representing the | |
728 // current collection set. | |
729 HeapRegion* collection_set() { return _collection_set; } | |
730 | |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
731 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
|
732 |
4090
a88de71c4e3a
7097002: G1: remove a lot of unused / redundant code from the G1CollectorPolicy class
tonyp
parents:
4023
diff
changeset
|
733 // 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
|
734 void add_old_region_to_cset(HeapRegion* hr); |
342 | 735 |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
736 // Incremental CSet Support |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
737 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
738 // 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
|
739 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
|
740 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
741 // 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
|
742 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
|
743 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
744 // 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
|
745 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
|
746 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
747 // 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
|
748 // before we can use them. |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
749 void finalize_incremental_cset_building(); |
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
750 |
1394
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
751 void clear_incremental_cset() { |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
752 _inc_cset_head = NULL; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
753 _inc_cset_tail = NULL; |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
754 } |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
755 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
756 // 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
|
757 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
|
758 |
4727
67fdcb391461
7119027: G1: use atomics to update RS length / predict time of inc CSet
tonyp
parents:
4710
diff
changeset
|
759 // 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
|
760 // 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
|
761 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
|
762 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
763 // 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
|
764 // 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
|
765 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
|
766 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
767 private: |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
768 // 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
|
769 // (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
|
770 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
|
771 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
772 public: |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
773 // 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
|
774 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
|
775 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
776 // 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
|
777 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
|
778 |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
779 #ifndef PRODUCT |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
780 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
|
781 #endif // !PRODUCT |
1316cec51b4d
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
1359
diff
changeset
|
782 |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
783 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
|
784 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
|
785 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
|
786 |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
787 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
|
788 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
|
789 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
|
790 |
1656
4e5661ba9d98
6944166: G1: explicit GCs are not always handled correctly
tonyp
parents:
1611
diff
changeset
|
791 // 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
|
792 // 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
|
793 // 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
|
794 // 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
|
795 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
|
796 |
1359
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
797 // 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
|
798 // 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
|
799 // 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
|
800 // 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
|
801 // 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
|
802 // the initial-mark work and start a marking cycle. |
23b1b27ac76c
6909756: G1: guarantee(G1CollectedHeap::heap()->mark_in_progress(),"Precondition.")
tonyp
parents:
1356
diff
changeset
|
803 void decide_on_conc_mark_initiation(); |
342 | 804 |
805 // If an expansion would be appropriate, because recent GC overhead had | |
806 // exceeded the desired limit, return an amount to expand by. | |
20655
b840813adfcc
8065305: Make it possible to extend the G1CollectorPolicy
jwilhelm
parents:
20481
diff
changeset
|
807 virtual size_t expansion_amount(); |
342 | 808 |
809 // Print tracing information. | |
810 void print_tracing_info() const; | |
811 | |
812 // Print stats on young survival ratio | |
813 void print_yg_surv_rate_info() const; | |
814 | |
545 | 815 void finished_recalculating_age_indexes(bool is_survivors) { |
816 if (is_survivors) { | |
817 _survivor_surv_rate_group->finished_recalculating_age_indexes(); | |
818 } else { | |
819 _short_lived_surv_rate_group->finished_recalculating_age_indexes(); | |
820 } | |
342 | 821 // do that for any other surv rate groups |
822 } | |
823 | |
17727 | 824 size_t young_list_target_length() const { return _young_list_target_length; } |
825 | |
20655
b840813adfcc
8065305: Make it possible to extend the G1CollectorPolicy
jwilhelm
parents:
20481
diff
changeset
|
826 bool is_young_list_full(); |
1991
016a3628c885
6994056: G1: when GC locker is active, extend the Eden instead of allocating into the old gen
tonyp
parents:
1973
diff
changeset
|
827 |
20655
b840813adfcc
8065305: Make it possible to extend the G1CollectorPolicy
jwilhelm
parents:
20481
diff
changeset
|
828 bool can_expand_young_list(); |
1973 | 829 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
830 uint young_list_max_length() { |
3980
8229bd737950
7075646: G1: fix inconsistencies in the monitoring data
tonyp
parents:
3979
diff
changeset
|
831 return _young_list_max_length; |
8229bd737950
7075646: G1: fix inconsistencies in the monitoring data
tonyp
parents:
3979
diff
changeset
|
832 } |
8229bd737950
7075646: G1: fix inconsistencies in the monitoring data
tonyp
parents:
3979
diff
changeset
|
833 |
4710 | 834 bool gcs_are_young() { |
835 return _gcs_are_young; | |
342 | 836 } |
4710 | 837 void set_gcs_are_young(bool gcs_are_young) { |
838 _gcs_are_young = gcs_are_young; | |
342 | 839 } |
840 | |
841 bool adaptive_young_list_length() { | |
4729
1cbe7978b021
7113021: G1: automatically enable young gen size auto-tuning when -Xms==-Xmx
brutisso
parents:
4727
diff
changeset
|
842 return _young_gen_sizer->adaptive_young_list_length(); |
342 | 843 } |
844 | |
4013 | 845 private: |
342 | 846 // |
847 // Survivor regions policy. | |
848 // | |
849 | |
850 // Current tenuring threshold, set to 0 if the collector reaches the | |
6818 | 851 // maximum amount of survivors regions. |
852 uint _tenuring_threshold; | |
342 | 853 |
545 | 854 // 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
|
855 uint _max_survivor_regions; |
545 | 856 |
3764
053d84a76d3d
7032531: G1: enhance GC logging to include more accurate eden / survivor size transitions
tonyp
parents:
2430
diff
changeset
|
857 // 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
|
858 // 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
|
859 // 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
|
860 |
48391ab0687e
8010738: G1: Output for full GCs with +PrintGCDetails should contain perm gen size/meta data change info
johnc
parents:
10098
diff
changeset
|
861 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
|
862 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
|
863 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
|
864 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
|
865 |
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 _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
|
867 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
|
868 |
6818 | 869 // 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
|
870 uint _recorded_survivor_regions; |
545 | 871 // List of survivor regions. |
872 HeapRegion* _recorded_survivor_head; | |
873 HeapRegion* _recorded_survivor_tail; | |
874 | |
875 ageTable _survivors_age_table; | |
876 | |
342 | 877 public: |
10405 | 878 uint tenuring_threshold() const { return _tenuring_threshold; } |
342 | 879 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
880 static const uint REGIONS_UNLIMITED = (uint) -1; |
545 | 881 |
22901
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
882 uint max_regions(InCSetState dest) { |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
883 switch (dest.value()) { |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
884 case InCSetState::Young: |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
885 return _max_survivor_regions; |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
886 case InCSetState::Old: |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
887 return REGIONS_UNLIMITED; |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
888 default: |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
889 assert(false, err_msg("Unknown dest state: " CSETSTATE_FORMAT, dest.value())); |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
890 break; |
342 | 891 } |
22901
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
892 // keep some compilers happy |
c132be0fb74d
8060025: Object copy time regressions after JDK-8031323 and JDK-8057536
tschatzl
parents:
20655
diff
changeset
|
893 return 0; |
342 | 894 } |
895 | |
896 void note_start_adding_survivor_regions() { | |
897 _survivor_surv_rate_group->start_adding_regions(); | |
898 } | |
899 | |
900 void note_stop_adding_survivor_regions() { | |
901 _survivor_surv_rate_group->stop_adding_regions(); | |
902 } | |
545 | 903 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
904 void record_survivor_regions(uint regions, |
545 | 905 HeapRegion* head, |
906 HeapRegion* tail) { | |
907 _recorded_survivor_regions = regions; | |
908 _recorded_survivor_head = head; | |
909 _recorded_survivor_tail = tail; | |
910 } | |
911 | |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
912 uint recorded_survivor_regions() { |
838
0316eac49d5a
6855834: G1: minimize the output when -XX:+PrintHeapAtGC is set
tonyp
parents:
794
diff
changeset
|
913 return _recorded_survivor_regions; |
0316eac49d5a
6855834: G1: minimize the output when -XX:+PrintHeapAtGC is set
tonyp
parents:
794
diff
changeset
|
914 } |
0316eac49d5a
6855834: G1: minimize the output when -XX:+PrintHeapAtGC is set
tonyp
parents:
794
diff
changeset
|
915 |
6010
720b6a76dd9d
7157073: G1: type change size_t -> uint for region counts / indexes
tonyp
parents:
5988
diff
changeset
|
916 void record_thread_age_table(ageTable* age_table) { |
545 | 917 _survivors_age_table.merge_par(age_table); |
918 } | |
919 | |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
920 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
|
921 |
545 | 922 // Calculates survivor space parameters. |
3919
4f41766176cf
7084509: G1: fix inconsistencies and mistakes in the young list target length calculations
tonyp
parents:
3914
diff
changeset
|
923 void update_survivors_policy(); |
545 | 924 |
13060
8f07aa079343
8016309: assert(eden_size > 0 && survivor_size > 0) failed: just checking
jwilhelm
parents:
13059
diff
changeset
|
925 virtual void post_heap_initialize(); |
342 | 926 }; |
927 | |
928 // This should move to some place more general... | |
929 | |
930 // If we have "n" measurements, and we've kept track of their "sum" and the | |
931 // "sum_of_squares" of the measurements, this returns the variance of the | |
932 // sequence. | |
933 inline double variance(int n, double sum_of_squares, double sum) { | |
934 double n_d = (double)n; | |
935 double avg = sum/n_d; | |
936 return (sum_of_squares - 2.0 * avg * sum + n_d * avg * avg) / n_d; | |
937 } | |
938 | |
1972 | 939 #endif // SHARE_VM_GC_IMPLEMENTATION_G1_G1COLLECTORPOLICY_HPP |