Commit 05078ede authored by mbrandy's avatar mbrandy Committed by Commit bot

PPC: Fix memento initialization when constructing from new call

Port 3285e3bf

Original commit message
    Additionally, push the allocation site or undefined independently
    of creating a memento to preserve a fixed size for the construct
    frames.

R=mlippautz@chromium.org, dstence@us.ibm.com, michael_dawson@ca.ibm.com
BUG=

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

Cr-Commit-Position: refs/heads/master@{#29732}
parent 88214f1b
...@@ -328,14 +328,10 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm, ...@@ -328,14 +328,10 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm,
{ {
FrameAndConstantPoolScope scope(masm, StackFrame::CONSTRUCT); FrameAndConstantPoolScope scope(masm, StackFrame::CONSTRUCT);
if (create_memento) {
__ AssertUndefinedOrAllocationSite(r5, r7);
__ push(r5);
}
// Preserve the incoming parameters on the stack. // Preserve the incoming parameters on the stack.
__ AssertUndefinedOrAllocationSite(r5, r7);
__ SmiTag(r3); __ SmiTag(r3);
__ Push(r3, r4, r6); __ Push(r5, r3, r4, r6);
// Try to allocate the object without transitioning into C code. If any of // Try to allocate the object without transitioning into C code. If any of
// the preconditions is not met, the code bails out to the runtime call. // the preconditions is not met, the code bails out to the runtime call.
...@@ -470,7 +466,8 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm, ...@@ -470,7 +466,8 @@ static void Generate_JSConstructStubHelper(MacroAssembler* masm,
__ LoadRoot(r10, Heap::kAllocationMementoMapRootIndex); __ LoadRoot(r10, Heap::kAllocationMementoMapRootIndex);
__ StoreP(r10, MemOperand(r8, AllocationMemento::kMapOffset)); __ StoreP(r10, MemOperand(r8, AllocationMemento::kMapOffset));
// Load the AllocationSite // Load the AllocationSite
__ LoadP(r10, MemOperand(sp, 2 * kPointerSize)); __ LoadP(r10, MemOperand(sp, 3 * kPointerSize));
__ AssertUndefinedOrAllocationSite(r10, r3);
__ StoreP(r10, __ StoreP(r10,
MemOperand(r8, AllocationMemento::kAllocationSiteOffset)); MemOperand(r8, AllocationMemento::kAllocationSiteOffset));
__ addi(r8, r8, Operand(AllocationMemento::kAllocationSiteOffset + __ addi(r8, r8, Operand(AllocationMemento::kAllocationSiteOffset +
...@@ -654,12 +651,11 @@ void Builtins::Generate_JSConstructStubForDerived(MacroAssembler* masm) { ...@@ -654,12 +651,11 @@ void Builtins::Generate_JSConstructStubForDerived(MacroAssembler* masm) {
// -- sp[...]: constructor arguments // -- sp[...]: constructor arguments
// ----------------------------------- // -----------------------------------
// TODO(dslomov): support pretenuring
CHECK(!FLAG_pretenuring_call_new);
{ {
FrameAndConstantPoolScope scope(masm, StackFrame::CONSTRUCT); FrameAndConstantPoolScope scope(masm, StackFrame::CONSTRUCT);
__ AssertUndefinedOrAllocationSite(r5, r7);
// Smi-tagged arguments count. // Smi-tagged arguments count.
__ mr(r7, r3); __ mr(r7, r3);
__ SmiTag(r7, SetRC); __ SmiTag(r7, SetRC);
...@@ -667,8 +663,8 @@ void Builtins::Generate_JSConstructStubForDerived(MacroAssembler* masm) { ...@@ -667,8 +663,8 @@ void Builtins::Generate_JSConstructStubForDerived(MacroAssembler* masm) {
// receiver is the hole. // receiver is the hole.
__ LoadRoot(ip, Heap::kTheHoleValueRootIndex); __ LoadRoot(ip, Heap::kTheHoleValueRootIndex);
// smi arguments count, new.target, receiver // allocation site, smi arguments count, new.target, receiver
__ Push(r7, r6, ip); __ Push(r5, r7, r6, ip);
// Set up pointer to last argument. // Set up pointer to last argument.
__ addi(r5, fp, Operand(StandardFrameConstants::kCallerSPOffset)); __ addi(r5, fp, Operand(StandardFrameConstants::kCallerSPOffset));
......
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