Index: src/compiler/x64/code-generator-x64.cc |
diff --git a/src/compiler/x64/code-generator-x64.cc b/src/compiler/x64/code-generator-x64.cc |
index 4d078b759608513a6cabd9b02e5d6a99215d0a68..8e60c7742668075ba7c82fa6e61b335bf0b49dc7 100644 |
--- a/src/compiler/x64/code-generator-x64.cc |
+++ b/src/compiler/x64/code-generator-x64.cc |
@@ -447,6 +447,12 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { |
__ addq(rsp, Immediate(kDoubleSize)); |
break; |
} |
+ case kCvtss2sd: |
+ __ cvtss2sd(i.OutputDoubleRegister(), i.InputDoubleRegister(0)); |
+ break; |
+ case kCvtsd2ss: |
+ __ cvtsd2ss(i.OutputDoubleRegister(), i.InputDoubleRegister(0)); |
+ break; |
case kSSEFloat64ToInt32: { |
RegisterOrOperand input = i.InputRegisterOrOperand(0); |
if (input.type == kDoubleRegister) { |
@@ -561,12 +567,10 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { |
case kX64Movss: |
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 kX64Movsd: |