Index: src/x87/builtins-x87.cc |
diff --git a/src/x87/builtins-x87.cc b/src/x87/builtins-x87.cc |
index 1036effcacd4bbef88f72e0780ce6349ed056120..fcaf4339a386796b8af4317cdb7bb882994c66d2 100644 |
--- a/src/x87/builtins-x87.cc |
+++ b/src/x87/builtins-x87.cc |
@@ -117,12 +117,9 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm, |
{ |
FrameScope scope(masm, StackFrame::CONSTRUCT); |
- if (create_memento) { |
- __ AssertUndefinedOrAllocationSite(ebx); |
- __ push(ebx); |
- } |
- |
// Preserve the incoming parameters on the stack. |
+ __ AssertUndefinedOrAllocationSite(ebx); |
+ __ push(ebx); |
__ SmiTag(eax); |
__ push(eax); |
__ push(edi); |
@@ -254,7 +251,8 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm, |
__ mov(Operand(esi, AllocationMemento::kMapOffset), |
factory->allocation_memento_map()); |
// Get the cell or undefined. |
- __ mov(edx, Operand(esp, kPointerSize*2)); |
+ __ mov(edx, Operand(esp, 3 * kPointerSize)); |
+ __ AssertUndefinedOrAllocationSite(edx); |
__ mov(Operand(esi, AllocationMemento::kAllocationSiteOffset), |
edx); |
} else { |
@@ -422,12 +420,13 @@ void Builtins::Generate_JSConstructStubForDerived(MacroAssembler* masm) { |
// -- edx: original constructor |
// ----------------------------------- |
- // TODO(dslomov): support pretenuring |
- CHECK(!FLAG_pretenuring_call_new); |
- |
{ |
FrameScope frame_scope(masm, StackFrame::CONSTRUCT); |
+ // Preserve allocation site. |
+ __ AssertUndefinedOrAllocationSite(ebx); |
+ __ push(ebx); |
+ |
// Preserve actual arguments count. |
__ SmiTag(eax); |
__ push(eax); |