Print this page
G1: Use SoftMaxHeapSize to guide GC heuristics


  28 #include "memory/allocation.hpp"
  29 
  30 class G1Analytics;
  31 class G1CollectedHeap;
  32 
  33 class G1HeapSizingPolicy: public CHeapObj<mtGC> {
  34   // MinOverThresholdForGrowth must be less than the number of recorded
  35   // pause times in G1Analytics, representing the minimum number of pause
  36   // time ratios that exceed GCTimeRatio before a heap expansion will be triggered.
  37   const static uint MinOverThresholdForGrowth = 4;
  38 
  39   const G1CollectedHeap* _g1h;
  40   const G1Analytics* _analytics;
  41 
  42   const uint _num_prev_pauses_for_heuristics;
  43   // Ratio check data for determining if heap growth is necessary.
  44   uint _ratio_over_threshold_count;
  45   double _ratio_over_threshold_sum;
  46   uint _pauses_since_start;
  47 



  48 
  49 protected:
  50   G1HeapSizingPolicy(const G1CollectedHeap* g1h, const G1Analytics* analytics);
  51 public:
  52 
  53   // If an expansion would be appropriate, because recent GC overhead had
  54   // exceeded the desired limit, return an amount to expand by.
  55   virtual size_t expansion_amount();


  56 
  57   // Clear ratio tracking data used by expansion_amount().
  58   void clear_ratio_check_data();
  59 
  60   static G1HeapSizingPolicy* create(const G1CollectedHeap* g1h, const G1Analytics* analytics);
  61 };
  62 
  63 #endif // SHARE_GC_G1_G1HEAPSIZINGPOLICY_HPP


  28 #include "memory/allocation.hpp"
  29 
  30 class G1Analytics;
  31 class G1CollectedHeap;
  32 
  33 class G1HeapSizingPolicy: public CHeapObj<mtGC> {
  34   // MinOverThresholdForGrowth must be less than the number of recorded
  35   // pause times in G1Analytics, representing the minimum number of pause
  36   // time ratios that exceed GCTimeRatio before a heap expansion will be triggered.
  37   const static uint MinOverThresholdForGrowth = 4;
  38 
  39   const G1CollectedHeap* _g1h;
  40   const G1Analytics* _analytics;
  41 
  42   const uint _num_prev_pauses_for_heuristics;
  43   // Ratio check data for determining if heap growth is necessary.
  44   uint _ratio_over_threshold_count;
  45   double _ratio_over_threshold_sum;
  46   uint _pauses_since_start;
  47 
  48   // Mininum heap capacity after last concurrent mark
  49   size_t _minimum_desired_bytes_after_last_cm;
  50 
  51 
  52 protected:
  53   G1HeapSizingPolicy(const G1CollectedHeap* g1h, const G1Analytics* analytics);
  54 public:
  55 
  56   // If an expansion would be appropriate, because recent GC overhead had
  57   // exceeded the desired limit, return an amount to expand by.
  58   virtual size_t expansion_amount_after_young_collection();
  59   virtual size_t expansion_amount_after_concurrent_mark();
  60   virtual size_t shrink_amount_after_mixed_collections();
  61 
  62   // Clear ratio tracking data used by expansion_amount().
  63   void clear_ratio_check_data();
  64 
  65   static G1HeapSizingPolicy* create(const G1CollectedHeap* g1h, const G1Analytics* analytics);
  66 };
  67 
  68 #endif // SHARE_GC_G1_G1HEAPSIZINGPOLICY_HPP