author | tschatzl |
Wed, 25 Nov 2015 14:43:29 +0100 | |
changeset 34300 | 6075c1e0e913 |
parent 33216 | 8ecefd0f0d10 |
child 38185 | c432f8466c73 |
permissions | -rw-r--r-- |
1374 | 1 |
/* |
30764 | 2 |
* Copyright (c) 2001, 2015, Oracle and/or its affiliates. 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 |
* |
|
5547
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5350
diff
changeset
|
19 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5350
diff
changeset
|
20 |
* or visit www.oracle.com if you need additional information or have any |
f4b087cbb361
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
5350
diff
changeset
|
21 |
* questions. |
1374 | 22 |
* |
23 |
*/ |
|
24 |
||
30764 | 25 |
#ifndef SHARE_VM_GC_G1_SURVRATEGROUP_HPP |
26 |
#define SHARE_VM_GC_G1_SURVRATEGROUP_HPP |
|
7397 | 27 |
|
28 |
#include "utilities/numberSeq.hpp" |
|
29 |
||
33214
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
30 |
class G1Predictions; |
1374 | 31 |
|
13195 | 32 |
class SurvRateGroup : public CHeapObj<mtGC> { |
1374 | 33 |
private: |
33214
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
34 |
G1Predictions* _predictor; |
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
35 |
|
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
36 |
double get_new_prediction(TruncatedSeq const* seq) const; |
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
37 |
|
1374 | 38 |
const char* _name; |
39 |
||
2009 | 40 |
size_t _stats_arrays_length; |
1374 | 41 |
double* _surv_rate; |
42 |
double* _accum_surv_rate_pred; |
|
43 |
double _last_pred; |
|
44 |
TruncatedSeq** _surv_rate_pred; |
|
45 |
NumberSeq** _summary_surv_rates; |
|
46 |
size_t _summary_surv_rates_len; |
|
47 |
size_t _summary_surv_rates_max_len; |
|
48 |
||
49 |
int _all_regions_allocated; |
|
2009 | 50 |
size_t _region_num; |
1374 | 51 |
size_t _setup_seq_num; |
52 |
||
53 |
public: |
|
33214
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
54 |
SurvRateGroup(G1Predictions* predictor, |
1374 | 55 |
const char* name, |
56 |
size_t summary_surv_rates_len); |
|
2009 | 57 |
void reset(); |
1374 | 58 |
void start_adding_regions(); |
59 |
void stop_adding_regions(); |
|
60 |
void record_surviving_words(int age_in_group, size_t surv_words); |
|
33216
8ecefd0f0d10
8138750: Remove dead code in survivor rate group
tschatzl
parents:
33214
diff
changeset
|
61 |
void all_surviving_words_recorded(bool update_predictors); |
1374 | 62 |
const char* name() { return _name; } |
63 |
||
2009 | 64 |
size_t region_num() { return _region_num; } |
33214
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
65 |
double accum_surv_rate_pred(int age) const { |
1374 | 66 |
assert(age >= 0, "must be"); |
2009 | 67 |
if ((size_t)age < _stats_arrays_length) |
1374 | 68 |
return _accum_surv_rate_pred[age]; |
69 |
else { |
|
2009 | 70 |
double diff = (double) (age - _stats_arrays_length + 1); |
71 |
return _accum_surv_rate_pred[_stats_arrays_length-1] + diff * _last_pred; |
|
1374 | 72 |
} |
73 |
} |
|
74 |
||
33214
5a00fba36171
8137082: Factor out G1 prediction code from G1CollectorPolicy and clean up
tschatzl
parents:
30764
diff
changeset
|
75 |
TruncatedSeq* get_seq(size_t age) const { |
1374 | 76 |
if (age >= _setup_seq_num) { |
77 |
guarantee( _setup_seq_num > 0, "invariant" ); |
|
78 |
age = _setup_seq_num-1; |
|
79 |
} |
|
80 |
TruncatedSeq* seq = _surv_rate_pred[age]; |
|
81 |
guarantee( seq != NULL, "invariant" ); |
|
82 |
return seq; |
|
83 |
} |
|
84 |
||
85 |
int next_age_index(); |
|
86 |
int age_in_group(int age_index) { |
|
5350
cccf0925702e
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
2105
diff
changeset
|
87 |
int ret = (int) (_all_regions_allocated - age_index); |
1374 | 88 |
assert( ret >= 0, "invariant" ); |
89 |
return ret; |
|
90 |
} |
|
91 |
void finished_recalculating_age_indexes() { |
|
5350
cccf0925702e
6819061: G1: eliminate serial Other times that are proportional to the collection set length
johnc
parents:
2105
diff
changeset
|
92 |
_all_regions_allocated = 0; |
1374 | 93 |
} |
94 |
||
95 |
#ifndef PRODUCT |
|
96 |
void print(); |
|
97 |
void print_surv_rate_summary(); |
|
98 |
#endif // PRODUCT |
|
99 |
}; |
|
7397 | 100 |
|
30764 | 101 |
#endif // SHARE_VM_GC_G1_SURVRATEGROUP_HPP |