Index: src/crankshaft/arm/lithium-codegen-arm.cc |
diff --git a/src/crankshaft/arm/lithium-codegen-arm.cc b/src/crankshaft/arm/lithium-codegen-arm.cc |
index ac7c1e7d1d5276e18c5fc1899617205712d7146c..970407b24e15060beeef31b5bedadc78b3cee40e 100644 |
--- a/src/crankshaft/arm/lithium-codegen-arm.cc |
+++ b/src/crankshaft/arm/lithium-codegen-arm.cc |
@@ -3834,7 +3834,6 @@ void LCodeGen::DoCallFunction(LCallFunction* instr) { |
DCHECK(ToRegister(instr->result()).is(r0)); |
int arity = instr->arity(); |
- CallFunctionFlags flags = instr->hydrogen()->function_flags(); |
if (instr->hydrogen()->HasVectorAndSlot()) { |
Register slot_register = ToRegister(instr->temp_slot()); |
Register vector_register = ToRegister(instr->temp_vector()); |
@@ -3848,15 +3847,12 @@ void LCodeGen::DoCallFunction(LCallFunction* instr) { |
__ Move(vector_register, vector); |
__ mov(slot_register, Operand(Smi::FromInt(index))); |
- CallICState::CallType call_type = |
- (flags & CALL_AS_METHOD) ? CallICState::METHOD : CallICState::FUNCTION; |
- |
Handle<Code> ic = |
- CodeFactory::CallICInOptimizedCode(isolate(), arity, call_type).code(); |
+ CodeFactory::CallICInOptimizedCode(isolate(), arity).code(); |
CallCode(ic, RelocInfo::CODE_TARGET, instr); |
} else { |
- CallFunctionStub stub(isolate(), arity, flags); |
- CallCode(stub.GetCode(), RelocInfo::CODE_TARGET, instr); |
+ __ mov(r0, Operand(arity)); |
+ CallCode(isolate()->builtins()->Call(), RelocInfo::CODE_TARGET, instr); |
} |
} |