[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