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