[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