author | tonyp |
Thu, 30 Jul 2009 16:22:58 -0400 | |
changeset 3697 | ea9211aa02f5 |
parent 3695 | 421cfcc8843c |
child 4099 | 77d31ea5a439 |
permissions | -rw-r--r-- |
1374 | 1 |
/* |
2105 | 2 |
* Copyright 2001-2009 Sun Microsystems, Inc. All Rights Reserved. |
1374 | 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 |
* |
|
19 |
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, |
|
20 |
* CA 95054 USA or visit www.sun.com if you need additional information or |
|
21 |
* have any questions. |
|
22 |
* |
|
23 |
*/ |
|
24 |
||
25 |
// |
|
26 |
// Defines all globals flags used by the garbage-first compiler. |
|
27 |
// |
|
28 |
||
1382
fa3de4068282
6618726: Introduce -XX:+UnlockExperimentalVMOptions flag
ysr
parents:
1374
diff
changeset
|
29 |
#define G1_FLAGS(develop, develop_pd, product, product_pd, diagnostic, experimental, notproduct, manageable, product_rw) \ |
1374 | 30 |
\ |
2741 | 31 |
product(intx, G1ParallelGCAllocBufferSize, 8*K, \ |
1374 | 32 |
"Size of parallel G1 allocation buffers in to-space.") \ |
33 |
\ |
|
2741 | 34 |
product(intx, G1ConfidencePercent, 50, \ |
1374 | 35 |
"Confidence level for MMU/pause predictions") \ |
36 |
\ |
|
3584
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
37 |
develop(intx, G1MarkingOverheadPercent, 0, \ |
1374 | 38 |
"Overhead of concurrent marking") \ |
39 |
\ |
|
3697
ea9211aa02f5
6819085: G1: use larger and/or user settable region size
tonyp
parents:
3695
diff
changeset
|
40 |
product(uintx, G1YoungGenSize, 0, \ |
1374 | 41 |
"Size of the G1 young generation, 0 is the adaptive policy") \ |
42 |
\ |
|
2741 | 43 |
develop(bool, G1Gen, true, \ |
1374 | 44 |
"If true, it will enable the generational G1") \ |
45 |
\ |
|
3584
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
46 |
develop(intx, G1GCPercent, 10, \ |
1374 | 47 |
"The desired percent time spent on GC") \ |
48 |
\ |
|
2741 | 49 |
develop(intx, G1PolicyVerbose, 0, \ |
1374 | 50 |
"The verbosity level on G1 policy decisions") \ |
51 |
\ |
|
52 |
develop(bool, G1UseHRIntoRS, true, \ |
|
53 |
"Determines whether the 'advanced' HR Into rem set is used.") \ |
|
54 |
\ |
|
55 |
develop(intx, G1MarkingVerboseLevel, 0, \ |
|
56 |
"Level (0-4) of verboseness of the marking code") \ |
|
57 |
\ |
|
2735
84d9ff956137
6829013: G1: set the default value of G1VerifyConcMarkPrintRechable to false
tonyp
parents:
2344
diff
changeset
|
58 |
develop(bool, G1VerifyConcMarkPrintReachable, false, \ |
1374 | 59 |
"If conc mark verification fails, print reachable objects") \ |
60 |
\ |
|
61 |
develop(bool, G1TraceMarkStackOverflow, false, \ |
|
62 |
"If true, extra debugging code for CM restart for ovflw.") \ |
|
63 |
\ |
|
64 |
develop(intx, G1PausesBtwnConcMark, -1, \ |
|
65 |
"If positive, fixed number of pauses between conc markings") \ |
|
66 |
\ |
|
2741 | 67 |
diagnostic(bool, G1SummarizeConcurrentMark, false, \ |
1374 | 68 |
"Summarize concurrent mark info") \ |
69 |
\ |
|
2741 | 70 |
diagnostic(bool, G1SummarizeRSetStats, false, \ |
1374 | 71 |
"Summarize remembered set processing info") \ |
72 |
\ |
|
3584
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
73 |
diagnostic(intx, G1SummarizeRSetStatsPeriod, 0, \ |
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
74 |
"The period (in number of GCs) at which we will generate " \ |
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
75 |
"update buffer processing info " \ |
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
76 |
"(0 means do not periodically generate this info); " \ |
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
77 |
"it also requires -XX:+G1SummarizeRSetStats") \ |
42c1f7bbffa4
6866591: G1: print update buffer processing stats more often
tonyp
parents:
3583
diff
changeset
|
78 |
\ |
2741 | 79 |
diagnostic(bool, G1SummarizeZFStats, false, \ |
1374 | 80 |
"Summarize zero-filling info") \ |
81 |
\ |
|
2741 | 82 |
develop(bool, G1TraceConcurrentRefinement, false, \ |
1374 | 83 |
"Trace G1 concurrent refinement") \ |
84 |
\ |
|
2741 | 85 |
product(intx, G1MarkStackSize, 2 * 1024 * 1024, \ |
1374 | 86 |
"Size of the mark stack for concurrent marking.") \ |
87 |
\ |
|
2741 | 88 |
product(intx, G1MarkRegionStackSize, 1024 * 1024, \ |
1374 | 89 |
"Size of the region stack for concurrent marking.") \ |
90 |
\ |
|
91 |
develop(bool, G1ConcRefine, true, \ |
|
92 |
"If true, run concurrent rem set refinement for G1") \ |
|
93 |
\ |
|
94 |
develop(intx, G1ConcRefineTargTraversals, 4, \ |
|
95 |
"Number of concurrent refinement we try to achieve") \ |
|
96 |
\ |
|
97 |
develop(intx, G1ConcRefineInitialDelta, 4, \ |
|
98 |
"Number of heap regions of alloc ahead of starting collection " \ |
|
99 |
"pause to start concurrent refinement (initially)") \ |
|
100 |
\ |
|
2741 | 101 |
develop(bool, G1SmoothConcRefine, true, \ |
1374 | 102 |
"Attempts to smooth out the overhead of concurrent refinement") \ |
103 |
\ |
|
104 |
develop(bool, G1ConcZeroFill, true, \ |
|
105 |
"If true, run concurrent zero-filling thread") \ |
|
106 |
\ |
|
107 |
develop(intx, G1ConcZFMaxRegions, 1, \ |
|
108 |
"Stop zero-filling when # of zf'd regions reaches") \ |
|
109 |
\ |
|
110 |
product(intx, G1SteadyStateUsed, 90, \ |
|
111 |
"If non-0, try to maintain 'used' at this pct (of max)") \ |
|
112 |
\ |
|
113 |
product(intx, G1SteadyStateUsedDelta, 30, \ |
|
114 |
"If G1SteadyStateUsed is non-0, then do pause this number of " \ |
|
115 |
"of percentage points earlier if no marking is in progress.") \ |
|
116 |
\ |
|
117 |
develop(bool, G1SATBBarrierPrintNullPreVals, false, \ |
|
118 |
"If true, count frac of ptr writes with null pre-vals.") \ |
|
119 |
\ |
|
120 |
product(intx, G1SATBLogBufferSize, 1*K, \ |
|
121 |
"Number of entries in an SATB log buffer.") \ |
|
122 |
\ |
|
123 |
product(intx, G1SATBProcessCompletedThreshold, 20, \ |
|
124 |
"Number of completed buffers that triggers log processing.") \ |
|
125 |
\ |
|
126 |
develop(intx, G1ExtraRegionSurvRate, 33, \ |
|
127 |
"If the young survival rate is S, and there's room left in " \ |
|
128 |
"to-space, we will allow regions whose survival rate is up to " \ |
|
129 |
"S + (1 - S)*X, where X is this parameter (as a fraction.)") \ |
|
130 |
\ |
|
131 |
develop(intx, G1InitYoungSurvRatio, 50, \ |
|
132 |
"Expected Survival Rate for newly allocated bytes") \ |
|
133 |
\ |
|
134 |
develop(bool, G1SATBPrintStubs, false, \ |
|
135 |
"If true, print generated stubs for the SATB barrier") \ |
|
136 |
\ |
|
2741 | 137 |
product(intx, G1ExpandByPercentOfAvailable, 20, \ |
1374 | 138 |
"When expanding, % of uncommitted space to claim.") \ |
139 |
\ |
|
140 |
develop(bool, G1RSBarrierRegionFilter, true, \ |
|
141 |
"If true, generate region filtering code in RS barrier") \ |
|
142 |
\ |
|
143 |
develop(bool, G1RSBarrierNullFilter, true, \ |
|
144 |
"If true, generate null-pointer filtering code in RS barrier") \ |
|
145 |
\ |
|
146 |
develop(bool, G1PrintCTFilterStats, false, \ |
|
147 |
"If true, print stats on RS filtering effectiveness") \ |
|
148 |
\ |
|
2142
032f4652700c
6720309: G1: don't synchronously update RSet during evacuation pauses
iveresov
parents:
2009
diff
changeset
|
149 |
develop(bool, G1DeferredRSUpdate, true, \ |
032f4652700c
6720309: G1: don't synchronously update RSet during evacuation pauses
iveresov
parents:
2009
diff
changeset
|
150 |
"If true, use deferred RS updates") \ |
032f4652700c
6720309: G1: don't synchronously update RSet during evacuation pauses
iveresov
parents:
2009
diff
changeset
|
151 |
\ |
1374 | 152 |
develop(bool, G1RSLogCheckCardTable, false, \ |
153 |
"If true, verify that no dirty cards remain after RS log " \ |
|
154 |
"processing.") \ |
|
155 |
\ |
|
156 |
develop(bool, G1RSCountHisto, false, \ |
|
157 |
"If true, print a histogram of RS occupancies after each pause") \ |
|
158 |
\ |
|
159 |
develop(intx, G1PrintRegionLivenessInfo, 0, \ |
|
160 |
"When > 0, print the occupancies of the <n> best and worst" \ |
|
161 |
"regions.") \ |
|
162 |
\ |
|
163 |
develop(bool, G1PrintParCleanupStats, false, \ |
|
164 |
"When true, print extra stats about parallel cleanup.") \ |
|
165 |
\ |
|
166 |
develop(bool, G1DisablePreBarrier, false, \ |
|
167 |
"Disable generation of pre-barrier (i.e., marking barrier) ") \ |
|
168 |
\ |
|
169 |
develop(bool, G1DisablePostBarrier, false, \ |
|
170 |
"Disable generation of post-barrier (i.e., RS barrier) ") \ |
|
171 |
\ |
|
3583
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
172 |
product(intx, G1UpdateBufferSize, 256, \ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
173 |
"Size of an update buffer") \ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
174 |
\ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
175 |
product(intx, G1UpdateBufferQueueProcessingThreshold, 5, \ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
176 |
"Number of enqueued update buffers that will " \ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
177 |
"trigger concurrent processing") \ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
178 |
\ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
179 |
product(intx, G1UpdateBufferQueueMaxLength, 30, \ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
180 |
"Maximum number of enqueued update buffers before mutator " \ |
805584e16d0f
6864886: G1: rename -XX parameters related to update buffers
tonyp
parents:
3262
diff
changeset
|
181 |
"threads start processing new ones instead of enqueueing them") \ |
1374 | 182 |
\ |
183 |
develop(intx, G1ConcRSLogCacheSize, 10, \ |
|
184 |
"Log base 2 of the length of conc RS hot-card cache.") \ |
|
185 |
\ |
|
2741 | 186 |
develop(intx, G1ConcRSHotCardLimit, 4, \ |
1374 | 187 |
"The threshold that defines (>=) a hot card.") \ |
188 |
\ |
|
189 |
develop(bool, G1PrintOopAppls, false, \ |
|
190 |
"When true, print applications of closures to external locs.") \ |
|
191 |
\ |
|
2741 | 192 |
develop(intx, G1LogRSRegionEntries, 7, \ |
1374 | 193 |
"Log_2 of max number of regions for which we keep bitmaps.") \ |
194 |
\ |
|
195 |
develop(bool, G1RecordHRRSOops, false, \ |
|
196 |
"When true, record recent calls to rem set operations.") \ |
|
197 |
\ |
|
198 |
develop(bool, G1RecordHRRSEvents, false, \ |
|
199 |
"When true, record recent calls to rem set operations.") \ |
|
200 |
\ |
|
201 |
develop(intx, G1MaxVerifyFailures, -1, \ |
|
202 |
"The maximum number of verification failrues to print. " \ |
|
203 |
"-1 means print all.") \ |
|
204 |
\ |
|
205 |
develop(bool, G1ScrubRemSets, true, \ |
|
206 |
"When true, do RS scrubbing after cleanup.") \ |
|
207 |
\ |
|
208 |
develop(bool, G1RSScrubVerbose, false, \ |
|
209 |
"When true, do RS scrubbing with verbose output.") \ |
|
210 |
\ |
|
211 |
develop(bool, G1YoungSurvRateVerbose, false, \ |
|
212 |
"print out the survival rate of young regions according to age.") \ |
|
213 |
\ |
|
214 |
develop(intx, G1YoungSurvRateNumRegionsSummary, 0, \ |
|
215 |
"the number of regions for which we'll print a surv rate " \ |
|
216 |
"summary.") \ |
|
217 |
\ |
|
218 |
product(bool, G1UseScanOnlyPrefix, false, \ |
|
219 |
"It determines whether the system will calculate an optimum " \ |
|
220 |
"scan-only set.") \ |
|
221 |
\ |
|
2741 | 222 |
product(intx, G1MinReservePercent, 10, \ |
1374 | 223 |
"It determines the minimum reserve we should have in the heap " \ |
224 |
"to minimize the probability of promotion failure.") \ |
|
225 |
\ |
|
2741 | 226 |
diagnostic(bool, G1PrintRegions, false, \ |
1374 | 227 |
"If set G1 will print information on which regions are being " \ |
228 |
"allocated and which are reclaimed.") \ |
|
229 |
\ |
|
230 |
develop(bool, G1HRRSUseSparseTable, true, \ |
|
231 |
"When true, use sparse table to save space.") \ |
|
232 |
\ |
|
233 |
develop(bool, G1HRRSFlushLogBuffersOnVerify, false, \ |
|
234 |
"Forces flushing of log buffers before verification.") \ |
|
235 |
\ |
|
2741 | 236 |
product(bool, G1UseSurvivorSpaces, true, \ |
2009 | 237 |
"When true, use survivor space.") \ |
238 |
\ |
|
2741 | 239 |
develop(bool, G1FixedTenuringThreshold, false, \ |
2009 | 240 |
"When set, G1 will not adjust the tenuring threshold") \ |
241 |
\ |
|
2741 | 242 |
develop(bool, G1FixedEdenSize, false, \ |
2009 | 243 |
"When set, G1 will not allocate unused survivor space regions") \ |
244 |
\ |
|
2741 | 245 |
develop(uintx, G1FixedSurvivorSpaceSize, 0, \ |
2009 | 246 |
"If non-0 is the size of the G1 survivor space, " \ |
2250
36d1eb1bb075
6816154: G1: introduce flags to enable/disable RSet updating and scanning
tonyp
parents:
2142
diff
changeset
|
247 |
"otherwise SurvivorRatio is used to determine the size") \ |
36d1eb1bb075
6816154: G1: introduce flags to enable/disable RSet updating and scanning
tonyp
parents:
2142
diff
changeset
|
248 |
\ |
3697
ea9211aa02f5
6819085: G1: use larger and/or user settable region size
tonyp
parents:
3695
diff
changeset
|
249 |
product(uintx, G1HeapRegionSize, 0, \ |
ea9211aa02f5
6819085: G1: use larger and/or user settable region size
tonyp
parents:
3695
diff
changeset
|
250 |
"Size of the G1 regions.") \ |
ea9211aa02f5
6819085: G1: use larger and/or user settable region size
tonyp
parents:
3695
diff
changeset
|
251 |
\ |
2741 | 252 |
experimental(bool, G1ParallelRSetUpdatingEnabled, false, \ |
2250
36d1eb1bb075
6816154: G1: introduce flags to enable/disable RSet updating and scanning
tonyp
parents:
2142
diff
changeset
|
253 |
"Enables the parallelization of remembered set updating " \ |
36d1eb1bb075
6816154: G1: introduce flags to enable/disable RSet updating and scanning
tonyp
parents:
2142
diff
changeset
|
254 |
"during evacuation pauses") \ |
36d1eb1bb075
6816154: G1: introduce flags to enable/disable RSet updating and scanning
tonyp
parents:
2142
diff
changeset
|
255 |
\ |
2741 | 256 |
experimental(bool, G1ParallelRSetScanningEnabled, false, \ |
2250
36d1eb1bb075
6816154: G1: introduce flags to enable/disable RSet updating and scanning
tonyp
parents:
2142
diff
changeset
|
257 |
"Enables the parallelization of remembered set scanning " \ |
2881 | 258 |
"during evacuation pauses") \ |
259 |
\ |
|
260 |
product(uintx, G1ParallelRSetThreads, 0, \ |
|
261 |
"If non-0 is the number of parallel rem set update threads, " \ |
|
3590
a268fa66d7fb
6819077: G1: first GC thread coming late into the GC.
johnc
parents:
3584
diff
changeset
|
262 |
"otherwise the value is determined ergonomically.") \ |
a268fa66d7fb
6819077: G1: first GC thread coming late into the GC.
johnc
parents:
3584
diff
changeset
|
263 |
\ |
a268fa66d7fb
6819077: G1: first GC thread coming late into the GC.
johnc
parents:
3584
diff
changeset
|
264 |
develop(intx, G1CardCountCacheExpandThreshold, 16, \ |
a268fa66d7fb
6819077: G1: first GC thread coming late into the GC.
johnc
parents:
3584
diff
changeset
|
265 |
"Expand the card count cache if the number of collisions for " \ |
3695
421cfcc8843c
6841313: G1: dirty cards of survivor regions in parallel
apetrusenko
parents:
3691
diff
changeset
|
266 |
"a particular entry exceeds this value.") \ |
421cfcc8843c
6841313: G1: dirty cards of survivor regions in parallel
apetrusenko
parents:
3691
diff
changeset
|
267 |
\ |
421cfcc8843c
6841313: G1: dirty cards of survivor regions in parallel
apetrusenko
parents:
3691
diff
changeset
|
268 |
develop(bool, G1VerifyCTCleanup, false, \ |
421cfcc8843c
6841313: G1: dirty cards of survivor regions in parallel
apetrusenko
parents:
3691
diff
changeset
|
269 |
"Verify card table cleanup.") |
1374 | 270 |
|
1382
fa3de4068282
6618726: Introduce -XX:+UnlockExperimentalVMOptions flag
ysr
parents:
1374
diff
changeset
|
271 |
G1_FLAGS(DECLARE_DEVELOPER_FLAG, DECLARE_PD_DEVELOPER_FLAG, DECLARE_PRODUCT_FLAG, DECLARE_PD_PRODUCT_FLAG, DECLARE_DIAGNOSTIC_FLAG, DECLARE_EXPERIMENTAL_FLAG, DECLARE_NOTPRODUCT_FLAG, DECLARE_MANAGEABLE_FLAG, DECLARE_PRODUCT_RW_FLAG) |