Make sure the regs are low regs for tMUL size reduction.
authorJim Grosbach <grosbach@apple.com>
Fri, 24 Feb 2012 00:53:11 +0000 (00:53 +0000)
committerJim Grosbach <grosbach@apple.com>
Fri, 24 Feb 2012 00:53:11 +0000 (00:53 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@151318 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/ARM/Thumb2SizeReduction.cpp

index 776d0eff5e19a28b1d79005ee6e6c111473b40b7..5ee5f4202efad9f417fb870974ed00b4ba8f793f 100644 (file)
@@ -599,7 +599,12 @@ Thumb2SizeReduce::ReduceTo2Addr(MachineBasicBlock &MBB, MachineInstr *MI,
   unsigned Reg1 = MI->getOperand(1).getReg();
   // t2MUL is "special". The tied source operand is second, not first.
   if (MI->getOpcode() == ARM::t2MUL) {
-    if (Reg0 != MI->getOperand(2).getReg()) {
+    unsigned Reg2 = MI->getOperand(2).getReg();
+    // Early exit if the regs aren't all low regs.
+    if (!isARMLowRegister(Reg0) || !isARMLowRegister(Reg1)
+        || !isARMLowRegister(Reg2))
+      return false;
+    if (Reg0 != Reg2) {
       // If the other operand also isn't the same as the destination, we
       // can't reduce.
       if (Reg1 != Reg0)