diff options
author | Chris Lattner <sabre@nondot.org> | 2005-09-10 01:14:37 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-09-10 01:14:37 +0000 |
commit | 0c7728e4d6dc89c8d60f7c923f1553b6f2abc9be (patch) | |
tree | 2a0e2ac626594b9d5e2a3f3e35ba1ff6640dc1a3 /llvm/test/Regression/Transforms/LoopStrengthReduce | |
parent | 4309c3a7856a5d6259e94b3afb494df00bf444fd (diff) | |
download | bcm5719-llvm-0c7728e4d6dc89c8d60f7c923f1553b6f2abc9be.tar.gz bcm5719-llvm-0c7728e4d6dc89c8d60f7c923f1553b6f2abc9be.zip |
new testcase
llvm-svn: 23305
Diffstat (limited to 'llvm/test/Regression/Transforms/LoopStrengthReduce')
-rw-r--r-- | llvm/test/Regression/Transforms/LoopStrengthReduce/dont-hoist-simple-loop-constants.ll | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/llvm/test/Regression/Transforms/LoopStrengthReduce/dont-hoist-simple-loop-constants.ll b/llvm/test/Regression/Transforms/LoopStrengthReduce/dont-hoist-simple-loop-constants.ll new file mode 100644 index 00000000000..b53ce9571c6 --- /dev/null +++ b/llvm/test/Regression/Transforms/LoopStrengthReduce/dont-hoist-simple-loop-constants.ll @@ -0,0 +1,24 @@ +; RUN: llvm-as < %s | opt -loop-reduce | llvm-dis | not grep 'cast uint 1 to uint' +; The setlt wants to use a value that is incremented one more than the dominant +; IV. Don't insert the 1 outside the loop, preventing folding it into the add. + +implementation ; Functions: + +void %test([700 x int]* %nbeaux_.0__558, int* %i_.16574) { +then.0: + br label %no_exit.2 + +no_exit.2: ; preds = %no_exit.2, %then.0 + %indvar630 = phi uint [ 0, %then.0 ], [ %indvar.next631, %no_exit.2 ] ; <uint> [#uses=3] + %indvar630 = cast uint %indvar630 to int ; <int> [#uses=1] + %tmp.38 = getelementptr [700 x int]* %nbeaux_.0__558, int 0, uint %indvar630 ; <int*> [#uses=1] + store int 0, int* %tmp.38 + %inc.2 = add int %indvar630, 2 ; <int> [#uses=2] + %tmp.34 = setlt int %inc.2, 701 ; <bool> [#uses=1] + %indvar.next631 = add uint %indvar630, 1 ; <uint> [#uses=1] + br bool %tmp.34, label %no_exit.2, label %loopexit.2.loopexit + +loopexit.2.loopexit: ; preds = %no_exit.2 + store int %inc.2, int* %i_.16574 + ret void +} |