| Index: src/builtins/arm/builtins-arm.cc
|
| diff --git a/src/builtins/arm/builtins-arm.cc b/src/builtins/arm/builtins-arm.cc
|
| index 3f1405cf424a040a72a098d599f87d8d5bfd08f6..959ce2af671f2536910e21edec265b568f819665 100644
|
| --- a/src/builtins/arm/builtins-arm.cc
|
| +++ b/src/builtins/arm/builtins-arm.cc
|
| @@ -1339,12 +1339,19 @@
|
| Register argument_count = r0;
|
| Register closure = r1;
|
| Register new_target = r3;
|
| + Register map = argument_count;
|
| + Register index = r2;
|
| +
|
| + // Do we have a valid feedback vector?
|
| + __ ldr(index, FieldMemOperand(closure, JSFunction::kLiteralsOffset));
|
| + __ ldr(index, FieldMemOperand(index, LiteralsArray::kFeedbackVectorOffset));
|
| + __ JumpIfRoot(index, Heap::kUndefinedValueRootIndex,
|
| + &gotta_call_runtime_no_stack);
|
| +
|
| __ push(argument_count);
|
| __ push(new_target);
|
| __ push(closure);
|
|
|
| - Register map = argument_count;
|
| - Register index = r2;
|
| __ ldr(map, FieldMemOperand(closure, JSFunction::kSharedFunctionInfoOffset));
|
| __ ldr(map,
|
| FieldMemOperand(map, SharedFunctionInfo::kOptimizedCodeMapOffset));
|
| @@ -1352,7 +1359,6 @@
|
| __ cmp(index, Operand(Smi::FromInt(2)));
|
| __ b(lt, &gotta_call_runtime);
|
|
|
| - // Find literals.
|
| // r3 : native context
|
| // r2 : length / index
|
| // r0 : optimized code map
|
| @@ -1372,20 +1378,6 @@
|
| __ ldr(temp, FieldMemOperand(temp, WeakCell::kValueOffset));
|
| __ cmp(temp, native_context);
|
| __ b(ne, &loop_bottom);
|
| - // Literals available?
|
| - __ ldr(temp, FieldMemOperand(array_pointer,
|
| - SharedFunctionInfo::kOffsetToPreviousLiterals));
|
| - __ ldr(temp, FieldMemOperand(temp, WeakCell::kValueOffset));
|
| - __ JumpIfSmi(temp, &gotta_call_runtime);
|
| -
|
| - // Save the literals in the closure.
|
| - __ ldr(r4, MemOperand(sp, 0));
|
| - __ str(temp, FieldMemOperand(r4, JSFunction::kLiteralsOffset));
|
| - __ push(index);
|
| - __ RecordWriteField(r4, JSFunction::kLiteralsOffset, temp, index,
|
| - kLRHasNotBeenSaved, kDontSaveFPRegs, EMIT_REMEMBERED_SET,
|
| - OMIT_SMI_CHECK);
|
| - __ pop(index);
|
|
|
| // Code available?
|
| Register entry = r4;
|
| @@ -1395,7 +1387,7 @@
|
| __ ldr(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.
|
| __ add(entry, entry, Operand(Code::kHeaderSize - kHeapObjectTag));
|
| @@ -1430,7 +1422,7 @@
|
| __ cmp(index, Operand(Smi::FromInt(1)));
|
| __ b(gt, &loop_top);
|
|
|
| - // We found neither literals nor code.
|
| + // We found no code.
|
| __ jmp(&gotta_call_runtime);
|
|
|
| __ bind(&try_shared);
|
|
|