| Index: src/builtins/mips64/builtins-mips64.cc
|
| diff --git a/src/builtins/mips64/builtins-mips64.cc b/src/builtins/mips64/builtins-mips64.cc
|
| index c3dcf05212fc863745d8e1a77268002be9a3fc47..f404d608cb1fceb0bf5cfdc1b7f73db252af74cf 100644
|
| --- a/src/builtins/mips64/builtins-mips64.cc
|
| +++ b/src/builtins/mips64/builtins-mips64.cc
|
| @@ -1009,6 +1009,7 @@ void Builtins::Generate_InterpreterEntryTrampoline(MacroAssembler* masm) {
|
|
|
| // Increment invocation count for the function.
|
| __ ld(a0, FieldMemOperand(a1, JSFunction::kFeedbackVectorOffset));
|
| + __ ld(a0, FieldMemOperand(a0, Cell::kValueOffset));
|
| __ ld(a4, FieldMemOperand(
|
| a0, TypeFeedbackVector::kInvocationCountIndex * kPointerSize +
|
| TypeFeedbackVector::kHeaderSize));
|
| @@ -1343,18 +1344,24 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| Register argument_count = a0;
|
| Register closure = a1;
|
| Register new_target = a3;
|
| + Register map = a0;
|
| + Register index = a2;
|
| +
|
| + // Do we have a valid feedback vector?
|
| + __ ld(index, FieldMemOperand(closure, JSFunction::kFeedbackVectorOffset));
|
| + __ ld(index, FieldMemOperand(index, Cell::kValueOffset));
|
| + __ JumpIfRoot(index, Heap::kUndefinedValueRootIndex,
|
| + &gotta_call_runtime_no_stack);
|
| +
|
| __ push(argument_count);
|
| __ push(new_target);
|
| __ push(closure);
|
|
|
| - Register map = a0;
|
| - Register index = a2;
|
| __ ld(map, FieldMemOperand(closure, JSFunction::kSharedFunctionInfoOffset));
|
| __ ld(map, FieldMemOperand(map, SharedFunctionInfo::kOptimizedCodeMapOffset));
|
| __ ld(index, FieldMemOperand(map, FixedArray::kLengthOffset));
|
| - __ Branch(&gotta_call_runtime, lt, index, Operand(Smi::FromInt(2)));
|
| + __ Branch(&try_shared, lt, index, Operand(Smi::FromInt(2)));
|
|
|
| - // Find literals.
|
| // a3 : native context
|
| // a2 : length / index
|
| // a0 : optimized code map
|
| @@ -1374,20 +1381,6 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| SharedFunctionInfo::kOffsetToPreviousContext));
|
| __ ld(temp, FieldMemOperand(temp, WeakCell::kValueOffset));
|
| __ Branch(&loop_bottom, ne, temp, Operand(native_context));
|
| - // Feedback vector available?
|
| - __ ld(temp, FieldMemOperand(array_pointer,
|
| - SharedFunctionInfo::kOffsetToPreviousLiterals));
|
| - __ ld(temp, FieldMemOperand(temp, WeakCell::kValueOffset));
|
| - __ JumpIfSmi(temp, &gotta_call_runtime);
|
| -
|
| - // Save the feedback vector in the closure.
|
| - __ ld(a4, MemOperand(sp, 0));
|
| - __ sd(temp, FieldMemOperand(a4, JSFunction::kFeedbackVectorOffset));
|
| - __ push(index);
|
| - __ RecordWriteField(a4, JSFunction::kFeedbackVectorOffset, temp, index,
|
| - kRAHasNotBeenSaved, kDontSaveFPRegs, EMIT_REMEMBERED_SET,
|
| - OMIT_SMI_CHECK);
|
| - __ pop(index);
|
|
|
| // Code available?
|
| Register entry = a4;
|
| @@ -1397,7 +1390,7 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| __ ld(entry, FieldMemOperand(entry, WeakCell::kValueOffset));
|
| __ JumpIfSmi(entry, &try_shared);
|
|
|
| - // Found literals and code. Get them into the closure and return.
|
| + // Found code. Get it into the closure and return.
|
| __ pop(closure);
|
| // Store code entry in the closure.
|
| __ Daddu(entry, entry, Operand(Code::kHeaderSize - kHeapObjectTag));
|
| @@ -1432,9 +1425,7 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| Operand(Smi::FromInt(SharedFunctionInfo::kEntryLength)));
|
| __ Branch(&loop_top, gt, index, Operand(Smi::FromInt(1)));
|
|
|
| - // We found neither literals nor code.
|
| - __ jmp(&gotta_call_runtime);
|
| -
|
| + // We found no code.
|
| __ bind(&try_shared);
|
| __ pop(closure);
|
| __ pop(new_target);
|
|
|