Recognize and simplify
authorAnders Carlsson <andersca@mac.com>
Sun, 30 Jan 2011 22:01:13 +0000 (22:01 +0000)
committerAnders Carlsson <andersca@mac.com>
Sun, 30 Jan 2011 22:01:13 +0000 (22:01 +0000)
(A+B) == A  ->  B == 0
A == (A+B)  ->  B == 0

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@124567 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/InstCombine/InstCombineCompares.cpp
test/Transforms/InstCombine/add.ll

index fe436bce210c754dbddde188cdb03c6eb9260053..8c5e7e48c4487082bcaf59d3cbe973fb7a73b982 100644 (file)
@@ -2341,7 +2341,17 @@ Instruction *InstCombiner::visitICmpInst(ICmpInst &I) {
     if (match(Op1, m_Sub(m_Specific(Op0), m_Value(B))))
       return new ICmpInst(I.getPredicate(), B,
                           Constant::getNullValue(B->getType()));
-    
+
+    // (A+B) == A  ->  B == 0
+    if (match(Op0, m_Add(m_Specific(Op1), m_Value(B))))
+      return new ICmpInst(I.getPredicate(), B,
+                          Constant::getNullValue(B->getType()));
+
+    // A == (A+B)  ->  B == 0
+    if (match(Op1, m_Add(m_Specific(Op0), m_Value(B))))
+      return new ICmpInst(I.getPredicate(), B,
+                          Constant::getNullValue(B->getType()));
+
     // (X&Z) == (Y&Z) -> (X^Y) & Z == 0
     if (Op0->hasOneUse() && Op1->hasOneUse() &&
         match(Op0, m_And(m_Value(A), m_Value(B))) && 
index 4719809d6d36944107595bbd71540fa9e63de629..b3a7f5260799bdf7e8b63a5f72c644f4756d5fa5 100644 (file)
@@ -275,3 +275,19 @@ define i32 @test36(i32 %a) {
        %q = and i32 %z, 1  ; always zero
        ret i32 %q
 }
+
+define i32 @test37(i32 %a, i32 %b) nounwind readnone {
+entry:
+  %add = add nsw i32 %a, %b
+  %cmp = icmp eq i32 %add, %a
+  %conv = zext i1 %cmp to i32
+  ret i32 %conv
+}
+
+define i32 @test38(i32 %a, i32 %b) nounwind readnone {
+entry:
+  %add = add nsw i32 %a, %b
+  %cmp = icmp eq i32 %add, %a
+  %conv = zext i1 %cmp to i32
+  ret i32 %conv
+}