| 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:
|
|
|