Add a priority queue class, which is a wrapper around std::priority_queue
[oota-llvm.git] / test / Transforms / LoopStrengthReduce / invariant_value_first_arg.ll
index 0289badddc418fdb314edb53bcb8377674fb34be..8e9cbc4a81ef81aaeba4a7afc9204a47d5d2b8be 100644 (file)
@@ -1,19 +1,20 @@
 ; Check that the index of 'P[outer]' is pulled out of the loop.
-; RUN: llvm-upgrade < %s | llvm-as | opt -loop-reduce | llvm-dis | not grep 'getelementptr.*%outer.*%INDVAR'
+; RUN: llvm-as < %s | opt -loop-reduce | llvm-dis | \
+; RUN:   not grep {getelementptr.*%outer.*%INDVAR}
 
-declare bool %pred()
+declare i1 @pred()
 
-void %test([10000 x int]* %P, int %outer) {
+define void @test([10000 x i32]* %P, i32 %outer) {
+; <label>:0
        br label %Loop
-Loop:
-       %INDVAR = phi int [0, %0], [%INDVAR2, %Loop]
-
-       %STRRED = getelementptr [10000 x int]* %P, int %outer, int %INDVAR
-       store int 0, int* %STRRED
-
-       %INDVAR2 = add int %INDVAR, 1
-       %cond = call bool %pred()
-       br bool %cond, label %Loop, label %Out
-Out:
+Loop:          ; preds = %Loop, %0
+       %INDVAR = phi i32 [ 0, %0 ], [ %INDVAR2, %Loop ]                ; <i32> [#uses=2]
+       %STRRED = getelementptr [10000 x i32]* %P, i32 %outer, i32 %INDVAR              ; <i32*> [#uses=1]
+       store i32 0, i32* %STRRED
+       %INDVAR2 = add i32 %INDVAR, 1           ; <i32> [#uses=1]
+       %cond = call i1 @pred( )                ; <i1> [#uses=1]
+       br i1 %cond, label %Loop, label %Out
+Out:           ; preds = %Loop
        ret void
 }
+