[llvm-commits] CVS: llvm/test/Regression/Transforms/CondProp/phisimplify2.ll
Chris Lattner
lattner at cs.uiuc.edu
Thu Aug 4 18:00:07 PDT 2005
Changes in directory llvm/test/Regression/Transforms/CondProp:
phisimplify2.ll added (r1.1)
---
Log message:
new testcase that condprop should handle. The PHI node becomes useless
after threading the branch, because both operands are the same value.
---
Diffs of the changes: (+36 -0)
phisimplify2.ll | 36 ++++++++++++++++++++++++++++++++++++
1 files changed, 36 insertions(+)
Index: llvm/test/Regression/Transforms/CondProp/phisimplify2.ll
diff -c /dev/null llvm/test/Regression/Transforms/CondProp/phisimplify2.ll:1.1
*** /dev/null Thu Aug 4 20:00:06 2005
--- llvm/test/Regression/Transforms/CondProp/phisimplify2.ll Thu Aug 4 19:59:55 2005
***************
*** 0 ****
--- 1,36 ----
+ ; RUN: llvm-as < %s | opt -condprop | llvm-dis | not grep phi
+
+ declare bool %foo()
+
+ int %test(uint %C) {
+ %Val = call bool %foo()
+ switch uint %C, label %T1 [
+ uint 4, label %T2
+ uint 17, label %T3
+ ]
+ T1:
+ call void %a()
+ br label %Cont
+ T2:
+ call void %b()
+ br label %Cont
+ T3:
+ call void %c()
+ br label %Cont
+
+ Cont:
+ ;; PHI becomes dead after threading T2
+ %C2 = phi bool [%Val, %T1], [true, %T2], [%Val, %T3]
+ br bool %C2, label %L2, label %F2
+ L2:
+ call void %d()
+ ret int 17
+ F2:
+ call void %e()
+ ret int 1
+ }
+ declare void %a()
+ declare void %b()
+ declare void %c()
+ declare void %d()
+ declare void %e()
More information about the llvm-commits
mailing list