| Index: src/builtins/ia32/builtins-ia32.cc
|
| diff --git a/src/builtins/ia32/builtins-ia32.cc b/src/builtins/ia32/builtins-ia32.cc
|
| index 50af4006c90c2db702998945404256b50e1d36d6..aa53f0edf2b575ba1db2b2ac6ff882d379b9c29d 100644
|
| --- a/src/builtins/ia32/builtins-ia32.cc
|
| +++ b/src/builtins/ia32/builtins-ia32.cc
|
| @@ -1028,6 +1028,12 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| Register new_target = edx;
|
| Register argument_count = eax;
|
|
|
| + // Do we have a valid feedback vector?
|
| + __ mov(ebx, FieldOperand(closure, JSFunction::kFeedbackVectorOffset));
|
| + __ mov(ebx, FieldOperand(ebx, Cell::kValueOffset));
|
| + __ JumpIfRoot(ebx, Heap::kUndefinedValueRootIndex,
|
| + &gotta_call_runtime_no_stack);
|
| +
|
| __ push(argument_count);
|
| __ push(new_target);
|
| __ push(closure);
|
| @@ -1038,9 +1044,8 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| __ mov(map, FieldOperand(map, SharedFunctionInfo::kOptimizedCodeMapOffset));
|
| __ mov(index, FieldOperand(map, FixedArray::kLengthOffset));
|
| __ cmp(index, Immediate(Smi::FromInt(2)));
|
| - __ j(less, &gotta_call_runtime);
|
| + __ j(less, &try_shared);
|
|
|
| - // Find literals.
|
| // edx : native context
|
| // ebx : length / index
|
| // eax : optimized code map
|
| @@ -1058,19 +1063,6 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| __ mov(temp, FieldOperand(temp, WeakCell::kValueOffset));
|
| __ cmp(temp, native_context);
|
| __ j(not_equal, &loop_bottom);
|
| - // Feedback vector available?
|
| - __ mov(temp, FieldOperand(map, index, times_half_pointer_size,
|
| - SharedFunctionInfo::kOffsetToPreviousLiterals));
|
| - __ mov(temp, FieldOperand(temp, WeakCell::kValueOffset));
|
| - __ JumpIfSmi(temp, &gotta_call_runtime);
|
| -
|
| - // Save the vector in the closure.
|
| - __ mov(ecx, Operand(esp, 0));
|
| - __ mov(FieldOperand(ecx, JSFunction::kFeedbackVectorOffset), temp);
|
| - __ push(index);
|
| - __ RecordWriteField(ecx, JSFunction::kFeedbackVectorOffset, temp, index,
|
| - kDontSaveFPRegs, EMIT_REMEMBERED_SET, OMIT_SMI_CHECK);
|
| - __ pop(index);
|
|
|
| // Code available?
|
| Register entry = ecx;
|
| @@ -1079,7 +1071,7 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| __ mov(entry, FieldOperand(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.
|
| __ lea(entry, FieldOperand(entry, Code::kHeaderSize));
|
| @@ -1113,9 +1105,7 @@ void Builtins::Generate_CompileLazy(MacroAssembler* masm) {
|
| __ cmp(index, Immediate(Smi::FromInt(1)));
|
| __ j(greater, &loop_top);
|
|
|
| - // We found neither literals nor code.
|
| - __ jmp(&gotta_call_runtime);
|
| -
|
| + // We found no code.
|
| __ bind(&try_shared);
|
| __ pop(closure);
|
| __ pop(new_target);
|
|
|