summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2007-07-04 22:33:23 +0000
committerOwen Anderson <resistor@mac.com>2007-07-04 22:33:23 +0000
commitca1a184fd812704a00b8d2c520c3757b1371b12a (patch)
treeabd4415dfd19e75bf1ca616dff01a8f9d13452b0
parent0e535c3c8e9e336c52cbad3712368701b94eaebb (diff)
downloadbcm5719-llvm-ca1a184fd812704a00b8d2c520c3757b1371b12a.tar.gz
bcm5719-llvm-ca1a184fd812704a00b8d2c520c3757b1371b12a.zip
Fix another bug, this time in PREing select instructions.
llvm-svn: 37878
-rw-r--r--llvm/lib/Transforms/Scalar/GVNPRE.cpp3
-rw-r--r--llvm/test/Transforms/GVNPRE/2007-07-04-SelectInst.ll18
2 files changed, 19 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Scalar/GVNPRE.cpp b/llvm/lib/Transforms/Scalar/GVNPRE.cpp
index 5d52aa48875..e5e3710643b 100644
--- a/llvm/lib/Transforms/Scalar/GVNPRE.cpp
+++ b/llvm/lib/Transforms/Scalar/GVNPRE.cpp
@@ -1586,8 +1586,7 @@ void GVNPRE::insertion_pre(Value* e, BasicBlock* BB,
newVal = new ExtractElementInst(s1, s2, S->getName()+".gvnpre",
(*PI)->getTerminator());
else if (SelectInst* S = dyn_cast<SelectInst>(U))
- newVal = new SelectInst(S->getCondition(), S->getTrueValue(),
- S->getFalseValue(), S->getName()+".gvnpre",
+ newVal = new SelectInst(s1, s2, s3, S->getName()+".gvnpre",
(*PI)->getTerminator());
else if (CastInst* C = dyn_cast<CastInst>(U))
newVal = CastInst::create(C->getOpcode(), s1, C->getType(),
diff --git a/llvm/test/Transforms/GVNPRE/2007-07-04-SelectInst.ll b/llvm/test/Transforms/GVNPRE/2007-07-04-SelectInst.ll
new file mode 100644
index 00000000000..944a7005938
--- /dev/null
+++ b/llvm/test/Transforms/GVNPRE/2007-07-04-SelectInst.ll
@@ -0,0 +1,18 @@
+; RUN: llvm-as < %s | opt -gvnpre | llvm-dis
+
+define void @set_depth_values(i32 %level) {
+cond_true90: ; preds = %cond_next84
+ br i1 false, label %cond_true105, label %cond_true151
+
+cond_true105: ; preds = %cond_true90
+ %tmp132 = add i32 %level, -3 ; <i32> [#uses=2]
+ %tmp133 = icmp sgt i32 %tmp132, 0 ; <i1> [#uses=1]
+ %max134 = select i1 %tmp133, i32 %tmp132, i32 1 ; <i32> [#uses=0]
+ br label %cond_true151
+
+cond_true151: ; preds = %cond_true140, %cond_true105
+ %tmp153 = add i32 %level, -3 ; <i32> [#uses=2]
+ %tmp154 = icmp sgt i32 %tmp153, 0 ; <i1> [#uses=1]
+ %max155 = select i1 %tmp154, i32 %tmp153, i32 1 ; <i32> [#uses=0]
+ ret void
+}
OpenPOWER on IntegriCloud