PPC: [builtins] One runtime fallback is enough for the String constructor.

Port 34b7b21d1d

Original commit message:
    If inline allocation fails, we can just use the %NewObject fallback,
    which will do the right thing. We don't need a dedicated fallback to
    %AllocateInNewSpace.

R=bmeurer@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
BUG=

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

Cr-Commit-Position: refs/heads/master@{#32015}
This commit is contained in:
mbrandy 2015-11-16 08:53:39 -08:00 committed by Commit bot
parent 6ce7f90aba
commit ff4c3f31a0

View File

@ -264,7 +264,12 @@ void Builtins::Generate_StringConstructor_ConstructStub(MacroAssembler* masm) {
__ bind(&done_convert); __ bind(&done_convert);
} }
// 3. Allocate a JSValue wrapper for the string. // 3. Check if original constructor and constructor differ.
Label new_object;
__ cmp(r4, r6);
__ bne(&new_object);
// 4. Allocate a JSValue wrapper for the string.
{ {
// ----------- S t a t e ------------- // ----------- S t a t e -------------
// -- r5 : the first argument // -- r5 : the first argument
@ -272,15 +277,7 @@ void Builtins::Generate_StringConstructor_ConstructStub(MacroAssembler* masm) {
// -- r6 : original constructor // -- r6 : original constructor
// -- lr : return address // -- lr : return address
// ----------------------------------- // -----------------------------------
__ Allocate(JSValue::kSize, r3, r7, r8, &new_object, TAG_OBJECT);
Label allocate, done_allocate, rt_call;
// Fall back to runtime if the original constructor and function differ.
__ cmp(r4, r6);
__ bne(&rt_call);
__ Allocate(JSValue::kSize, r3, r6, r7, &allocate, TAG_OBJECT);
__ bind(&done_allocate);
// Initialize the JSValue in r3. // Initialize the JSValue in r3.
__ LoadGlobalFunctionInitialMap(r4, r6, r7); __ LoadGlobalFunctionInitialMap(r4, r6, r7);
@ -291,29 +288,18 @@ void Builtins::Generate_StringConstructor_ConstructStub(MacroAssembler* masm) {
__ StoreP(r5, FieldMemOperand(r3, JSValue::kValueOffset), r0); __ StoreP(r5, FieldMemOperand(r3, JSValue::kValueOffset), r0);
STATIC_ASSERT(JSValue::kSize == 4 * kPointerSize); STATIC_ASSERT(JSValue::kSize == 4 * kPointerSize);
__ Ret(); __ Ret();
// Fallback to the runtime to allocate in new space.
__ bind(&allocate);
{
FrameAndConstantPoolScope scope(masm, StackFrame::INTERNAL);
__ LoadSmiLiteral(r6, Smi::FromInt(JSValue::kSize));
__ Push(r4, r5, r6);
__ CallRuntime(Runtime::kAllocateInNewSpace, 1);
__ Pop(r4, r5);
} }
__ b(&done_allocate);
// Fallback to the runtime to create new object. // 5. Fallback to the runtime to create new object.
__ bind(&rt_call); __ bind(&new_object);
{ {
FrameAndConstantPoolScope scope(masm, StackFrame::INTERNAL); FrameAndConstantPoolScope scope(masm, StackFrame::INTERNAL);
__ Push(r4, r5, r4, r6); // constructor function, original constructor __ Push(r5, r4, r6); // first argument, constructor, original constructor
__ CallRuntime(Runtime::kNewObject, 2); __ CallRuntime(Runtime::kNewObject, 2);
__ Pop(r4, r5); __ Pop(r5);
} }
__ StoreP(r5, FieldMemOperand(r3, JSValue::kValueOffset), r0); __ StoreP(r5, FieldMemOperand(r3, JSValue::kValueOffset), r0);
__ Ret(); __ Ret();
}
} }