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 deab7cd9f6239f979c03db4fb1a6b92837449862..9d9a5691c6c3454bf3b910b39dc1905a78ce1b48 100644 |
--- a/src/compiler/ia32/code-generator-ia32.cc |
+++ b/src/compiler/ia32/code-generator-ia32.cc |
@@ -288,6 +288,12 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { |
case kSSEFloat64Sqrt: |
__ sqrtsd(i.OutputDoubleRegister(), i.InputOperand(0)); |
break; |
+ case kSSECvtss2sd: |
+ __ cvtss2sd(i.OutputDoubleRegister(), i.InputDoubleRegister(0)); |
+ break; |
+ case kSSECvtsd2ss: |
+ __ cvtsd2ss(i.OutputDoubleRegister(), i.InputDoubleRegister(0)); |
+ break; |
case kSSEFloat64ToInt32: |
__ cvttsd2si(i.OutputRegister(), i.InputOperand(0)); |
break; |
@@ -363,12 +369,10 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { |
case kIA32Movss: |
if (instr->HasOutput()) { |
__ movss(i.OutputDoubleRegister(), i.MemoryOperand()); |
- __ cvtss2sd(i.OutputDoubleRegister(), i.OutputDoubleRegister()); |
} else { |
int index = 0; |
Operand operand = i.MemoryOperand(&index); |
- __ cvtsd2ss(xmm0, i.InputDoubleRegister(index)); |
- __ movss(operand, xmm0); |
+ __ movss(operand, i.InputDoubleRegister(index)); |
} |
break; |
case kIA32Push: |