| Index: src/ia32/lithium-ia32.cc | 
| =================================================================== | 
| --- src/ia32/lithium-ia32.cc	(revision 6230) | 
| +++ src/ia32/lithium-ia32.cc	(working copy) | 
| @@ -293,7 +293,7 @@ | 
|  | 
|  | 
| void LCallNew::PrintDataTo(StringStream* stream) const { | 
| -  LUnaryOperation::PrintDataTo(stream); | 
| +  LUnaryOperation<1>::PrintDataTo(stream); | 
| stream->Add(" #%d / ", arity()); | 
| } | 
|  | 
| @@ -305,7 +305,8 @@ | 
| } | 
|  | 
|  | 
| -void LUnaryOperation::PrintDataTo(StringStream* stream) const { | 
| +template <int R> | 
| +void LUnaryOperation<R>::PrintDataTo(StringStream* stream) const { | 
| stream->Add("= "); | 
| input()->PrintTo(stream); | 
| } | 
| @@ -598,32 +599,34 @@ | 
| } | 
|  | 
|  | 
| -LInstruction* LChunkBuilder::Define(LInstruction* instr) { | 
| +LInstruction* LChunkBuilder::Define(LTemplateInstruction<1>* instr) { | 
| return Define(instr, new LUnallocated(LUnallocated::NONE)); | 
| } | 
|  | 
|  | 
| -LInstruction* LChunkBuilder::DefineAsRegister(LInstruction* instr) { | 
| +LInstruction* LChunkBuilder::DefineAsRegister(LTemplateInstruction<1>* instr) { | 
| return Define(instr, new LUnallocated(LUnallocated::MUST_HAVE_REGISTER)); | 
| } | 
|  | 
|  | 
| -LInstruction* LChunkBuilder::DefineAsSpilled(LInstruction* instr, int index) { | 
| +LInstruction* LChunkBuilder::DefineAsSpilled(LTemplateInstruction<1>* instr, | 
| +                                             int index) { | 
| return Define(instr, new LUnallocated(LUnallocated::FIXED_SLOT, index)); | 
| } | 
|  | 
|  | 
| -LInstruction* LChunkBuilder::DefineSameAsFirst(LInstruction* instr) { | 
| +LInstruction* LChunkBuilder::DefineSameAsFirst(LTemplateInstruction<1>* instr) { | 
| return Define(instr, new LUnallocated(LUnallocated::SAME_AS_FIRST_INPUT)); | 
| } | 
|  | 
|  | 
| -LInstruction* LChunkBuilder::DefineFixed(LInstruction* instr, Register reg) { | 
| +LInstruction* LChunkBuilder::DefineFixed(LTemplateInstruction<1>* instr, | 
| +                                         Register reg) { | 
| return Define(instr, ToUnallocated(reg)); | 
| } | 
|  | 
|  | 
| -LInstruction* LChunkBuilder::DefineFixedDouble(LInstruction* instr, | 
| +LInstruction* LChunkBuilder::DefineFixedDouble(LTemplateInstruction<1>* instr, | 
| XMMRegister reg) { | 
| return Define(instr, ToUnallocated(reg)); | 
| } | 
| @@ -692,7 +695,8 @@ | 
| } | 
|  | 
|  | 
| -LInstruction* LChunkBuilder::Define(LInstruction* instr, LUnallocated* result) { | 
| +LInstruction* LChunkBuilder::Define(LTemplateInstruction<1>* instr, | 
| +                                    LUnallocated* result) { | 
| allocator_->RecordDefinition(current_instruction_, result); | 
| instr->set_result(result); | 
| return instr; | 
| @@ -781,10 +785,10 @@ | 
| can_deopt = !can_truncate; | 
| } | 
|  | 
| -  LInstruction* result = | 
| -      DefineSameAsFirst(new LShiftI(op, left, right, can_deopt)); | 
| -  if (can_deopt) AssignEnvironment(result); | 
| -  return result; | 
| +  LShiftI* result = new LShiftI(op, left, right, can_deopt); | 
| +  return can_deopt | 
| +      ? AssignEnvironment(DefineSameAsFirst(result)) | 
| +      : DefineSameAsFirst(result); | 
| } | 
|  | 
|  | 
| @@ -813,7 +817,7 @@ | 
| ASSERT(right->representation().IsTagged()); | 
| LOperand* left_operand = UseFixed(left, edx); | 
| LOperand* right_operand = UseFixed(right, eax); | 
| -  LInstruction* result = new LArithmeticT(op, left_operand, right_operand); | 
| +  LArithmeticT* result = new LArithmeticT(op, left_operand, right_operand); | 
| return MarkAsCall(DefineFixed(result, eax), instr); | 
| } | 
|  | 
| @@ -999,10 +1003,11 @@ | 
|  | 
|  | 
| LInstruction* LChunkBuilder::DoGoto(HGoto* instr) { | 
| -  LInstruction* result = new LGoto(instr->FirstSuccessor()->block_id(), | 
| -                                   instr->include_stack_check()); | 
| -  if (instr->include_stack_check()) result = AssignPointerMap(result); | 
| -  return result; | 
| +  LGoto* result = new LGoto(instr->FirstSuccessor()->block_id(), | 
| +                            instr->include_stack_check()); | 
| +  return (instr->include_stack_check()) | 
| +      ? AssignPointerMap(result) | 
| +      : result; | 
| } | 
|  | 
|  | 
| @@ -1051,10 +1056,10 @@ | 
| bool reversed = op == Token::GT || op == Token::LTE; | 
| LOperand* left_operand = UseFixed(left, reversed ? eax : edx); | 
| LOperand* right_operand = UseFixed(right, reversed ? edx : eax); | 
| -        LInstruction* result = new LCmpTAndBranch(left_operand, | 
| -                                                  right_operand, | 
| -                                                  first_id, | 
| -                                                  second_id); | 
| +        LCmpTAndBranch* result = new LCmpTAndBranch(left_operand, | 
| +                                                    right_operand, | 
| +                                                    first_id, | 
| +                                                    second_id); | 
| return MarkAsCall(result, instr); | 
| } | 
| } else if (v->IsIsSmi()) { | 
| @@ -1108,7 +1113,7 @@ | 
| second_id); | 
| } else if (v->IsInstanceOf()) { | 
| HInstanceOf* instance_of = HInstanceOf::cast(v); | 
| -      LInstruction* result = | 
| +      LInstanceOfAndBranch* result = | 
| new LInstanceOfAndBranch( | 
| UseFixed(instance_of->left(), InstanceofStub::left()), | 
| UseFixed(instance_of->right(), InstanceofStub::right()), | 
| @@ -1155,7 +1160,7 @@ | 
|  | 
|  | 
| LInstruction* LChunkBuilder::DoInstanceOf(HInstanceOf* instr) { | 
| -  LInstruction* result = | 
| +  LInstanceOf* result = | 
| new LInstanceOf(UseFixed(instr->left(), InstanceofStub::left()), | 
| UseFixed(instr->right(), InstanceofStub::right())); | 
| return MarkAsCall(DefineFixed(result, eax), instr); | 
| @@ -1164,7 +1169,7 @@ | 
|  | 
| LInstruction* LChunkBuilder::DoInstanceOfKnownGlobal( | 
| HInstanceOfKnownGlobal* instr) { | 
| -  LInstruction* result = | 
| +  LInstanceOfKnownGlobal* result = | 
| new LInstanceOfKnownGlobal( | 
| UseFixed(instr->value(), InstanceofStub::left()), | 
| FixedTemp(edi)); | 
| @@ -1178,10 +1183,10 @@ | 
| LOperand* receiver = UseFixed(instr->receiver(), eax); | 
| LOperand* length = UseRegisterAtStart(instr->length()); | 
| LOperand* elements = UseRegisterAtStart(instr->elements()); | 
| -  LInstruction* result = new LApplyArguments(function, | 
| -                                             receiver, | 
| -                                             length, | 
| -                                             elements); | 
| +  LApplyArguments* result = new LApplyArguments(function, | 
| +                                                receiver, | 
| +                                                length, | 
| +                                                elements); | 
| return MarkAsCall(DefineFixed(result, eax), instr, CAN_DEOPTIMIZE_EAGERLY); | 
| } | 
|  | 
| @@ -1214,11 +1219,11 @@ | 
| BuiltinFunctionId op = instr->op(); | 
| if (op == kMathLog || op == kMathSin || op == kMathCos) { | 
| LOperand* input = UseFixedDouble(instr->value(), xmm1); | 
| -    LInstruction* result = new LUnaryMathOperation(input); | 
| +    LUnaryMathOperation* result = new LUnaryMathOperation(input); | 
| return MarkAsCall(DefineFixedDouble(result, xmm1), instr); | 
| } else { | 
| LOperand* input = UseRegisterAtStart(instr->value()); | 
| -    LInstruction* result = new LUnaryMathOperation(input); | 
| +    LUnaryMathOperation* result = new LUnaryMathOperation(input); | 
| switch (op) { | 
| case kMathAbs: | 
| return AssignEnvironment(AssignPointerMap(DefineSameAsFirst(result))); | 
| @@ -1267,7 +1272,7 @@ | 
| LInstruction* LChunkBuilder::DoCallNew(HCallNew* instr) { | 
| LOperand* constructor = UseFixed(instr->constructor(), edi); | 
| argument_count_ -= instr->argument_count(); | 
| -  LInstruction* result = new LCallNew(constructor); | 
| +  LCallNew* result = new LCallNew(constructor); | 
| return MarkAsCall(DefineFixed(result, eax), instr); | 
| } | 
|  | 
| @@ -1347,12 +1352,12 @@ | 
| FixedTemp(edx); | 
| LOperand* value = UseFixed(instr->left(), eax); | 
| LOperand* divisor = UseRegister(instr->right()); | 
| -    LInstruction* result = DefineFixed(new LModI(value, divisor), edx); | 
| -    if (instr->CheckFlag(HValue::kBailoutOnMinusZero) || | 
| -        instr->CheckFlag(HValue::kCanBeDivByZero)) { | 
| -      result = AssignEnvironment(result); | 
| -    } | 
| -    return result; | 
| +    LModI* mod = new LModI(value, divisor); | 
| +    LInstruction* result = DefineFixed(mod, edx); | 
| +    return (instr->CheckFlag(HValue::kBailoutOnMinusZero) || | 
| +            instr->CheckFlag(HValue::kCanBeDivByZero)) | 
| +        ? AssignEnvironment(result) | 
| +        : result; | 
| } else if (instr->representation().IsTagged()) { | 
| return DoArithmeticT(Token::MOD, instr); | 
| } else { | 
| @@ -1463,7 +1468,7 @@ | 
| bool reversed = (op == Token::GT || op == Token::LTE); | 
| LOperand* left = UseFixed(instr->left(), reversed ? eax : edx); | 
| LOperand* right = UseFixed(instr->right(), reversed ? edx : eax); | 
| -    LInstruction* result = new LCmpT(left, right); | 
| +    LCmpT* result = new LCmpT(left, right); | 
| return MarkAsCall(DefineFixed(result, eax), instr); | 
| } | 
| } | 
| @@ -1473,7 +1478,7 @@ | 
| HCompareJSObjectEq* instr) { | 
| LOperand* left = UseRegisterAtStart(instr->left()); | 
| LOperand* right = UseRegisterAtStart(instr->right()); | 
| -  LInstruction* result = new LCmpJSObjectEq(left, right); | 
| +  LCmpJSObjectEq* result = new LCmpJSObjectEq(left, right); | 
| return DefineAsRegister(result); | 
| } | 
|  | 
| @@ -1542,7 +1547,7 @@ | 
|  | 
| LInstruction* LChunkBuilder::DoValueOf(HValueOf* instr) { | 
| LOperand* object = UseRegister(instr->value()); | 
| -  LInstruction* result = new LValueOf(object, TempRegister()); | 
| +  LValueOf* result = new LValueOf(object, TempRegister()); | 
| return AssignEnvironment(DefineSameAsFirst(result)); | 
| } | 
|  | 
| @@ -1565,7 +1570,7 @@ | 
| if (from.IsTagged()) { | 
| if (to.IsDouble()) { | 
| LOperand* value = UseRegister(instr->value()); | 
| -      LInstruction* res = new LNumberUntagD(value); | 
| +      LNumberUntagD* res = new LNumberUntagD(value); | 
| return AssignEnvironment(DefineAsRegister(res)); | 
| } else { | 
| ASSERT(to.IsInteger32()); | 
| @@ -1576,7 +1581,7 @@ | 
| (instr->CanTruncateToInt32() && CpuFeatures::IsSupported(SSE3)) | 
| ? NULL | 
| : FixedTemp(xmm1); | 
| -        LInstruction* res = new LTaggedToI(value, xmm_temp); | 
| +        LTaggedToI* res = new LTaggedToI(value, xmm_temp); | 
| return AssignEnvironment(DefineSameAsFirst(res)); | 
| } else { | 
| return DefineSameAsFirst(new LSmiUntag(value, needs_check)); | 
| @@ -1589,7 +1594,7 @@ | 
|  | 
| // Make sure that temp and result_temp are different registers. | 
| LUnallocated* result_temp = TempRegister(); | 
| -      LInstruction* result = new LNumberTagD(value, temp); | 
| +      LNumberTagD* result = new LNumberTagD(value, temp); | 
| return AssignPointerMap(Define(result, result_temp)); | 
| } else { | 
| ASSERT(to.IsInteger32()); | 
| @@ -1603,7 +1608,7 @@ | 
| if (val->HasRange() && val->range()->IsInSmiRange()) { | 
| return DefineSameAsFirst(new LSmiTag(value)); | 
| } else { | 
| -        LInstruction* result = new LNumberTagI(value); | 
| +        LNumberTagI* result = new LNumberTagI(value); | 
| return AssignEnvironment(AssignPointerMap(DefineSameAsFirst(result))); | 
| } | 
| } else { | 
| @@ -1625,14 +1630,14 @@ | 
| LInstruction* LChunkBuilder::DoCheckInstanceType(HCheckInstanceType* instr) { | 
| LOperand* value = UseRegisterAtStart(instr->value()); | 
| LOperand* temp = TempRegister(); | 
| -  LInstruction* result = new LCheckInstanceType(value, temp); | 
| +  LCheckInstanceType* result = new LCheckInstanceType(value, temp); | 
| return AssignEnvironment(result); | 
| } | 
|  | 
|  | 
| LInstruction* LChunkBuilder::DoCheckPrototypeMaps(HCheckPrototypeMaps* instr) { | 
| LOperand* temp = TempRegister(); | 
| -  LInstruction* result = | 
| +  LCheckPrototypeMaps* result = | 
| new LCheckPrototypeMaps(temp, | 
| instr->holder(), | 
| instr->receiver_map()); | 
| @@ -1654,7 +1659,7 @@ | 
|  | 
| LInstruction* LChunkBuilder::DoCheckMap(HCheckMap* instr) { | 
| LOperand* value = UseRegisterAtStart(instr->value()); | 
| -  LInstruction* result = new LCheckMap(value); | 
| +  LCheckMap* result = new LCheckMap(value); | 
| return AssignEnvironment(result); | 
| } | 
|  | 
| @@ -1682,7 +1687,7 @@ | 
|  | 
|  | 
| LInstruction* LChunkBuilder::DoLoadGlobal(HLoadGlobal* instr) { | 
| -  LInstruction* result = new LLoadGlobal; | 
| +  LLoadGlobal* result = new LLoadGlobal; | 
| return instr->check_hole_value() | 
| ? AssignEnvironment(DefineAsRegister(result)) | 
| : DefineAsRegister(result); | 
| @@ -1702,8 +1707,8 @@ | 
|  | 
| LInstruction* LChunkBuilder::DoLoadNamedGeneric(HLoadNamedGeneric* instr) { | 
| LOperand* object = UseFixed(instr->object(), eax); | 
| -  LInstruction* result = DefineFixed(new LLoadNamedGeneric(object), eax); | 
| -  return MarkAsCall(result, instr); | 
| +  LLoadNamedGeneric* result = new LLoadNamedGeneric(object); | 
| +  return MarkAsCall(DefineFixed(result, eax), instr); | 
| } | 
|  | 
|  | 
| @@ -1731,14 +1736,12 @@ | 
| // Double needs an extra temp, because the result is converted from heap | 
| // number to a double register. | 
| if (r.IsDouble()) load_result = TempRegister(); | 
| -  LInstruction* result = new LLoadKeyedFastElement(obj, | 
| -                                                   key, | 
| -                                                   load_result); | 
| -  if (r.IsDouble()) { | 
| -    result = DefineAsRegister(result); | 
| -  } else { | 
| -    result = DefineSameAsFirst(result); | 
| -  } | 
| +  LLoadKeyedFastElement* load = new LLoadKeyedFastElement(obj, | 
| +                                                          key, | 
| +                                                          load_result); | 
| +  LInstruction* result = r.IsDouble() | 
| +      ? DefineAsRegister(load) | 
| +      : DefineSameAsFirst(load); | 
| return AssignEnvironment(result); | 
| } | 
|  | 
| @@ -1747,9 +1750,8 @@ | 
| LOperand* object = UseFixed(instr->object(), edx); | 
| LOperand* key = UseFixed(instr->key(), eax); | 
|  | 
| -  LInstruction* result = | 
| -      DefineFixed(new LLoadKeyedGeneric(object, key), eax); | 
| -  return MarkAsCall(result, instr); | 
| +  LLoadKeyedGeneric* result = new LLoadKeyedGeneric(object, key); | 
| +  return MarkAsCall(DefineFixed(result, eax), instr); | 
| } | 
|  | 
|  | 
| @@ -1816,7 +1818,7 @@ | 
| LOperand* obj = UseFixed(instr->object(), edx); | 
| LOperand* val = UseFixed(instr->value(), eax); | 
|  | 
| -  LInstruction* result = new LStoreNamedGeneric(obj, instr->name(), val); | 
| +  LStoreNamedGeneric* result = new LStoreNamedGeneric(obj, instr->name(), val); | 
| return MarkAsCall(result, instr); | 
| } | 
|  | 
| @@ -1842,8 +1844,8 @@ | 
|  | 
|  | 
| LInstruction* LChunkBuilder::DoDeleteProperty(HDeleteProperty* instr) { | 
| -  LInstruction* result = new LDeleteProperty(Use(instr->object()), | 
| -                                             UseOrConstant(instr->key())); | 
| +  LDeleteProperty* result = new LDeleteProperty(Use(instr->object()), | 
| +                                                UseOrConstant(instr->key())); | 
| return MarkAsCall(DefineFixed(result, eax), instr); | 
| } | 
|  | 
| @@ -1884,13 +1886,13 @@ | 
| LOperand* arguments = UseRegister(instr->arguments()); | 
| LOperand* length = UseTempRegister(instr->length()); | 
| LOperand* index = Use(instr->index()); | 
| -  LInstruction* result = new LAccessArgumentsAt(arguments, length, index); | 
| -  return DefineAsRegister(AssignEnvironment(result)); | 
| +  LAccessArgumentsAt* result = new LAccessArgumentsAt(arguments, length, index); | 
| +  return AssignEnvironment(DefineAsRegister(result)); | 
| } | 
|  | 
|  | 
| LInstruction* LChunkBuilder::DoTypeof(HTypeof* instr) { | 
| -  LInstruction* result = new LTypeof(UseAtStart(instr->value())); | 
| +  LTypeof* result = new LTypeof(UseAtStart(instr->value())); | 
| return MarkAsCall(DefineFixed(result, eax), instr); | 
| } | 
|  | 
| @@ -1919,8 +1921,8 @@ | 
| // If there is an instruction pending deoptimization environment create a | 
| // lazy bailout instruction to capture the environment. | 
| if (pending_deoptimization_ast_id_ == instr->ast_id()) { | 
| -    LInstruction* result = new LLazyBailout; | 
| -    result = AssignEnvironment(result); | 
| +    LLazyBailout* lazy_bailout = new LLazyBailout; | 
| +    LInstruction* result = AssignEnvironment(lazy_bailout); | 
| instructions_pending_deoptimization_environment_-> | 
| set_deoptimization_environment(result->environment()); | 
| ClearInstructionPendingDeoptimizationEnvironment(); | 
|  |