Index: src/arm/lithium-codegen-arm.cc |
diff --git a/src/arm/lithium-codegen-arm.cc b/src/arm/lithium-codegen-arm.cc |
index 24231c594b5d234f88657865e572a1ea8ec60346..bc6f71de3ae12e0e28070aa99b6020b0a8af77d7 100644 |
--- a/src/arm/lithium-codegen-arm.cc |
+++ b/src/arm/lithium-codegen-arm.cc |
@@ -2938,19 +2938,19 @@ void LCodeGen::DoReturn(LReturn* instr) { |
if (NeedsEagerFrame()) { |
__ mov(sp, fp); |
__ ldm(ia_w, sp, fp.bit() | lr.bit()); |
- |
- if (instr->has_constant_parameter_count()) { |
- int parameter_count = ToInteger32(instr->constant_parameter_count()); |
- int32_t sp_delta = (parameter_count + 1) * kPointerSize; |
- if (sp_delta != 0) { |
- __ add(sp, sp, Operand(sp_delta)); |
- } |
- } else { |
- Register reg = ToRegister(instr->parameter_count()); |
- __ add(reg, reg, Operand(1)); |
- __ add(sp, sp, Operand(reg, LSL, kPointerSizeLog2)); |
+ } |
+ if (instr->has_constant_parameter_count()) { |
+ int parameter_count = ToInteger32(instr->constant_parameter_count()); |
+ int32_t sp_delta = (parameter_count + 1) * kPointerSize; |
+ if (sp_delta != 0) { |
+ __ add(sp, sp, Operand(sp_delta)); |
} |
+ } else { |
+ Register reg = ToRegister(instr->parameter_count()); |
+ __ SmiUntag(reg); // it is a smi |
Hannes Payer (out of office)
2013/04/23 11:42:50
codestyle, move comment in a separate line before
mvstanton
2013/04/23 14:19:58
done, on all platforms
|
+ __ add(sp, sp, Operand(reg, LSL, kPointerSizeLog2)); |
} |
+ |
__ Jump(lr); |
} |
@@ -4220,10 +4220,18 @@ void LCodeGen::DoCallNewArray(LCallNewArray* instr) { |
__ mov(r0, Operand(instr->arity())); |
__ mov(r2, Operand(instr->hydrogen()->property_cell())); |
- Handle<Code> array_construct_code = |
- isolate()->builtins()->ArrayConstructCode(); |
- |
- CallCode(array_construct_code, RelocInfo::CONSTRUCT_CALL, instr); |
+ Object* cell_value = instr->hydrogen()->property_cell()->value(); |
+ ElementsKind kind = static_cast<ElementsKind>(Smi::cast(cell_value)->value()); |
+ if (instr->arity() == 0) { |
+ ArrayNoArgumentConstructorStub stub(kind); |
+ CallCode(stub.GetCode(isolate()), RelocInfo::CONSTRUCT_CALL, instr); |
+ } else if (instr->arity() == 1) { |
+ ArraySingleArgumentConstructorStub stub(kind); |
+ CallCode(stub.GetCode(isolate()), RelocInfo::CONSTRUCT_CALL, instr); |
+ } else { |
+ ArrayNArgumentsConstructorStub stub(kind); |
+ CallCode(stub.GetCode(isolate()), RelocInfo::CONSTRUCT_CALL, instr); |
+ } |
} |