Commit 21ea5859 authored by hpayer@chromium.org's avatar hpayer@chromium.org

Set promotion queue limit before migrating object.

BUG=
R=titzer@chromium.org

Review URL: https://codereview.chromium.org/357263004

git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@22079 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 965f7037
...@@ -1992,13 +1992,17 @@ class ScavengingVisitor : public StaticVisitorBase { ...@@ -1992,13 +1992,17 @@ class ScavengingVisitor : public StaticVisitorBase {
target = EnsureDoubleAligned(heap, target, allocation_size); target = EnsureDoubleAligned(heap, target, allocation_size);
} }
// Order is important here: Set the promotion limit before migrating
// the object. Otherwise we may end up overwriting promotion queue
// entries when we migrate the object.
heap->promotion_queue()->SetNewLimit(heap->new_space()->top());
// Order is important: slot might be inside of the target if target // Order is important: slot might be inside of the target if target
// was allocated over a dead object and slot comes from the store // was allocated over a dead object and slot comes from the store
// buffer. // buffer.
*slot = target; *slot = target;
MigrateObject(heap, object, target, object_size); MigrateObject(heap, object, target, object_size);
heap->promotion_queue()->SetNewLimit(heap->new_space()->top());
heap->IncrementSemiSpaceCopiedObjectSize(object_size); heap->IncrementSemiSpaceCopiedObjectSize(object_size);
return true; return true;
} }
......
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