| 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);
|
| }
|
|
|