src/hotspot/share/gc/g1/g1Policy.hpp
author tschatzl
Fri, 29 Nov 2019 10:20:14 +0100
changeset 59319 9ee940f1de90
parent 59198 92c98aa0f801
permissions -rw-r--r--
8227739: Merge cost predictions for scanning cards and log buffer entries Summary: Revamp the cost predictions for the changes in JDK-8200545 and JDK-8213108. Reviewed-by: sjohanss, kbarrett
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     1
/*
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53116
diff changeset
     2
 * Copyright (c) 2016, 2019, Oracle and/or its affiliates. All rights reserved.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     4
 *
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     7
 * published by the Free Software Foundation.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     8
 *
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
     9
 * This code is distributed in the hope that it will be useful, but WITHOUT
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    10
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    11
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    12
 * version 2 for more details (a copy is included in the LICENSE file that
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    13
 * accompanied this code).
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    14
 *
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    15
 * You should have received a copy of the GNU General Public License version
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    16
 * 2 along with this work; if not, write to the Free Software Foundation,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    17
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    18
 *
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    19
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    20
 * or visit www.oracle.com if you need additional information or have any
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    21
 * questions.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    22
 *
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    23
 */
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    24
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53116
diff changeset
    25
#ifndef SHARE_GC_G1_G1POLICY_HPP
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53116
diff changeset
    26
#define SHARE_GC_G1_G1POLICY_HPP
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    27
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    28
#include "gc/g1/g1CollectorState.hpp"
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    29
#include "gc/g1/g1GCPhaseTimes.hpp"
54843
25c329958c70 8200545: Improve filter for enqueued deferred cards
tschatzl
parents: 54678
diff changeset
    30
#include "gc/g1/g1HeapRegionAttr.hpp"
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    31
#include "gc/g1/g1InitialMarkToMixedTimeTracker.hpp"
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    32
#include "gc/g1/g1MMUTracker.hpp"
49607
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
    33
#include "gc/g1/g1RemSetTrackingPolicy.hpp"
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    34
#include "gc/g1/g1Predictions.hpp"
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    35
#include "gc/g1/g1YoungGenSizer.hpp"
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    36
#include "gc/shared/gcCause.hpp"
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    37
#include "utilities/pair.hpp"
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    38
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
    39
// A G1Policy makes policy decisions that determine the
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
    40
// characteristics of the collector.  Examples include:
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
    41
//   * choice of collection set.
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
    42
//   * when to collect.
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
    43
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    44
class HeapRegion;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    45
class G1CollectionSet;
54465
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
    46
class G1CollectionSetCandidates;
53704
ef72c85a0534 8217328: Rename CollectionSetChooser to G1CollectionSetChooser
tschatzl
parents: 53244
diff changeset
    47
class G1CollectionSetChooser;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    48
class G1IHOPControl;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    49
class G1Analytics;
38183
cb68e4923223 8150721: Don't explicitly manage G1 young regions in YoungList
mgerdin
parents: 38109
diff changeset
    50
class G1SurvivorRegions;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    51
class G1YoungGenSizer;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    52
class GCPolicyCounters;
46795
623a5e42deb6 8173335: Improve logging for j.l.ref.reference processing
sangheki
parents: 41284
diff changeset
    53
class STWGCTimer;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    54
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
    55
class G1Policy: public CHeapObj<mtGC> {
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    56
 private:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    57
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    58
  static G1IHOPControl* create_ihop_control(const G1Predictions* predictor);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    59
  // Update the IHOP control with necessary statistics.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    60
  void update_ihop_prediction(double mutator_time_s,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    61
                              size_t mutator_alloc_bytes,
49643
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
    62
                              size_t young_gen_size,
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
    63
                              bool this_gc_was_young_only);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    64
  void report_ihop_statistics();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    65
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    66
  G1Predictions _predictor;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    67
  G1Analytics* _analytics;
49607
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
    68
  G1RemSetTrackingPolicy _remset_tracker;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    69
  G1MMUTracker* _mmu_tracker;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    70
  G1IHOPControl* _ihop_control;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    71
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    72
  GCPolicyCounters* _policy_counters;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    73
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    74
  double _full_collection_start_sec;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    75
41284
b4276ec89d0d 8164482: [REDO] G1 does not implement millis_since_last_gc which is needed by RMI GC
jprovino
parents: 40914
diff changeset
    76
  jlong _collection_pause_end_millis;
b4276ec89d0d 8164482: [REDO] G1 does not implement millis_since_last_gc which is needed by RMI GC
jprovino
parents: 40914
diff changeset
    77
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    78
  uint _young_list_target_length;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    79
  uint _young_list_fixed_length;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    80
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    81
  // The max number of regions we can extend the eden by while the GC
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    82
  // locker is active. This should be >= _young_list_target_length;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    83
  uint _young_list_max_length;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    84
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    85
  // SurvRateGroups below must be initialized after the predictor because they
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    86
  // indirectly use it through this object passed to their constructor.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    87
  SurvRateGroup* _short_lived_surv_rate_group;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    88
  SurvRateGroup* _survivor_surv_rate_group;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    89
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    90
  double _reserve_factor;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    91
  // This will be set when the heap is expanded
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    92
  // for the first time during initialization.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    93
  uint   _reserve_regions;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    94
53116
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
    95
  G1YoungGenSizer* _young_gen_sizer;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    96
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    97
  uint _free_regions_at_end_of_collection;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    98
58797
f29ca6895893 8232777: Rename G1Policy::_max_rs_length as it is no maximum
tschatzl
parents: 58508
diff changeset
    99
  size_t _rs_length;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   100
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   101
  size_t _rs_length_prediction;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   102
58508
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   103
  size_t _pending_cards_at_gc_start;
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   104
  size_t _pending_cards_at_prev_gc_end;
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   105
  size_t _total_mutator_refined_cards;
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   106
  size_t _total_concurrent_refined_cards;
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   107
  Tickspan _total_concurrent_refinement_time;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   108
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   109
  // The amount of allocated bytes in old gen during the last mutator and the following
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   110
  // young GC phase.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   111
  size_t _bytes_allocated_in_old_since_last_gc;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   112
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   113
  G1InitialMarkToMixedTimeTracker _initial_mark_to_mixed;
49643
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   114
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   115
  bool should_update_surv_rate_group_predictors() {
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   116
    return collector_state()->in_young_only_phase() && !collector_state()->mark_or_rebuild_in_progress();
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   117
  }
55510
3e31a8beaae4 8213108: Improve work distribution during remembered set scan
tschatzl
parents: 54843
diff changeset
   118
57953
d78c910f9069 8230109: G1DirtyCardQueueSet should use card counts rather than buffer counts
kbarrett
parents: 57663
diff changeset
   119
  double logged_cards_processing_time() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   120
public:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   121
  const G1Predictions& predictor() const { return _predictor; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   122
  const G1Analytics* analytics()   const { return const_cast<const G1Analytics*>(_analytics); }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   123
49607
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
   124
  G1RemSetTrackingPolicy* remset_tracker() { return &_remset_tracker; }
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
   125
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   126
  // Add the given number of bytes to the total number of allocated bytes in the old gen.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   127
  void add_bytes_allocated_in_old_since_last_gc(size_t bytes) { _bytes_allocated_in_old_since_last_gc += bytes; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   128
38109
6503703df058 8155209: Move setting of young index in cset to G1CollectionSet
mgerdin
parents: 38106
diff changeset
   129
  void set_region_eden(HeapRegion* hr) {
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   130
    hr->set_eden();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   131
    hr->install_surv_rate_group(_short_lived_surv_rate_group);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   132
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   133
38109
6503703df058 8155209: Move setting of young index in cset to G1CollectionSet
mgerdin
parents: 38106
diff changeset
   134
  void set_region_survivor(HeapRegion* hr) {
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   135
    assert(hr->is_survivor(), "pre-condition");
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   136
    hr->install_surv_rate_group(_survivor_surv_rate_group);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   137
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   138
58797
f29ca6895893 8232777: Rename G1Policy::_max_rs_length as it is no maximum
tschatzl
parents: 58508
diff changeset
   139
  void record_rs_length(size_t rs_length) {
f29ca6895893 8232777: Rename G1Policy::_max_rs_length as it is no maximum
tschatzl
parents: 58508
diff changeset
   140
    _rs_length = rs_length;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   141
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   142
59319
9ee940f1de90 8227739: Merge cost predictions for scanning cards and log buffer entries
tschatzl
parents: 59198
diff changeset
   143
  double predict_base_elapsed_time_ms(size_t num_pending_cards) const;
9ee940f1de90 8227739: Merge cost predictions for scanning cards and log buffer entries
tschatzl
parents: 59198
diff changeset
   144
  double predict_base_elapsed_time_ms(size_t num_pending_cards,
9ee940f1de90 8227739: Merge cost predictions for scanning cards and log buffer entries
tschatzl
parents: 59198
diff changeset
   145
                                      size_t rs_length) const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   146
  size_t predict_bytes_to_copy(HeapRegion* hr) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   147
  double predict_region_elapsed_time_ms(HeapRegion* hr, bool for_young_gc) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   148
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   149
  double predict_survivor_regions_evac_time() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   150
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   151
  void cset_regions_freed() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   152
    bool update = should_update_surv_rate_group_predictors();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   153
38185
c432f8466c73 8155634: Clean out old logging and dead code from SurvRateGroup
mgerdin
parents: 38183
diff changeset
   154
    _short_lived_surv_rate_group->all_surviving_words_recorded(predictor(), update);
c432f8466c73 8155634: Clean out old logging and dead code from SurvRateGroup
mgerdin
parents: 38183
diff changeset
   155
    _survivor_surv_rate_group->all_surviving_words_recorded(predictor(), update);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   156
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   157
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   158
  G1MMUTracker* mmu_tracker() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   159
    return _mmu_tracker;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   160
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   161
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   162
  const G1MMUTracker* mmu_tracker() const {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   163
    return _mmu_tracker;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   164
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   165
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   166
  double max_pause_time_ms() const {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   167
    return _mmu_tracker->max_gc_time() * 1000.0;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   168
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   169
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   170
  double predict_yg_surv_rate(int age, SurvRateGroup* surv_rate_group) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   171
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   172
  double predict_yg_surv_rate(int age) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   173
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   174
  double accum_yg_surv_rate_pred(int age) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   175
49472
982acd800812 8199027: Make protected members private in G1Policy
ehelin
parents: 49375
diff changeset
   176
private:
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   177
  G1CollectionSet* _collection_set;
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   178
  double average_time_ms(G1GCPhaseTimes::GCParPhases phase) const;
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   179
  double other_time_ms(double pause_time_ms) const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   180
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   181
  double young_other_time_ms() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   182
  double non_young_other_time_ms() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   183
  double constant_other_time_ms(double pause_time_ms) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   184
53704
ef72c85a0534 8217328: Rename CollectionSetChooser to G1CollectionSetChooser
tschatzl
parents: 53244
diff changeset
   185
  G1CollectionSetChooser* cset_chooser() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   186
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   187
  // Stash a pointer to the g1 heap.
49806
2d62570a615c 8200426: Make G1 code use _g1h members
tschatzl
parents: 49743
diff changeset
   188
  G1CollectedHeap* _g1h;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   189
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   190
  G1GCPhaseTimes* _phase_times;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   191
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   192
  // This set of variables tracks the collector efficiency, in order to
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   193
  // determine whether we should initiate a new marking.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   194
  double _mark_remark_start_sec;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   195
  double _mark_cleanup_start_sec;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   196
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   197
  // Updates the internal young list maximum and target lengths. Returns the
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   198
  // unbounded young list target length. If no rs_length parameter is passed,
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   199
  // predict the RS length using the prediction model, otherwise use the
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   200
  // given rs_length as the prediction.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   201
  uint update_young_list_max_and_target_length();
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   202
  uint update_young_list_max_and_target_length(size_t rs_length);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   203
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   204
  // Update the young list target length either by setting it to the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   205
  // desired fixed value or by calculating it using G1's pause
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   206
  // prediction model.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   207
  // Returns the unbounded young list target length.
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   208
  uint update_young_list_target_length(size_t rs_length);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   209
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   210
  // Calculate and return the minimum desired young list target
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   211
  // length. This is the minimum desired young list length according
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   212
  // to the user's inputs.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   213
  uint calculate_young_list_desired_min_length(uint base_min_length) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   214
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   215
  // Calculate and return the maximum desired young list target
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   216
  // length. This is the maximum desired young list length according
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   217
  // to the user's inputs.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   218
  uint calculate_young_list_desired_max_length() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   219
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   220
  // Calculate and return the maximum young list target length that
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   221
  // can fit into the pause time goal. The parameters are: rs_length
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   222
  // represent the prediction of how large the young RSet lengths will
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   223
  // be, base_min_length is the already existing number of regions in
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   224
  // the young list, min_length and max_length are the desired min and
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   225
  // max young list length according to the user's inputs.
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   226
  uint calculate_young_list_target_length(size_t rs_length,
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   227
                                          uint base_min_length,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   228
                                          uint desired_min_length,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   229
                                          uint desired_max_length) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   230
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   231
  // Result of the bounded_young_list_target_length() method, containing both the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   232
  // bounded as well as the unbounded young list target lengths in this order.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   233
  typedef Pair<uint, uint, StackObj> YoungTargetLengths;
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   234
  YoungTargetLengths young_list_target_lengths(size_t rs_length) const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   235
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   236
  void update_rs_length_prediction();
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   237
  void update_rs_length_prediction(size_t prediction);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   238
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   239
  // Check whether a given young length (young_length) fits into the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   240
  // given target pause time and whether the prediction for the amount
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   241
  // of objects to be copied for the given length will fit into the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   242
  // given free space (expressed by base_free_regions).  It is used by
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   243
  // calculate_young_list_target_length().
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   244
  bool predict_will_fit(uint young_length, double base_time_ms,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   245
                        uint base_free_regions, double target_pause_time_ms) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   246
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   247
public:
58508
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   248
  size_t pending_cards_at_gc_start() const { return _pending_cards_at_gc_start; }
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   249
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   250
  // Calculate the minimum number of old regions we'll add to the CSet
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   251
  // during a mixed GC.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   252
  uint calc_min_old_cset_length() const;
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   253
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   254
  // Calculate the maximum number of old regions we'll add to the CSet
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   255
  // during a mixed GC.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   256
  uint calc_max_old_cset_length() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   257
47679
4cfcb7be4984 8189666: Replace various inlined percentage calculations with global percent_of()
tschatzl
parents: 47216
diff changeset
   258
  // Returns the given amount of reclaimable bytes (that represents
4cfcb7be4984 8189666: Replace various inlined percentage calculations with global percent_of()
tschatzl
parents: 47216
diff changeset
   259
  // the amount of reclaimable space still to be collected) as a
4cfcb7be4984 8189666: Replace various inlined percentage calculations with global percent_of()
tschatzl
parents: 47216
diff changeset
   260
  // percentage of the current heap capacity.
47681
149745044e48 8189729: Change _perc suffixes in identifiers to _percent
tschatzl
parents: 47679
diff changeset
   261
  double reclaimable_bytes_percent(size_t reclaimable_bytes) const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   262
41284
b4276ec89d0d 8164482: [REDO] G1 does not implement millis_since_last_gc which is needed by RMI GC
jprovino
parents: 40914
diff changeset
   263
  jlong collection_pause_end_millis() { return _collection_pause_end_millis; }
b4276ec89d0d 8164482: [REDO] G1 does not implement millis_since_last_gc which is needed by RMI GC
jprovino
parents: 40914
diff changeset
   264
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   265
private:
49607
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
   266
  void clear_collection_set_candidates();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   267
  // Sets up marking if proper conditions are met.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   268
  void maybe_start_marking();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   269
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   270
  // The kind of STW pause.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   271
  enum PauseKind {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   272
    FullGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   273
    YoungOnlyGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   274
    MixedGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   275
    LastYoungGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   276
    InitialMarkGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   277
    Cleanup,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   278
    Remark
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   279
  };
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   280
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   281
  // Calculate PauseKind from internal state.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   282
  PauseKind young_gc_pause_kind() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   283
  // Record the given STW pause with the given start and end times (in s).
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   284
  void record_pause(PauseKind kind, double start, double end);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   285
  // Indicate that we aborted marking before doing any mixed GCs.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   286
  void abort_time_to_mixed_tracking();
58508
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   287
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   288
  void record_concurrent_refinement_data(bool is_full_collection);
d6058bd73982 8231153: Improve concurrent refinement statistics
kbarrett
parents: 57953
diff changeset
   289
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   290
public:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   291
54678
93f09ca4a7f8 8198505: Remove CollectorPolicy and its subclasses
stefank
parents: 54466
diff changeset
   292
  G1Policy(STWGCTimer* gc_timer);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   293
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   294
  virtual ~G1Policy();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   295
54678
93f09ca4a7f8 8198505: Remove CollectorPolicy and its subclasses
stefank
parents: 54466
diff changeset
   296
  static G1Policy* create_policy(STWGCTimer* gc_timer_stw);
53116
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   297
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   298
  G1CollectorState* collector_state() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   299
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   300
  G1GCPhaseTimes* phase_times() const { return _phase_times; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   301
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   302
  // Check the current value of the young list RSet length and
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   303
  // compare it against the last prediction. If the current value is
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   304
  // higher, recalculate the young list target length prediction.
57663
bf8e76d86d05 8228503: Rename "rs_lengths" to "rs_length" in ergo code
tschatzl
parents: 55510
diff changeset
   305
  void revise_young_list_target_length_if_necessary(size_t rs_length);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   306
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   307
  // This should be called after the heap is resized.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   308
  void record_new_heap_size(uint new_number_of_regions);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   309
53116
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   310
  virtual void init(G1CollectedHeap* g1h, G1CollectionSet* collection_set);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   311
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   312
  void note_gc_start();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   313
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   314
  bool need_to_start_conc_mark(const char* source, size_t alloc_word_size = 0);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   315
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   316
  bool about_to_start_mixed_phase() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   317
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   318
  // Record the start and end of an evacuation pause.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   319
  void record_collection_pause_start(double start_time_sec);
59198
92c98aa0f801 8228609: G1 copy cost prediction uses used vs. actual copied byte
tschatzl
parents: 59114
diff changeset
   320
  virtual void record_collection_pause_end(double pause_time_ms);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   321
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   322
  // Record the start and end of a full collection.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   323
  void record_full_collection_start();
53116
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   324
  virtual void record_full_collection_end();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   325
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   326
  // Must currently be called while the world is stopped.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   327
  void record_concurrent_mark_init_end(double mark_init_elapsed_time_ms);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   328
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   329
  // Record start and end of remark.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   330
  void record_concurrent_mark_remark_start();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   331
  void record_concurrent_mark_remark_end();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   332
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   333
  // Record start, end, and completion of cleanup.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   334
  void record_concurrent_mark_cleanup_start();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   335
  void record_concurrent_mark_cleanup_end();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   336
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   337
  void print_phases();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   338
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   339
  bool next_gc_should_be_mixed(const char* true_action_str,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   340
                               const char* false_action_str) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   341
54465
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   342
  // Calculate and return the number of initial and optional old gen regions from
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   343
  // the given collection set candidates and the remaining time.
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   344
  void calculate_old_collection_set_regions(G1CollectionSetCandidates* candidates,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   345
                                            double time_remaining_ms,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   346
                                            uint& num_initial_regions,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   347
                                            uint& num_optional_regions);
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   348
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   349
  // Calculate the number of optional regions from the given collection set candidates,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   350
  // the remaining time and the maximum number of these regions and return the number
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   351
  // of actually selected regions in num_optional_regions.
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   352
  void calculate_optional_collection_set_regions(G1CollectionSetCandidates* candidates,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   353
                                                 uint const max_optional_regions,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   354
                                                 double time_remaining_ms,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   355
                                                 uint& num_optional_regions);
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   356
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   357
private:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   358
  // Set the state to start a concurrent marking cycle and clear
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   359
  // _initiate_conc_mark_if_possible because it has now been
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   360
  // acted on.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   361
  void initiate_conc_mark();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   362
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   363
public:
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   364
  // This sets the initiate_conc_mark_if_possible() flag to start a
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   365
  // new cycle, as long as we are not already in one. It's best if it
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   366
  // is called during a safepoint when the test whether a cycle is in
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   367
  // progress or not is stable.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   368
  bool force_initial_mark_if_outside_cycle(GCCause::Cause gc_cause);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   369
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   370
  // This is called at the very beginning of an evacuation pause (it
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   371
  // has to be the first thing that the pause does). If
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   372
  // initiate_conc_mark_if_possible() is true, and the concurrent
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   373
  // marking thread has completed its work during the previous cycle,
49643
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   374
  // it will set in_initial_mark_gc() to so that the pause does
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   375
  // the initial-mark work and start a marking cycle.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   376
  void decide_on_conc_mark_initiation();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   377
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   378
  void finished_recalculating_age_indexes(bool is_survivors) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   379
    if (is_survivors) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   380
      _survivor_surv_rate_group->finished_recalculating_age_indexes();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   381
    } else {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   382
      _short_lived_surv_rate_group->finished_recalculating_age_indexes();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   383
    }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   384
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   385
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   386
  size_t young_list_target_length() const { return _young_list_target_length; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   387
38106
da14ba2f0cd9 8155082: Refactor mutator region restriction
sjohanss
parents: 38105
diff changeset
   388
  bool should_allocate_mutator_region() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   389
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   390
  bool can_expand_young_list() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   391
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   392
  uint young_list_max_length() const {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   393
    return _young_list_max_length;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   394
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   395
54466
58751415d5f8 8222105: Add "use_" prefix to G1Policy::adaptive_young_list_length
tschatzl
parents: 54465
diff changeset
   396
  bool use_adaptive_young_list_length() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   397
38183
cb68e4923223 8150721: Don't explicitly manage G1 young regions in YoungList
mgerdin
parents: 38109
diff changeset
   398
  void transfer_survivors_to_cset(const G1SurvivorRegions* survivors);
cb68e4923223 8150721: Don't explicitly manage G1 young regions in YoungList
mgerdin
parents: 38109
diff changeset
   399
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   400
private:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   401
  //
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   402
  // Survivor regions policy.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   403
  //
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   404
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   405
  // Current tenuring threshold, set to 0 if the collector reaches the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   406
  // maximum amount of survivors regions.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   407
  uint _tenuring_threshold;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   408
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   409
  // The limit on the number of regions allocated for survivors.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   410
  uint _max_survivor_regions;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   411
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   412
  AgeTable _survivors_age_table;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   413
52975
35e2bbea78b2 8152724: Sum of eden before GC and current survivor capacity may be larger than heap size
tschatzl
parents: 52897
diff changeset
   414
  size_t desired_survivor_size(uint max_regions) const;
54465
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   415
52897
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   416
  // Fraction used when predicting how many optional regions to include in
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   417
  // the CSet. This fraction of the available time is used for optional regions,
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   418
  // the rest is used to add old regions to the normal CSet.
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   419
  double optional_prediction_fraction() { return 0.2; }
54465
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   420
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   421
public:
52897
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   422
  // Fraction used when evacuating the optional regions. This fraction of the
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   423
  // remaining time is used to choose what regions to include in the evacuation.
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   424
  double optional_evacuation_fraction() { return 0.75; }
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   425
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   426
  uint tenuring_threshold() const { return _tenuring_threshold; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   427
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   428
  uint max_survivor_regions() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   429
    return _max_survivor_regions;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   430
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   431
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   432
  void note_start_adding_survivor_regions() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   433
    _survivor_surv_rate_group->start_adding_regions();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   434
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   435
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   436
  void note_stop_adding_survivor_regions() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   437
    _survivor_surv_rate_group->stop_adding_regions();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   438
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   439
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   440
  void record_age_table(AgeTable* age_table) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   441
    _survivors_age_table.merge(age_table);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   442
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   443
40914
90c87069b39c 8164936: G1 age table printout contains contents from previous GC
tschatzl
parents: 39698
diff changeset
   444
  void print_age_table();
90c87069b39c 8164936: G1 age table printout contains contents from previous GC
tschatzl
parents: 39698
diff changeset
   445
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   446
  void update_max_gc_locker_expansion();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   447
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   448
  void update_survivors_policy();
53116
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   449
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   450
  virtual bool force_upgrade_to_full() {
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   451
    return false;
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   452
  }
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   453
};
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   454
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53116
diff changeset
   455
#endif // SHARE_GC_G1_G1POLICY_HPP