Commit f739088b authored by balazs.kilvady's avatar balazs.kilvady Committed by Commit bot

MIPS64: Fix2 '[runtime] Introduce FastNewStrictArgumentsStub to optimize strict arguments.'

Port 09d84535

More fix after 3b980234

Original commit message:
The FastNewStrictArgumentsStub is very similar to the recently added
FastNewRestParameterStub, it's actually almost a copy of it, except that
it doesn't have the fast case we have for the empty rest parameter. This
patch improves strict arguments in TurboFan and fullcodegen by up to 10x
compared to the previous version.

Also introduce proper JSSloppyArgumentsObject and JSStrictArgumentsObject
for the in-object properties instead of having them as constants in the
Heap class.

Drive-by-fix: Use this stub and the FastNewRestParameterStub in the
interpreter to avoid the runtime call overhead for strict arguments
and rest parameter creation.

BUG=

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

Cr-Commit-Position: refs/heads/master@{#34043}
parent 55791537
...@@ -4869,7 +4869,7 @@ void FastNewRestParameterStub::Generate(MacroAssembler* masm) { ...@@ -4869,7 +4869,7 @@ void FastNewRestParameterStub::Generate(MacroAssembler* masm) {
__ sd(at, FieldMemOperand(a3, 0 * kPointerSize)); __ sd(at, FieldMemOperand(a3, 0 * kPointerSize));
__ Dsubu(a2, a2, Operand(1 * kPointerSize)); __ Dsubu(a2, a2, Operand(1 * kPointerSize));
__ Daddu(a3, a3, Operand(1 * kPointerSize)); __ Daddu(a3, a3, Operand(1 * kPointerSize));
__ b(&loop); __ Branch(&loop);
__ bind(&done_loop); __ bind(&done_loop);
} }
...@@ -5204,8 +5204,8 @@ void FastNewStrictArgumentsStub::Generate(MacroAssembler* masm) { ...@@ -5204,8 +5204,8 @@ void FastNewStrictArgumentsStub::Generate(MacroAssembler* masm) {
__ bind(&done_loop); __ bind(&done_loop);
} }
// Setup the rest parameter array in a3. // Setup the strict arguments object in a3.
__ LoadNativeContextSlot(Context::JS_ARRAY_FAST_ELEMENTS_MAP_INDEX, at); __ LoadNativeContextSlot(Context::STRICT_ARGUMENTS_MAP_INDEX, at);
__ sd(at, FieldMemOperand(a3, JSStrictArgumentsObject::kMapOffset)); __ sd(at, FieldMemOperand(a3, JSStrictArgumentsObject::kMapOffset));
__ LoadRoot(at, Heap::kEmptyFixedArrayRootIndex); __ LoadRoot(at, Heap::kEmptyFixedArrayRootIndex);
__ sd(at, FieldMemOperand(a3, JSStrictArgumentsObject::kPropertiesOffset)); __ sd(at, FieldMemOperand(a3, JSStrictArgumentsObject::kPropertiesOffset));
......
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