[llvm] r300495 - [InstCombine] Matchers work with both ConstExpr and Instructions.

Davide Italiano via llvm-commits llvm-commits at lists.llvm.org
Mon Apr 17 13:49:50 PDT 2017


Author: davide
Date: Mon Apr 17 15:49:50 2017
New Revision: 300495

URL: http://llvm.org/viewvc/llvm-project?rev=300495&view=rev
Log:
[InstCombine] Matchers work with both ConstExpr and Instructions.

So, `cast<Instruction>` is not guaranteed to succeed. Change the
code so that we create a new constant and use it in the newly
created instruction, as it's done in other places in InstCombine.

OK'ed by Sanjay/Craig. Fixes PR32686.

Added:
    llvm/trunk/test/Transforms/InstCombine/pr32686.ll
Modified:
    llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp

Modified: llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp?rev=300495&r1=300494&r2=300495&view=diff
==============================================================================
--- llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp (original)
+++ llvm/trunk/lib/Transforms/InstCombine/InstCombineAndOrXor.cpp Mon Apr 17 15:49:50 2017
@@ -2078,7 +2078,7 @@ Instruction *InstCombiner::visitOr(Binar
       Value *NOr = Builder->CreateOr(A, Op1);
       NOr->takeName(Op0);
       return BinaryOperator::CreateXor(NOr,
-                                       cast<Instruction>(Op0)->getOperand(1));
+                                       ConstantInt::get(NOr->getType(), *C));
     }
 
     // Y|(X^C) -> (X|Y)^C iff Y&C == 0
@@ -2087,7 +2087,7 @@ Instruction *InstCombiner::visitOr(Binar
       Value *NOr = Builder->CreateOr(A, Op0);
       NOr->takeName(Op0);
       return BinaryOperator::CreateXor(NOr,
-                                       cast<Instruction>(Op1)->getOperand(1));
+                                       ConstantInt::get(NOr->getType(), *C));
     }
   }
 

Added: llvm/trunk/test/Transforms/InstCombine/pr32686.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/InstCombine/pr32686.ll?rev=300495&view=auto
==============================================================================
--- llvm/trunk/test/Transforms/InstCombine/pr32686.ll (added)
+++ llvm/trunk/test/Transforms/InstCombine/pr32686.ll Mon Apr 17 15:49:50 2017
@@ -0,0 +1,22 @@
+; RUN: opt -S -instcombine %s | FileCheck %s
+
+; CHECK-LABEL: define void @tinkywinky
+; CHECK-NEXT:   %patatino = load i8, i8* @a, align 1
+; CHECK-NEXT:   %tobool = icmp eq i8 %patatino, 0
+; CHECK-NEXT:   %1 = zext i1 %tobool to i32
+; CHECK-NEXT:   %or1 = or i32 %1, or (i32 zext (i1 icmp ne (i32* bitcast (i8* @a to i32*), i32* @b) to i32), i32 2)
+; CHECK-NEXT:   store i32 %or1, i32* @b, align 4
+; CHECK-NEXT:   ret void
+
+ at a = external global i8
+ at b = external global i32
+
+define void @tinkywinky() {
+  %patatino = load i8, i8* @a
+  %tobool = icmp ne i8 %patatino, 0
+  %lnot = xor i1 %tobool, true
+  %lnot.ext = zext i1 %lnot to i32
+  %or = or i32 xor (i32 zext (i1 icmp ne (i32* bitcast (i8* @a to i32*), i32* @b) to i32), i32 2), %lnot.ext
+  store i32 %or, i32* @b, align 4
+  ret void
+}




More information about the llvm-commits mailing list