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 482376d6aa15851c9e2b32ce6f6706e513475324..cce57b484bccba2f23e950825c152d58fff2e2d4 100644 |
--- a/src/compiler/ia32/code-generator-ia32.cc |
+++ b/src/compiler/ia32/code-generator-ia32.cc |
@@ -688,6 +688,22 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) { |
__ PairShl_cl(i.InputRegister(1), i.InputRegister(0)); |
} |
break; |
+ case kIA32PairShr: |
+ if (HasImmediateInput(instr, 2)) { |
+ __ PairShr(i.InputRegister(1), i.InputRegister(0), i.InputInt6(2)); |
+ } else { |
+ // Shift has been loaded into CL by the register allocator. |
+ __ PairShr_cl(i.InputRegister(1), i.InputRegister(0)); |
+ } |
+ break; |
+ case kIA32PairSar: |
+ if (HasImmediateInput(instr, 2)) { |
+ __ PairSar(i.InputRegister(1), i.InputRegister(0), i.InputInt6(2)); |
+ } else { |
+ // Shift has been loaded into CL by the register allocator. |
+ __ PairSar_cl(i.InputRegister(1), i.InputRegister(0)); |
+ } |
+ break; |
case kIA32Ror: |
if (HasImmediateInput(instr, 1)) { |
__ ror(i.OutputOperand(), i.InputInt5(1)); |