| Index: src/arm/full-codegen-arm.cc | 
| diff --git a/src/arm/full-codegen-arm.cc b/src/arm/full-codegen-arm.cc | 
| index 1d91a6ea186fafa0e6c0d1b0e9b4d33896708ace..f2e5136d453f70d937c0ccf1230e513d2d335712 100644 | 
| --- a/src/arm/full-codegen-arm.cc | 
| +++ b/src/arm/full-codegen-arm.cc | 
| @@ -264,7 +264,7 @@ void FullCodeGenerator::Generate() { | 
| scope()->VisitIllegalRedeclaration(this); | 
|  | 
| } else { | 
| -    PrepareForBailoutForId(AstNode::kFunctionEntryId, NO_REGISTERS); | 
| +    PrepareForBailoutForId(BailoutId::FunctionEntry(), NO_REGISTERS); | 
| { Comment cmnt(masm_, "[ Declarations"); | 
| // For named function expressions, declare the function name as a | 
| // constant. | 
| @@ -279,7 +279,7 @@ void FullCodeGenerator::Generate() { | 
| } | 
|  | 
| { Comment cmnt(masm_, "[ Stack check"); | 
| -      PrepareForBailoutForId(AstNode::kDeclarationsId, NO_REGISTERS); | 
| +      PrepareForBailoutForId(BailoutId::Declarations(), NO_REGISTERS); | 
| Label ok; | 
| __ LoadRoot(ip, Heap::kStackLimitRootIndex); | 
| __ cmp(sp, Operand(ip)); | 
| @@ -1159,7 +1159,7 @@ void FullCodeGenerator::VisitForInStatement(ForInStatement* stmt) { | 
| isolate()->factory()->NewJSGlobalPropertyCell( | 
| Handle<Object>( | 
| Smi::FromInt(TypeFeedbackCells::kForInFastCaseMarker))); | 
| -  RecordTypeFeedbackCell(stmt->PrepareId(), cell); | 
| +  RecordTypeFeedbackCell(stmt->ForInFeedbackId(), cell); | 
| __ LoadHeapObject(r1, cell); | 
| __ mov(r2, Operand(Smi::FromInt(TypeFeedbackCells::kForInSlowCaseMarker))); | 
| __ str(r2, FieldMemOperand(r1, JSGlobalPropertyCell::kValueOffset)); | 
| @@ -1631,7 +1631,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) { | 
| Handle<Code> ic = is_classic_mode() | 
| ? isolate()->builtins()->StoreIC_Initialize() | 
| : isolate()->builtins()->StoreIC_Initialize_Strict(); | 
| -            CallIC(ic, RelocInfo::CODE_TARGET, key->id()); | 
| +            CallIC(ic, RelocInfo::CODE_TARGET, key->LiteralFeedbackId()); | 
| PrepareForBailoutForId(key->id(), NO_REGISTERS); | 
| } else { | 
| VisitForEffect(value); | 
| @@ -1898,7 +1898,7 @@ void FullCodeGenerator::EmitNamedPropertyLoad(Property* prop) { | 
| __ mov(r2, Operand(key->handle())); | 
| // Call load IC. It has arguments receiver and property name r0 and r2. | 
| Handle<Code> ic = isolate()->builtins()->LoadIC_Initialize(); | 
| -  CallIC(ic, RelocInfo::CODE_TARGET, prop->id()); | 
| +  CallIC(ic, RelocInfo::CODE_TARGET, prop->PropertyFeedbackId()); | 
| } | 
|  | 
|  | 
| @@ -1906,7 +1906,7 @@ void FullCodeGenerator::EmitKeyedPropertyLoad(Property* prop) { | 
| SetSourcePosition(prop->position()); | 
| // Call keyed load IC. It has arguments key and receiver in r0 and r1. | 
| Handle<Code> ic = isolate()->builtins()->KeyedLoadIC_Initialize(); | 
| -  CallIC(ic, RelocInfo::CODE_TARGET, prop->id()); | 
| +  CallIC(ic, RelocInfo::CODE_TARGET, prop->PropertyFeedbackId()); | 
| } | 
|  | 
|  | 
| @@ -1933,7 +1933,8 @@ void FullCodeGenerator::EmitInlineSmiBinaryOp(BinaryOperation* expr, | 
|  | 
| __ bind(&stub_call); | 
| BinaryOpStub stub(op, mode); | 
| -  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, expr->id()); | 
| +  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, | 
| +         expr->BinaryOperationFeedbackId()); | 
| patch_site.EmitPatchInfo(); | 
| __ jmp(&done); | 
|  | 
| @@ -2016,7 +2017,8 @@ void FullCodeGenerator::EmitBinaryOp(BinaryOperation* expr, | 
| __ pop(r1); | 
| BinaryOpStub stub(op, mode); | 
| JumpPatchSite patch_site(masm_);    // unbound, signals no inlined smi code. | 
| -  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, expr->id()); | 
| +  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, | 
| +         expr->BinaryOperationFeedbackId()); | 
| patch_site.EmitPatchInfo(); | 
| context()->Plug(r0); | 
| } | 
| @@ -2205,7 +2207,7 @@ void FullCodeGenerator::EmitNamedPropertyAssignment(Assignment* expr) { | 
| Handle<Code> ic = is_classic_mode() | 
| ? isolate()->builtins()->StoreIC_Initialize() | 
| : isolate()->builtins()->StoreIC_Initialize_Strict(); | 
| -  CallIC(ic, RelocInfo::CODE_TARGET, expr->id()); | 
| +  CallIC(ic, RelocInfo::CODE_TARGET, expr->AssignmentFeedbackId()); | 
|  | 
| // If the assignment ends an initialization block, revert to fast case. | 
| if (expr->ends_initialization_block()) { | 
| @@ -2251,7 +2253,7 @@ void FullCodeGenerator::EmitKeyedPropertyAssignment(Assignment* expr) { | 
| Handle<Code> ic = is_classic_mode() | 
| ? isolate()->builtins()->KeyedStoreIC_Initialize() | 
| : isolate()->builtins()->KeyedStoreIC_Initialize_Strict(); | 
| -  CallIC(ic, RelocInfo::CODE_TARGET, expr->id()); | 
| +  CallIC(ic, RelocInfo::CODE_TARGET, expr->AssignmentFeedbackId()); | 
|  | 
| // If the assignment ends an initialization block, revert to fast case. | 
| if (expr->ends_initialization_block()) { | 
| @@ -2289,7 +2291,7 @@ void FullCodeGenerator::VisitProperty(Property* expr) { | 
|  | 
| void FullCodeGenerator::CallIC(Handle<Code> code, | 
| RelocInfo::Mode rmode, | 
| -                               unsigned ast_id) { | 
| +                               TypeFeedbackId ast_id) { | 
| ic_total_count_++; | 
| __ Call(code, rmode, ast_id); | 
| } | 
| @@ -2311,7 +2313,7 @@ void FullCodeGenerator::EmitCallWithIC(Call* expr, | 
| // Call the IC initialization code. | 
| Handle<Code> ic = | 
| isolate()->stub_cache()->ComputeCallInitialize(arg_count, mode); | 
| -  CallIC(ic, mode, expr->id()); | 
| +  CallIC(ic, mode, expr->CallFeedbackId()); | 
| RecordJSReturnSite(expr); | 
| // Restore context register. | 
| __ ldr(cp, MemOperand(fp, StandardFrameConstants::kContextOffset)); | 
| @@ -2344,7 +2346,7 @@ void FullCodeGenerator::EmitKeyedCallWithIC(Call* expr, | 
| Handle<Code> ic = | 
| isolate()->stub_cache()->ComputeKeyedCallInitialize(arg_count); | 
| __ ldr(r2, MemOperand(sp, (arg_count + 1) * kPointerSize));  // Key. | 
| -  CallIC(ic, RelocInfo::CODE_TARGET, expr->id()); | 
| +  CallIC(ic, RelocInfo::CODE_TARGET, expr->CallFeedbackId()); | 
| RecordJSReturnSite(expr); | 
| // Restore context register. | 
| __ ldr(cp, MemOperand(fp, StandardFrameConstants::kContextOffset)); | 
| @@ -2370,7 +2372,7 @@ void FullCodeGenerator::EmitCallWithStub(Call* expr, CallFunctionFlags flags) { | 
| TypeFeedbackCells::UninitializedSentinel(isolate()); | 
| Handle<JSGlobalPropertyCell> cell = | 
| isolate()->factory()->NewJSGlobalPropertyCell(uninitialized); | 
| -  RecordTypeFeedbackCell(expr->id(), cell); | 
| +  RecordTypeFeedbackCell(expr->CallFeedbackId(), cell); | 
| __ mov(r2, Operand(cell)); | 
|  | 
| CallFunctionStub stub(arg_count, flags); | 
| @@ -2566,7 +2568,7 @@ void FullCodeGenerator::VisitCallNew(CallNew* expr) { | 
| TypeFeedbackCells::UninitializedSentinel(isolate()); | 
| Handle<JSGlobalPropertyCell> cell = | 
| isolate()->factory()->NewJSGlobalPropertyCell(uninitialized); | 
| -  RecordTypeFeedbackCell(expr->id(), cell); | 
| +  RecordTypeFeedbackCell(expr->CallNewFeedbackId(), cell); | 
| __ mov(r2, Operand(cell)); | 
|  | 
| CallConstructStub stub(RECORD_CALL_TARGET); | 
| @@ -3847,7 +3849,7 @@ void FullCodeGenerator::VisitCallRuntime(CallRuntime* expr) { | 
| RelocInfo::Mode mode = RelocInfo::CODE_TARGET; | 
| Handle<Code> ic = | 
| isolate()->stub_cache()->ComputeCallInitialize(arg_count, mode); | 
| -    CallIC(ic, mode, expr->id()); | 
| +    CallIC(ic, mode, expr->CallRuntimeFeedbackId()); | 
| // Restore context register. | 
| __ ldr(cp, MemOperand(fp, StandardFrameConstants::kContextOffset)); | 
| } else { | 
| @@ -4002,7 +4004,8 @@ void FullCodeGenerator::EmitUnaryOperation(UnaryOperation* expr, | 
| // accumulator register r0. | 
| VisitForAccumulatorValue(expr->expression()); | 
| SetSourcePosition(expr->position()); | 
| -  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, expr->id()); | 
| +  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, | 
| +         expr->UnaryOperationFeedbackId()); | 
| context()->Plug(r0); | 
| } | 
|  | 
| @@ -4113,7 +4116,7 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) { | 
| SetSourcePosition(expr->position()); | 
|  | 
| BinaryOpStub stub(Token::ADD, NO_OVERWRITE); | 
| -  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, expr->CountId()); | 
| +  CallIC(stub.GetCode(), RelocInfo::CODE_TARGET, expr->CountBinOpFeedbackId()); | 
| patch_site.EmitPatchInfo(); | 
| __ bind(&done); | 
|  | 
| @@ -4145,7 +4148,7 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) { | 
| Handle<Code> ic = is_classic_mode() | 
| ? isolate()->builtins()->StoreIC_Initialize() | 
| : isolate()->builtins()->StoreIC_Initialize_Strict(); | 
| -      CallIC(ic, RelocInfo::CODE_TARGET, expr->id()); | 
| +      CallIC(ic, RelocInfo::CODE_TARGET, expr->CountStoreFeedbackId()); | 
| PrepareForBailoutForId(expr->AssignmentId(), TOS_REG); | 
| if (expr->is_postfix()) { | 
| if (!context()->IsEffect()) { | 
| @@ -4162,7 +4165,7 @@ void FullCodeGenerator::VisitCountOperation(CountOperation* expr) { | 
| Handle<Code> ic = is_classic_mode() | 
| ? isolate()->builtins()->KeyedStoreIC_Initialize() | 
| : isolate()->builtins()->KeyedStoreIC_Initialize_Strict(); | 
| -      CallIC(ic, RelocInfo::CODE_TARGET, expr->id()); | 
| +      CallIC(ic, RelocInfo::CODE_TARGET, expr->CountStoreFeedbackId()); | 
| PrepareForBailoutForId(expr->AssignmentId(), TOS_REG); | 
| if (expr->is_postfix()) { | 
| if (!context()->IsEffect()) { | 
| @@ -4371,7 +4374,7 @@ void FullCodeGenerator::VisitCompareOperation(CompareOperation* expr) { | 
| // Record position and call the compare IC. | 
| SetSourcePosition(expr->position()); | 
| Handle<Code> ic = CompareIC::GetUninitialized(op); | 
| -      CallIC(ic, RelocInfo::CODE_TARGET, expr->id()); | 
| +      CallIC(ic, RelocInfo::CODE_TARGET, expr->CompareOperationFeedbackId()); | 
| patch_site.EmitPatchInfo(); | 
| PrepareForBailoutBeforeSplit(expr, true, if_true, if_false); | 
| __ cmp(r0, Operand(0)); | 
|  |