diff --git a/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.cpp b/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.cpp index 9bc148106ee..9bab0b561c0 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.cpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.cpp @@ -261,25 +261,45 @@ bool ShenandoahHeuristics::should_degenerate_cycle() { return _degenerated_cycles_in_a_row <= ShenandoahFullGCThreshold; } +void ShenandoahHeuristics::adjust_penalty(intx step) { + assert(0 <= _gc_time_penalties && _gc_time_penalties <= 100, + "In range before adjustment: " INTX_FORMAT, _gc_time_penalties); + + intx new_val = _gc_time_penalties + step; + if (new_val < 0) { + new_val = 0; + } + if (new_val > 100) { + new_val = 100; + } + _gc_time_penalties = new_val; + + assert(0 <= _gc_time_penalties && _gc_time_penalties <= 100, + "In range after adjustment: " INTX_FORMAT, _gc_time_penalties); +} + void ShenandoahHeuristics::record_success_concurrent() { _degenerated_cycles_in_a_row = 0; _successful_cycles_in_a_row++; _gc_time_history->add(time_since_last_gc()); _gc_times_learned++; - _gc_time_penalties -= MIN2(_gc_time_penalties, Concurrent_Adjust); + + adjust_penalty(Concurrent_Adjust); } void ShenandoahHeuristics::record_success_degenerated() { _degenerated_cycles_in_a_row++; _successful_cycles_in_a_row = 0; - _gc_time_penalties += Degenerated_Penalty; + + adjust_penalty(Degenerated_Penalty); } void ShenandoahHeuristics::record_success_full() { _degenerated_cycles_in_a_row = 0; _successful_cycles_in_a_row++; - _gc_time_penalties += Full_Penalty; + + adjust_penalty(Full_Penalty); } void ShenandoahHeuristics::record_allocation_failure_gc() { diff --git a/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.hpp b/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.hpp index d04deac31a2..b653eabe633 100644 --- a/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.hpp +++ b/src/hotspot/share/gc/shenandoah/shenandoahHeuristics.hpp @@ -67,7 +67,7 @@ class ShenandoahCollectionSet; class ShenandoahHeapRegion; class ShenandoahHeuristics : public CHeapObj { - static const intx Concurrent_Adjust = 1; // recover from penalties + static const intx Concurrent_Adjust = -1; // recover from penalties static const intx Degenerated_Penalty = 10; // how much to penalize average GC duration history on Degenerated GC static const intx Full_Penalty = 20; // how much to penalize average GC duration history on Full GC @@ -93,7 +93,7 @@ protected: double _last_cycle_end; size_t _gc_times_learned; - size_t _gc_time_penalties; + intx _gc_time_penalties; TruncatedSeq* _gc_time_history; // There may be many threads that contend to set this flag @@ -110,6 +110,8 @@ protected: RegionData* data, size_t data_size, size_t free) = 0; + void adjust_penalty(intx step); + public: ShenandoahHeuristics(); virtual ~ShenandoahHeuristics();