| Index: src/heap.h
|
| diff --git a/src/heap.h b/src/heap.h
|
| index 6dc9d61117d93ff34041c093db077111a2a47ef6..4577a879ed1c34e83b368a32bd910bf81340a06e 100644
|
| --- a/src/heap.h
|
| +++ b/src/heap.h
|
| @@ -1381,6 +1381,7 @@ class Heap {
|
| void CheckNewSpaceExpansionCriteria();
|
|
|
| inline void IncrementYoungSurvivorsCounter(int survived) {
|
| + ASSERT(survived >= 0);
|
| young_survivors_after_last_gc_ = survived;
|
| survived_since_last_expansion_ += survived;
|
| }
|
| @@ -1430,6 +1431,7 @@ class Heap {
|
|
|
| // Returns the size of objects residing in non new spaces.
|
| intptr_t PromotedSpaceSize();
|
| + intptr_t PromotedSpaceSizeOfObjects();
|
|
|
| double total_regexp_code_generated() { return total_regexp_code_generated_; }
|
| void IncreaseTotalRegexpCodeGenerated(int size) {
|
| @@ -1799,11 +1801,13 @@ class Heap {
|
|
|
| enum SurvivalRateTrend { INCREASING, STABLE, DECREASING, FLUCTUATING };
|
|
|
| - static const int kYoungSurvivalRateThreshold = 90;
|
| + static const int kYoungSurvivalRateHighThreshold = 90;
|
| + static const int kYoungSurvivalRateLowThreshold = 10;
|
| static const int kYoungSurvivalRateAllowedDeviation = 15;
|
|
|
| int young_survivors_after_last_gc_;
|
| int high_survival_rate_period_length_;
|
| + int low_survival_rate_period_length_;
|
| double survival_rate_;
|
| SurvivalRateTrend previous_survival_rate_trend_;
|
| SurvivalRateTrend survival_rate_trend_;
|
| @@ -1836,18 +1840,28 @@ class Heap {
|
| }
|
| }
|
|
|
| - bool IsIncreasingSurvivalTrend() {
|
| - return survival_rate_trend() == INCREASING;
|
| + bool IsStableOrDecreasingSurvivalTrend() {
|
| + switch (survival_rate_trend()) {
|
| + case STABLE:
|
| + case DECREASING:
|
| + return true;
|
| + default:
|
| + return false;
|
| + }
|
| }
|
|
|
| - bool IsDecreasingSurvivalTrend() {
|
| - return survival_rate_trend() == DECREASING;
|
| + bool IsIncreasingSurvivalTrend() {
|
| + return survival_rate_trend() == INCREASING;
|
| }
|
|
|
| bool IsHighSurvivalRate() {
|
| return high_survival_rate_period_length_ > 0;
|
| }
|
|
|
| + bool IsLowSurvivalRate() {
|
| + return low_survival_rate_period_length_ > 0;
|
| + }
|
| +
|
| void SelectScavengingVisitorsTable();
|
|
|
| void StartIdleRound() {
|
|
|