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:
parent
6ce7f90aba
commit
ff4c3f31a0
@ -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();
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user