[llvm-commits] CVS: llvm/test/Regression/Transforms/LoopStrengthReduce/exit_compare_live_range.ll related_indvars.ll
Chris Lattner
lattner at cs.uiuc.edu
Fri Aug 5 12:47:51 PDT 2005
Changes in directory llvm/test/Regression/Transforms/LoopStrengthReduce:
exit_compare_live_range.ll added (r1.1)
related_indvars.ll added (r1.1)
---
Log message:
two simple testcases loopreduce should handle but does not yet currently
---
Diffs of the changes: (+50 -0)
exit_compare_live_range.ll | 21 +++++++++++++++++++++
related_indvars.ll | 29 +++++++++++++++++++++++++++++
2 files changed, 50 insertions(+)
Index: llvm/test/Regression/Transforms/LoopStrengthReduce/exit_compare_live_range.ll
diff -c /dev/null llvm/test/Regression/Transforms/LoopStrengthReduce/exit_compare_live_range.ll:1.1
*** /dev/null Fri Aug 5 14:47:49 2005
--- llvm/test/Regression/Transforms/LoopStrengthReduce/exit_compare_live_range.ll Fri Aug 5 14:47:39 2005
***************
*** 0 ****
--- 1,21 ----
+ ; Make sure that the compare instruction occurs after the increment to avoid
+ ; having overlapping live ranges that result in copies. We want the setcc instruction
+ ; immediately before the conditional branch.
+ ;
+ ; RUN: llvm-as < %s | opt -loop-reduce | llvm-dis | %prcontext 'br bool' 1 | grep set
+ ; XFAIL: *
+
+ void %foo(float* %D, uint %E) {
+ entry:
+ br label %no_exit
+
+ no_exit:
+ %indvar = phi uint [ 0, %entry ], [ %indvar.next, %no_exit ]
+ volatile store float 0.0, float* %D
+ %indvar.next = add uint %indvar, 1 ; <uint> [#uses=2]
+ %exitcond = seteq uint %indvar.next, %E ; <bool> [#uses=1]
+ br bool %exitcond, label %loopexit, label %no_exit
+
+ loopexit:
+ ret void
+ }
Index: llvm/test/Regression/Transforms/LoopStrengthReduce/related_indvars.ll
diff -c /dev/null llvm/test/Regression/Transforms/LoopStrengthReduce/related_indvars.ll:1.1
*** /dev/null Fri Aug 5 14:47:51 2005
--- llvm/test/Regression/Transforms/LoopStrengthReduce/related_indvars.ll Fri Aug 5 14:47:39 2005
***************
*** 0 ****
--- 1,29 ----
+ ; RUN: llvm-as < %s | opt -loop-reduce | llvm-dis | grep phi | wc -l | grep 1
+
+ ; This should only result in one PHI node!
+ ; XFAIL: *
+
+ ; void foo(double *D, double *E, double F) {
+ ; while (D != E)
+ ; *D++ = F;
+ ; }
+
+ void %foo(double* %D, double* %E, double %F) {
+ entry:
+ %tmp.24 = seteq double* %D, %E ; <bool> [#uses=1]
+ br bool %tmp.24, label %return, label %no_exit
+
+ no_exit: ; preds = %no_exit, %entry
+ %indvar = phi uint [ 0, %entry ], [ %indvar.next, %no_exit ] ; <uint> [#uses=3]
+ %D_addr.0.0.rec = cast uint %indvar to int ; <int> [#uses=1]
+ %D_addr.0.0 = getelementptr double* %D, uint %indvar ; <double*> [#uses=1]
+ %inc.rec = add int %D_addr.0.0.rec, 1 ; <int> [#uses=1]
+ %inc = getelementptr double* %D, int %inc.rec ; <double*> [#uses=1]
+ store double %F, double* %D_addr.0.0
+ %tmp.2 = seteq double* %inc, %E ; <bool> [#uses=1]
+ %indvar.next = add uint %indvar, 1 ; <uint> [#uses=1]
+ br bool %tmp.2, label %return, label %no_exit
+
+ return: ; preds = %no_exit, %entry
+ ret void
+ }
More information about the llvm-commits
mailing list