src/hotspot/share/gc/g1/g1Policy.hpp
author tschatzl
Thu, 27 Jun 2019 11:48:32 +0200
changeset 55510 3e31a8beaae4
parent 54843 25c329958c70
child 57663 bf8e76d86d05
permissions -rw-r--r--
8213108: Improve work distribution during remembered set scan Summary: Before scanning the heap for roots into the collection set, merge them into a single remembered set (card table) and do work distribution based on location like other collectors do. Reviewed-by: kbarrett, lkorinth
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
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
    99
  size_t _max_rs_lengths;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   100
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   101
  size_t _rs_lengths_prediction;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   102
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   103
  size_t _pending_cards;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   104
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   105
  // 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
   106
  // young GC phase.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   107
  size_t _bytes_allocated_in_old_since_last_gc;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   108
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   109
  G1InitialMarkToMixedTimeTracker _initial_mark_to_mixed;
49643
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   110
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   111
  bool should_update_surv_rate_group_predictors() {
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   112
    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
   113
  }
55510
3e31a8beaae4 8213108: Improve work distribution during remembered set scan
tschatzl
parents: 54843
diff changeset
   114
3e31a8beaae4 8213108: Improve work distribution during remembered set scan
tschatzl
parents: 54843
diff changeset
   115
  double log_buffer_processing_time() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   116
public:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   117
  const G1Predictions& predictor() const { return _predictor; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   118
  const G1Analytics* analytics()   const { return const_cast<const G1Analytics*>(_analytics); }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   119
49607
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
   120
  G1RemSetTrackingPolicy* remset_tracker() { return &_remset_tracker; }
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
   121
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   122
  // 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
   123
  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
   124
38109
6503703df058 8155209: Move setting of young index in cset to G1CollectionSet
mgerdin
parents: 38106
diff changeset
   125
  void set_region_eden(HeapRegion* hr) {
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   126
    hr->set_eden();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   127
    hr->install_surv_rate_group(_short_lived_surv_rate_group);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   128
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   129
38109
6503703df058 8155209: Move setting of young index in cset to G1CollectionSet
mgerdin
parents: 38106
diff changeset
   130
  void set_region_survivor(HeapRegion* hr) {
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   131
    assert(hr->is_survivor(), "pre-condition");
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   132
    hr->install_surv_rate_group(_survivor_surv_rate_group);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   133
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   134
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   135
  void record_max_rs_lengths(size_t rs_lengths) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   136
    _max_rs_lengths = rs_lengths;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   137
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   138
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   139
  double predict_base_elapsed_time_ms(size_t pending_cards) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   140
  double predict_base_elapsed_time_ms(size_t pending_cards,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   141
                                      size_t scanned_cards) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   142
  size_t predict_bytes_to_copy(HeapRegion* hr) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   143
  double predict_region_elapsed_time_ms(HeapRegion* hr, bool for_young_gc) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   144
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   145
  double predict_survivor_regions_evac_time() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   146
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   147
  void cset_regions_freed() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   148
    bool update = should_update_surv_rate_group_predictors();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   149
38185
c432f8466c73 8155634: Clean out old logging and dead code from SurvRateGroup
mgerdin
parents: 38183
diff changeset
   150
    _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
   151
    _survivor_surv_rate_group->all_surviving_words_recorded(predictor(), update);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   152
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   153
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   154
  G1MMUTracker* mmu_tracker() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   155
    return _mmu_tracker;
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
  const G1MMUTracker* mmu_tracker() const {
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
  double max_pause_time_ms() const {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   163
    return _mmu_tracker->max_gc_time() * 1000.0;
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 predict_yg_surv_rate(int age, SurvRateGroup* surv_rate_group) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   167
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   168
  double predict_yg_surv_rate(int age) const;
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 accum_yg_surv_rate_pred(int age) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   171
49472
982acd800812 8199027: Make protected members private in G1Policy
ehelin
parents: 49375
diff changeset
   172
private:
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   173
  G1CollectionSet* _collection_set;
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   174
  double average_time_ms(G1GCPhaseTimes::GCParPhases phase) const;
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   175
  double other_time_ms(double pause_time_ms) const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   176
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   177
  double young_other_time_ms() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   178
  double non_young_other_time_ms() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   179
  double constant_other_time_ms(double pause_time_ms) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   180
53704
ef72c85a0534 8217328: Rename CollectionSetChooser to G1CollectionSetChooser
tschatzl
parents: 53244
diff changeset
   181
  G1CollectionSetChooser* cset_chooser() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   182
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   183
  // The number of bytes copied during the GC.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   184
  size_t _bytes_copied_during_gc;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   185
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   186
  // Stash a pointer to the g1 heap.
49806
2d62570a615c 8200426: Make G1 code use _g1h members
tschatzl
parents: 49743
diff changeset
   187
  G1CollectedHeap* _g1h;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   188
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   189
  G1GCPhaseTimes* _phase_times;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   190
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   191
  // This set of variables tracks the collector efficiency, in order to
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   192
  // determine whether we should initiate a new marking.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   193
  double _mark_remark_start_sec;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   194
  double _mark_cleanup_start_sec;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   195
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   196
  // Updates the internal young list maximum and target lengths. Returns the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   197
  // unbounded young list target length.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   198
  uint update_young_list_max_and_target_length();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   199
  uint update_young_list_max_and_target_length(size_t rs_lengths);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   200
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   201
  // Update the young list target length either by setting it to the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   202
  // desired fixed value or by calculating it using G1's pause
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   203
  // prediction model. If no rs_lengths parameter is passed, predict
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   204
  // the RS lengths using the prediction model, otherwise use the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   205
  // given rs_lengths as the prediction.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   206
  // Returns the unbounded young list target length.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   207
  uint update_young_list_target_length(size_t rs_lengths);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   208
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   209
  // Calculate and return the minimum desired young list target
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   210
  // length. This is the minimum desired young list length according
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   211
  // to the user's inputs.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   212
  uint calculate_young_list_desired_min_length(uint base_min_length) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   213
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   214
  // Calculate and return the maximum desired young list target
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   215
  // length. This is the maximum desired young list length according
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   216
  // to the user's inputs.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   217
  uint calculate_young_list_desired_max_length() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   218
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   219
  // Calculate and return the maximum young list target length that
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   220
  // can fit into the pause time goal. The parameters are: rs_lengths
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   221
  // represent the prediction of how large the young RSet lengths will
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   222
  // be, base_min_length is the already existing number of regions in
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   223
  // the young list, min_length and max_length are the desired min and
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   224
  // max young list length according to the user's inputs.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   225
  uint calculate_young_list_target_length(size_t rs_lengths,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   226
                                          uint base_min_length,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   227
                                          uint desired_min_length,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   228
                                          uint desired_max_length) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   229
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   230
  // Result of the bounded_young_list_target_length() method, containing both the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   231
  // bounded as well as the unbounded young list target lengths in this order.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   232
  typedef Pair<uint, uint, StackObj> YoungTargetLengths;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   233
  YoungTargetLengths young_list_target_lengths(size_t rs_lengths) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   234
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   235
  void update_rs_lengths_prediction();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   236
  void update_rs_lengths_prediction(size_t prediction);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   237
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   238
  // Check whether a given young length (young_length) fits into the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   239
  // given target pause time and whether the prediction for the amount
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   240
  // of objects to be copied for the given length will fit into the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   241
  // given free space (expressed by base_free_regions).  It is used by
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   242
  // calculate_young_list_target_length().
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   243
  bool predict_will_fit(uint young_length, double base_time_ms,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   244
                        uint base_free_regions, double target_pause_time_ms) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   245
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   246
public:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   247
  size_t pending_cards() const { return _pending_cards; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   248
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   249
  // Calculate the minimum number of old regions we'll add to the CSet
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   250
  // during a mixed GC.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   251
  uint calc_min_old_cset_length() const;
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   252
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   253
  // Calculate the maximum number of old regions we'll add to the CSet
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   254
  // during a mixed GC.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   255
  uint calc_max_old_cset_length() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   256
47679
4cfcb7be4984 8189666: Replace various inlined percentage calculations with global percent_of()
tschatzl
parents: 47216
diff changeset
   257
  // 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
   258
  // 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
   259
  // percentage of the current heap capacity.
47681
149745044e48 8189729: Change _perc suffixes in identifiers to _percent
tschatzl
parents: 47679
diff changeset
   260
  double reclaimable_bytes_percent(size_t reclaimable_bytes) const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   261
41284
b4276ec89d0d 8164482: [REDO] G1 does not implement millis_since_last_gc which is needed by RMI GC
jprovino
parents: 40914
diff changeset
   262
  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
   263
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   264
private:
49607
acffe6ff3ae7 8180415: Rebuild remembered sets during the concurrent cycle
tschatzl
parents: 49488
diff changeset
   265
  void clear_collection_set_candidates();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   266
  // Sets up marking if proper conditions are met.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   267
  void maybe_start_marking();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   268
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   269
  // The kind of STW pause.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   270
  enum PauseKind {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   271
    FullGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   272
    YoungOnlyGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   273
    MixedGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   274
    LastYoungGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   275
    InitialMarkGC,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   276
    Cleanup,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   277
    Remark
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   278
  };
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   279
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   280
  // Calculate PauseKind from internal state.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   281
  PauseKind young_gc_pause_kind() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   282
  // 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
   283
  void record_pause(PauseKind kind, double start, double end);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   284
  // Indicate that we aborted marking before doing any mixed GCs.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   285
  void abort_time_to_mixed_tracking();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   286
public:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   287
54678
93f09ca4a7f8 8198505: Remove CollectorPolicy and its subclasses
stefank
parents: 54466
diff changeset
   288
  G1Policy(STWGCTimer* gc_timer);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   289
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   290
  virtual ~G1Policy();
38076
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
  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
   293
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   294
  G1CollectorState* collector_state() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   295
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   296
  G1GCPhaseTimes* phase_times() const { return _phase_times; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   297
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   298
  // Check the current value of the young list RSet lengths and
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   299
  // compare it against the last prediction. If the current value is
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   300
  // higher, recalculate the young list target length prediction.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   301
  void revise_young_list_target_length_if_necessary(size_t rs_lengths);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   302
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   303
  // This should be called after the heap is resized.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   304
  void record_new_heap_size(uint new_number_of_regions);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   305
53116
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   306
  virtual void init(G1CollectedHeap* g1h, G1CollectionSet* collection_set);
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   307
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   308
  void note_gc_start();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   309
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   310
  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
   311
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   312
  bool about_to_start_mixed_phase() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   313
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   314
  // Record the start and end of an evacuation pause.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   315
  void record_collection_pause_start(double start_time_sec);
55510
3e31a8beaae4 8213108: Improve work distribution during remembered set scan
tschatzl
parents: 54843
diff changeset
   316
  virtual void record_collection_pause_end(double pause_time_ms, size_t heap_used_bytes_before_gc);
38076
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 a full collection.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   319
  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
   320
  virtual void record_full_collection_end();
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
  // Must currently be called while the world is stopped.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   323
  void record_concurrent_mark_init_end(double mark_init_elapsed_time_ms);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   324
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   325
  // Record start and end of remark.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   326
  void record_concurrent_mark_remark_start();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   327
  void record_concurrent_mark_remark_end();
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, end, and completion of cleanup.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   330
  void record_concurrent_mark_cleanup_start();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   331
  void record_concurrent_mark_cleanup_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
  void print_phases();
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   334
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   335
  // Record how much space we copied during a GC. This is typically
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   336
  // called when a GC alloc region is being retired.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   337
  void record_bytes_copied_during_gc(size_t bytes) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   338
    _bytes_copied_during_gc += bytes;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   339
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   340
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   341
  // The amount of space we copied during a GC.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   342
  size_t bytes_copied_during_gc() const {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   343
    return _bytes_copied_during_gc;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   344
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   345
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   346
  bool next_gc_should_be_mixed(const char* true_action_str,
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   347
                               const char* false_action_str) const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   348
54465
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   349
  // 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
   350
  // the given collection set candidates and the remaining time.
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   351
  void calculate_old_collection_set_regions(G1CollectionSetCandidates* candidates,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   352
                                            double time_remaining_ms,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   353
                                            uint& num_initial_regions,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   354
                                            uint& num_optional_regions);
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   355
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   356
  // 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
   357
  // 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
   358
  // of actually selected regions in num_optional_regions.
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   359
  void calculate_optional_collection_set_regions(G1CollectionSetCandidates* candidates,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   360
                                                 uint const max_optional_regions,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   361
                                                 double time_remaining_ms,
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   362
                                                 uint& num_optional_regions);
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   363
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   364
private:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   365
  // Set the state to start a concurrent marking cycle and clear
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   366
  // _initiate_conc_mark_if_possible because it has now been
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   367
  // acted on.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   368
  void initiate_conc_mark();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   369
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   370
public:
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   371
  // This sets the initiate_conc_mark_if_possible() flag to start a
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   372
  // 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
   373
  // is called during a safepoint when the test whether a cycle is in
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   374
  // progress or not is stable.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   375
  bool force_initial_mark_if_outside_cycle(GCCause::Cause gc_cause);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   376
49375
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   377
  // This is called at the very beginning of an evacuation pause (it
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   378
  // has to be the first thing that the pause does). If
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   379
  // initiate_conc_mark_if_possible() is true, and the concurrent
9453739cb5b0 8197852: Move G1DefaultPolicy into G1Policy
ehelin
parents: 47681
diff changeset
   380
  // marking thread has completed its work during the previous cycle,
49643
a3453bbd5418 8199742: Clean up state flags in G1CollectorState
tschatzl
parents: 49632
diff changeset
   381
  // 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
   382
  // the initial-mark work and start a marking cycle.
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   383
  void decide_on_conc_mark_initiation();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   384
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   385
  void finished_recalculating_age_indexes(bool is_survivors) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   386
    if (is_survivors) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   387
      _survivor_surv_rate_group->finished_recalculating_age_indexes();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   388
    } else {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   389
      _short_lived_surv_rate_group->finished_recalculating_age_indexes();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   390
    }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   391
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   392
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   393
  size_t young_list_target_length() const { return _young_list_target_length; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   394
38106
da14ba2f0cd9 8155082: Refactor mutator region restriction
sjohanss
parents: 38105
diff changeset
   395
  bool should_allocate_mutator_region() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   396
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   397
  bool can_expand_young_list() const;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   398
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   399
  uint young_list_max_length() const {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   400
    return _young_list_max_length;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   401
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   402
54466
58751415d5f8 8222105: Add "use_" prefix to G1Policy::adaptive_young_list_length
tschatzl
parents: 54465
diff changeset
   403
  bool use_adaptive_young_list_length() const;
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   404
38183
cb68e4923223 8150721: Don't explicitly manage G1 young regions in YoungList
mgerdin
parents: 38109
diff changeset
   405
  void transfer_survivors_to_cset(const G1SurvivorRegions* survivors);
cb68e4923223 8150721: Don't explicitly manage G1 young regions in YoungList
mgerdin
parents: 38109
diff changeset
   406
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   407
private:
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   408
  //
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   409
  // Survivor regions policy.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   410
  //
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   411
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   412
  // Current tenuring threshold, set to 0 if the collector reaches the
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   413
  // maximum amount of survivors regions.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   414
  uint _tenuring_threshold;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   415
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   416
  // The limit on the number of regions allocated for survivors.
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   417
  uint _max_survivor_regions;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   418
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   419
  AgeTable _survivors_age_table;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   420
52975
35e2bbea78b2 8152724: Sum of eden before GC and current survivor capacity may be larger than heap size
tschatzl
parents: 52897
diff changeset
   421
  size_t desired_survivor_size(uint max_regions) const;
54465
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   422
52897
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   423
  // 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
   424
  // 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
   425
  // 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
   426
  double optional_prediction_fraction() { return 0.2; }
54465
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   427
c4f16445675a 8218668: Clean up evacuation of optional collection set
tschatzl
parents: 54262
diff changeset
   428
public:
52897
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   429
  // 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
   430
  // 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
   431
  double optional_evacuation_fraction() { return 0.75; }
495c05ee2a9a 8213890: Implementation of JEP 344: Abortable Mixed Collections for G1
sjohanss
parents: 49806
diff changeset
   432
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   433
  uint tenuring_threshold() const { return _tenuring_threshold; }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   434
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   435
  uint max_survivor_regions() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   436
    return _max_survivor_regions;
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   437
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   438
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   439
  void note_start_adding_survivor_regions() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   440
    _survivor_surv_rate_group->start_adding_regions();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   441
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   442
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   443
  void note_stop_adding_survivor_regions() {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   444
    _survivor_surv_rate_group->stop_adding_regions();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   445
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   446
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   447
  void record_age_table(AgeTable* age_table) {
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   448
    _survivors_age_table.merge(age_table);
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   449
  }
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   450
40914
90c87069b39c 8164936: G1 age table printout contains contents from previous GC
tschatzl
parents: 39698
diff changeset
   451
  void print_age_table();
90c87069b39c 8164936: G1 age table printout contains contents from previous GC
tschatzl
parents: 39698
diff changeset
   452
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   453
  void update_max_gc_locker_expansion();
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   454
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   455
  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
   456
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   457
  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
   458
    return false;
bb03098c4dde 8211425: Allocation of old generation of java heap on alternate memory devices - G1 GC
sangheki
parents: 52975
diff changeset
   459
  }
38076
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   460
};
581ddcff38d9 8154753: Turn G1Policy into an interface
ehelin
parents:
diff changeset
   461
53244
9807daeb47c4 8216167: Update include guards to reflect correct directories
coleenp
parents: 53116
diff changeset
   462
#endif // SHARE_GC_G1_G1POLICY_HPP