AArch64/ARM64: move ARM64 into AArch64's place
[oota-llvm.git] / test / Transforms / LoopStrengthReduce / share_ivs.ll
index 76bfe1d529c923d0bbb0e0d805a62671c2261e1e..0459bc849bfb303967a60f43dd0618f99ac83c5e 100644 (file)
@@ -1,24 +1,24 @@
-; RUN: llvm-upgrade < %s | llvm-as | opt -loop-reduce | llvm-dis | grep phi | wc -l | grep 1
+; RUN: opt < %s -loop-reduce -S | grep phi | count 1
 
 ; This testcase should have ONE stride 18 indvar, the other use should have a
 ; loop invariant value (B) added to it inside of the loop, instead of having
 ; a whole indvar based on B for it.
 
-declare bool %cond(uint)
+declare i1 @cond(i32)
 
-void %test(uint %B) {
+define void @test(i32 %B) {
+; <label>:0
        br label %Loop
-Loop:
-       %IV = phi uint [0, %0], [%IVn, %Loop]
-
-       %C = mul uint %IV, 18
-       %D = mul uint %IV, 18
-       %E = add uint %D, %B
-
-       %cnd = call bool %cond(uint %E)
-       call bool %cond(uint %C)
-       %IVn = add uint %IV, 1
-       br bool %cnd, label %Loop, label %Out
-Out:
+Loop:          ; preds = %Loop, %0
+       %IV = phi i32 [ 0, %0 ], [ %IVn, %Loop ]                ; <i32> [#uses=3]
+       %C = mul i32 %IV, 18            ; <i32> [#uses=1]
+       %D = mul i32 %IV, 18            ; <i32> [#uses=1]
+       %E = add i32 %D, %B             ; <i32> [#uses=1]
+       %cnd = call i1 @cond( i32 %E )          ; <i1> [#uses=1]
+       call i1 @cond( i32 %C )         ; <i1>:1 [#uses=0]
+       %IVn = add i32 %IV, 1           ; <i32> [#uses=1]
+       br i1 %cnd, label %Loop, label %Out
+Out:           ; preds = %Loop
        ret void
 }
+