| Index: src/arm/builtins-arm.cc
|
| diff --git a/src/arm/builtins-arm.cc b/src/arm/builtins-arm.cc
|
| index 1f5481bed7862c229739d420515d6fded6f40559..5066da92e1b770b8c46b7b97944c9f65d1eba823 100644
|
| --- a/src/arm/builtins-arm.cc
|
| +++ b/src/arm/builtins-arm.cc
|
| @@ -1011,8 +1011,12 @@ void Builtins::Generate_InterpreterEntryTrampoline(MacroAssembler* masm) {
|
| __ Assert(eq, kFunctionDataShouldBeBytecodeArrayOnInterpreterEntry);
|
| }
|
|
|
| - // Push new.target, bytecode array and zero for bytecode array offset.
|
| - __ mov(r0, Operand(0));
|
| + // Load the initial bytecode offset.
|
| + __ mov(kInterpreterBytecodeOffsetRegister,
|
| + Operand(BytecodeArray::kHeaderSize - kHeapObjectTag));
|
| +
|
| + // Push new.target, bytecode array and Smi tagged bytecode array offset.
|
| + __ SmiTag(r0, kInterpreterBytecodeOffsetRegister);
|
| __ Push(r3, kInterpreterBytecodeArrayRegister, r0);
|
|
|
| // Allocate the local and temporary register file on the stack.
|
| @@ -1044,12 +1048,8 @@ void Builtins::Generate_InterpreterEntryTrampoline(MacroAssembler* masm) {
|
| __ b(&loop_header, ge);
|
| }
|
|
|
| - // Load accumulator, register file, bytecode offset, dispatch table into
|
| - // registers.
|
| + // Load accumulator and dispatch table into registers.
|
| __ LoadRoot(kInterpreterAccumulatorRegister, Heap::kUndefinedValueRootIndex);
|
| - __ add(r4, fp, Operand(InterpreterFrameConstants::kRegisterFileFromFp));
|
| - __ mov(kInterpreterBytecodeOffsetRegister,
|
| - Operand(BytecodeArray::kHeaderSize - kHeapObjectTag));
|
| __ mov(kInterpreterDispatchTableRegister,
|
| Operand(ExternalReference::interpreter_dispatch_table_address(
|
| masm->isolate())));
|
|
|