8239904: Shenandoah: accumulated penalties should not be over 100% of capacity

Reviewed-by: rkennke
This commit is contained in:
Aleksey Shipilev 2020-02-25 12:35:29 +01:00
parent 7d5652f14a
commit 98e0a704d4
2 changed files with 27 additions and 5 deletions

View File

@ -261,25 +261,45 @@ bool ShenandoahHeuristics::should_degenerate_cycle() {
return _degenerated_cycles_in_a_row <= ShenandoahFullGCThreshold; 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() { void ShenandoahHeuristics::record_success_concurrent() {
_degenerated_cycles_in_a_row = 0; _degenerated_cycles_in_a_row = 0;
_successful_cycles_in_a_row++; _successful_cycles_in_a_row++;
_gc_time_history->add(time_since_last_gc()); _gc_time_history->add(time_since_last_gc());
_gc_times_learned++; _gc_times_learned++;
_gc_time_penalties -= MIN2<size_t>(_gc_time_penalties, Concurrent_Adjust);
adjust_penalty(Concurrent_Adjust);
} }
void ShenandoahHeuristics::record_success_degenerated() { void ShenandoahHeuristics::record_success_degenerated() {
_degenerated_cycles_in_a_row++; _degenerated_cycles_in_a_row++;
_successful_cycles_in_a_row = 0; _successful_cycles_in_a_row = 0;
_gc_time_penalties += Degenerated_Penalty;
adjust_penalty(Degenerated_Penalty);
} }
void ShenandoahHeuristics::record_success_full() { void ShenandoahHeuristics::record_success_full() {
_degenerated_cycles_in_a_row = 0; _degenerated_cycles_in_a_row = 0;
_successful_cycles_in_a_row++; _successful_cycles_in_a_row++;
_gc_time_penalties += Full_Penalty;
adjust_penalty(Full_Penalty);
} }
void ShenandoahHeuristics::record_allocation_failure_gc() { void ShenandoahHeuristics::record_allocation_failure_gc() {

View File

@ -67,7 +67,7 @@ class ShenandoahCollectionSet;
class ShenandoahHeapRegion; class ShenandoahHeapRegion;
class ShenandoahHeuristics : public CHeapObj<mtGC> { class ShenandoahHeuristics : public CHeapObj<mtGC> {
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 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 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; double _last_cycle_end;
size_t _gc_times_learned; size_t _gc_times_learned;
size_t _gc_time_penalties; intx _gc_time_penalties;
TruncatedSeq* _gc_time_history; TruncatedSeq* _gc_time_history;
// There may be many threads that contend to set this flag // There may be many threads that contend to set this flag
@ -110,6 +110,8 @@ protected:
RegionData* data, size_t data_size, RegionData* data, size_t data_size,
size_t free) = 0; size_t free) = 0;
void adjust_penalty(intx step);
public: public:
ShenandoahHeuristics(); ShenandoahHeuristics();
virtual ~ShenandoahHeuristics(); virtual ~ShenandoahHeuristics();