InstCombine: Propagate exact for (sdiv X, Y) -> (udiv X, Y)
authorDavid Majnemer <david.majnemer@gmail.com>
Sat, 22 Nov 2014 20:00:38 +0000 (20:00 +0000)
committerDavid Majnemer <david.majnemer@gmail.com>
Sat, 22 Nov 2014 20:00:38 +0000 (20:00 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@222624 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/InstCombine/InstCombineMulDivRem.cpp
test/Transforms/InstCombine/div.ll

index b79f55e1435a939570a53d5c12ee155ab0a5fc26..216177ff2b42616d838d72d330abc65f1b4c56f5 100644 (file)
@@ -1097,7 +1097,9 @@ Instruction *InstCombiner::visitSDiv(BinaryOperator &I) {
     if (MaskedValueIsZero(Op0, Mask, 0, &I)) {
       if (MaskedValueIsZero(Op1, Mask, 0, &I)) {
         // X sdiv Y -> X udiv Y, iff X and Y don't have sign bit set
-        return BinaryOperator::CreateUDiv(Op0, Op1, I.getName());
+        auto *BO = BinaryOperator::CreateUDiv(Op0, Op1, I.getName());
+        BO->setIsExact(I.isExact());
+        return BO;
       }
 
       if (match(Op1, m_Shl(m_Power2(), m_Value()))) {
index f4166ec5cbcdb08e98a76b07e4e4199b253eb5d2..cfe346e1f2b2ffdc44260015e367d6df0d92a6e9 100644 (file)
@@ -304,3 +304,13 @@ define <2 x i64> @test34(<2 x i64> %x) nounwind {
 ; CHECK-NEXT: sdiv exact <2 x i64> %x, <i64 -3, i64 -4>
 ; CHECK-NEXT: ret <2 x i64>
 }
+
+define i32 @test35(i32 %A) {
+  %and = and i32 %A, 2147483647
+  %mul = sdiv exact i32 %and, 2147483647
+  ret i32 %mul
+; CHECK-LABEL: @test35(
+; CHECK-NEXT: %[[and:.*]]  = and i32 %A, 2147483647
+; CHECK-NEXT: %[[udiv:.*]] = udiv exact i32 %[[and]], 2147483647
+; CHECK-NEXT: ret i32 %[[udiv]]
+}