Index: src/compiler/ia32/code-generator-ia32.cc |
diff --git a/src/compiler/ia32/code-generator-ia32.cc b/src/compiler/ia32/code-generator-ia32.cc |
index fc572106c844198ce30542f40753e814a328030d..b1701c264c24d9e7002bb97a425f913d928ab946 100644 |
--- a/src/compiler/ia32/code-generator-ia32.cc |
+++ b/src/compiler/ia32/code-generator-ia32.cc |
@@ -677,6 +677,31 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { |
__ sar_cl(i.OutputOperand()); |
} |
break; |
+ case kIA32AddPair: { |
+ // i.OutputRegister(0) == i.InputRegister(0) ... left low word. |
+ // i.InputRegister(1) ... left high word. |
+ // i.InputRegister(2) ... right low word. |
+ // i.InputRegister(3) ... right high word. |
+ bool use_temp = false; |
+ if (i.OutputRegister(0).code() == i.InputRegister(1).code() || |
+ i.OutputRegister(0).code() == i.InputRegister(3).code()) { |
+ // We cannot write to the output register directly, because it would |
+ // overwrite an input for adc. We have to use the temp register. |
+ use_temp = true; |
+ __ Move(i.TempRegister(0), i.InputRegister(0)); |
+ __ add(i.TempRegister(0), i.InputRegister(2)); |
+ } else { |
+ __ add(i.OutputRegister(0), i.InputRegister(2)); |
+ } |
+ __ adc(i.InputRegister(1), Operand(i.InputRegister(3))); |
+ if (i.OutputRegister(1).code() != i.InputRegister(1).code()) { |
+ __ Move(i.OutputRegister(1), i.InputRegister(1)); |
+ } |
+ if (use_temp) { |
+ __ Move(i.OutputRegister(0), i.TempRegister(0)); |
+ } |
+ break; |
+ } |
case kIA32ShlPair: |
if (HasImmediateInput(instr, 2)) { |
__ ShlPair(i.InputRegister(1), i.InputRegister(0), i.InputInt6(2)); |