Commit 49270565 authored by bak@chromium.org's avatar bak@chromium.org

Changed the expansion of new space to depend on how much has survived scavenge.

This replaces the fixed expansion policy based on number of scavenges.
Increased the max new space size to 8MB (only reserved space).
Increased the defalt new space size to 512KB.

Review URL: http://codereview.chromium.org/125046

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@2151 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 63dced13
...@@ -79,9 +79,9 @@ int Heap::amount_of_external_allocated_memory_at_last_global_gc_ = 0; ...@@ -79,9 +79,9 @@ int Heap::amount_of_external_allocated_memory_at_last_global_gc_ = 0;
// semispace_size_ should be a power of 2 and old_generation_size_ should be // semispace_size_ should be a power of 2 and old_generation_size_ should be
// a multiple of Page::kPageSize. // a multiple of Page::kPageSize.
int Heap::semispace_size_ = 2*MB; int Heap::semispace_size_ = 8*MB;
int Heap::old_generation_size_ = 512*MB; int Heap::old_generation_size_ = 512*MB;
int Heap::initial_semispace_size_ = 256*KB; int Heap::initial_semispace_size_ = 512*KB;
GCCallback Heap::global_gc_prologue_callback_ = NULL; GCCallback Heap::global_gc_prologue_callback_ = NULL;
GCCallback Heap::global_gc_epilogue_callback_ = NULL; GCCallback Heap::global_gc_epilogue_callback_ = NULL;
...@@ -90,9 +90,8 @@ GCCallback Heap::global_gc_epilogue_callback_ = NULL; ...@@ -90,9 +90,8 @@ GCCallback Heap::global_gc_epilogue_callback_ = NULL;
// ConfigureHeap. // ConfigureHeap.
int Heap::young_generation_size_ = 0; // Will be 2 * semispace_size_. int Heap::young_generation_size_ = 0; // Will be 2 * semispace_size_.
// Double the new space after this many scavenge collections. int Heap::survived_since_last_expansion_ = 0;
int Heap::new_space_growth_limit_ = 8;
int Heap::scavenge_count_ = 0;
Heap::HeapState Heap::gc_state_ = NOT_IN_GC; Heap::HeapState Heap::gc_state_ = NOT_IN_GC;
int Heap::mc_count_ = 0; int Heap::mc_count_ = 0;
...@@ -421,7 +420,7 @@ void Heap::PerformGarbageCollection(AllocationSpace space, ...@@ -421,7 +420,7 @@ void Heap::PerformGarbageCollection(AllocationSpace space,
old_gen_promotion_limit_ = old_gen_promotion_limit_ =
old_gen_size + Max(kMinimumPromotionLimit, old_gen_size / 3); old_gen_size + Max(kMinimumPromotionLimit, old_gen_size / 3);
old_gen_allocation_limit_ = old_gen_allocation_limit_ =
old_gen_size + Max(kMinimumAllocationLimit, old_gen_size / 3); old_gen_size + Max(kMinimumAllocationLimit, old_gen_size / 2);
old_gen_exhausted_ = false; old_gen_exhausted_ = false;
// If we have used the mark-compact collector to collect the new // If we have used the mark-compact collector to collect the new
...@@ -624,16 +623,17 @@ void Heap::Scavenge() { ...@@ -624,16 +623,17 @@ void Heap::Scavenge() {
// Implements Cheney's copying algorithm // Implements Cheney's copying algorithm
LOG(ResourceEvent("scavenge", "begin")); LOG(ResourceEvent("scavenge", "begin"));
scavenge_count_++; // Used for updating survived_since_last_expansion_ at function end.
int survived_watermark = PromotedSpaceSize();
if (new_space_.Capacity() < new_space_.MaximumCapacity() && if (new_space_.Capacity() < new_space_.MaximumCapacity() &&
scavenge_count_ > new_space_growth_limit_) { survived_since_last_expansion_ > new_space_.Capacity()) {
// Double the size of the new space, and double the limit. The next // Double the size of new space if there is room to grow and enough
// doubling attempt will occur after the current new_space_growth_limit_ // data has survived scavenge since the last expansion.
// more collections.
// TODO(1240712): NewSpace::Double has a return value which is // TODO(1240712): NewSpace::Double has a return value which is
// ignored here. // ignored here.
new_space_.Double(); new_space_.Double();
new_space_growth_limit_ *= 2; survived_since_last_expansion_ = 0;
} }
// Flip the semispaces. After flipping, to space is empty, from space has // Flip the semispaces. After flipping, to space is empty, from space has
...@@ -737,6 +737,10 @@ void Heap::Scavenge() { ...@@ -737,6 +737,10 @@ void Heap::Scavenge() {
// Set age mark. // Set age mark.
new_space_.set_age_mark(new_space_.top()); new_space_.set_age_mark(new_space_.top());
// Update how much has survived scavenge.
survived_since_last_expansion_ +=
(PromotedSpaceSize() - survived_watermark) + new_space_.Size();
LOG(ResourceEvent("scavenge", "end")); LOG(ResourceEvent("scavenge", "end"));
gc_state_ = NOT_IN_GC; gc_state_ = NOT_IN_GC;
......
...@@ -827,8 +827,9 @@ class Heap : public AllStatic { ...@@ -827,8 +827,9 @@ class Heap : public AllStatic {
static int young_generation_size_; static int young_generation_size_;
static int old_generation_size_; static int old_generation_size_;
static int new_space_growth_limit_; // For keeping track of how much data has survived
static int scavenge_count_; // scavenge since last new space expansion.
static int survived_since_last_expansion_;
static int always_allocate_scope_depth_; static int always_allocate_scope_depth_;
static bool context_disposed_pending_; static bool context_disposed_pending_;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment