Index: src/ia32/full-codegen-ia32.cc |
diff --git a/src/ia32/full-codegen-ia32.cc b/src/ia32/full-codegen-ia32.cc |
index 9854bb6e27829cf73fd45574517dd4d9146ac5d9..182e74e440593f9f8530d2c89fc86844646d5c28 100644 |
--- a/src/ia32/full-codegen-ia32.cc |
+++ b/src/ia32/full-codegen-ia32.cc |
@@ -140,8 +140,6 @@ void FullCodeGenerator::Generate() { |
handler_table_ = |
isolate()->factory()->NewFixedArray(function()->handler_count(), TENURED); |
- InitializeFeedbackVector(); |
- |
profiling_counter_ = isolate()->factory()->NewCell( |
Handle<Smi>(Smi::FromInt(FLAG_interrupt_budget), isolate())); |
SetFunctionPosition(function()); |
@@ -1135,15 +1133,10 @@ void FullCodeGenerator::VisitForInStatement(ForInStatement* stmt) { |
Label non_proxy; |
__ bind(&fixed_array); |
- Handle<Object> feedback = Handle<Object>( |
- Smi::FromInt(TypeFeedbackInfo::kForInFastCaseMarker), |
- isolate()); |
- StoreFeedbackVectorSlot(slot, feedback); |
- |
// No need for a write barrier, we are storing a Smi in the feedback vector. |
__ LoadHeapObject(ebx, FeedbackVector()); |
__ mov(FieldOperand(ebx, FixedArray::OffsetOfElementAt(slot)), |
- Immediate(Smi::FromInt(TypeFeedbackInfo::kForInSlowCaseMarker))); |
+ Immediate(TypeFeedbackInfo::MegamorphicSentinel(isolate()))); |
__ mov(ebx, Immediate(Smi::FromInt(1))); // Smi indicates slow check |
__ mov(ecx, Operand(esp, 0 * kPointerSize)); // Get enumerated object |
@@ -2662,9 +2655,6 @@ void FullCodeGenerator::EmitCallWithStub(Call* expr) { |
// Record source position for debugger. |
SetSourcePosition(expr->position()); |
- Handle<Object> uninitialized = |
- TypeFeedbackInfo::UninitializedSentinel(isolate()); |
- StoreFeedbackVectorSlot(expr->CallFeedbackSlot(), uninitialized); |
__ LoadHeapObject(ebx, FeedbackVector()); |
__ mov(edx, Immediate(Smi::FromInt(expr->CallFeedbackSlot()))); |
@@ -2842,12 +2832,8 @@ void FullCodeGenerator::VisitCallNew(CallNew* expr) { |
__ mov(edi, Operand(esp, arg_count * kPointerSize)); |
// Record call targets in unoptimized code. |
- Handle<Object> uninitialized = |
- TypeFeedbackInfo::UninitializedSentinel(isolate()); |
- StoreFeedbackVectorSlot(expr->CallNewFeedbackSlot(), uninitialized); |
if (FLAG_pretenuring_call_new) { |
- StoreFeedbackVectorSlot(expr->AllocationSiteFeedbackSlot(), |
- isolate()->factory()->NewAllocationSite()); |
+ EnsureSlotContainsAllocationSite(expr->AllocationSiteFeedbackSlot()); |
ASSERT(expr->AllocationSiteFeedbackSlot() == |
expr->CallNewFeedbackSlot() + 1); |
} |