[TwoAddressInstructionPass] When looking for a 3 addr conversion after commuting...
[oota-llvm.git] / test / Transforms / LoopStrengthReduce / dont_insert_redundant_ops.ll
index 68eb107f1091694dde063a6d906e4a7cd950f3f6..4a6ec50ab97d52ba5109d8e6c2498b59e918a163 100644 (file)
@@ -1,5 +1,9 @@
 ; Check that this test makes INDVAR and related stuff dead.
-; RUN: llvm-as < %s | opt -loop-reduce | llvm-dis | grep phi | count 2
+; RUN: opt < %s -loop-reduce -S | FileCheck %s
+
+; CHECK: phi
+; CHECK: phi
+; CHECK-NOT: phi
 
 declare i1 @pred()
 
@@ -8,9 +12,9 @@ define void @test1({ i32, i32 }* %P) {
        br label %Loop
 Loop:          ; preds = %Loop, %0
        %INDVAR = phi i32 [ 0, %0 ], [ %INDVAR2, %Loop ]                ; <i32> [#uses=3]
-       %gep1 = getelementptr { i32, i32 }* %P, i32 %INDVAR, i32 0              ; <i32*> [#uses=1]
+       %gep1 = getelementptr { i32, i32 }, { i32, i32 }* %P, i32 %INDVAR, i32 0                ; <i32*> [#uses=1]
        store i32 0, i32* %gep1
-       %gep2 = getelementptr { i32, i32 }* %P, i32 %INDVAR, i32 1              ; <i32*> [#uses=1]
+       %gep2 = getelementptr { i32, i32 }, { i32, i32 }* %P, i32 %INDVAR, i32 1                ; <i32*> [#uses=1]
        store i32 0, i32* %gep2
        %INDVAR2 = add i32 %INDVAR, 1           ; <i32> [#uses=1]
        %cond = call i1 @pred( )                ; <i1> [#uses=1]
@@ -24,9 +28,9 @@ define void @test2([2 x i32]* %P) {
        br label %Loop
 Loop:          ; preds = %Loop, %0
        %INDVAR = phi i32 [ 0, %0 ], [ %INDVAR2, %Loop ]                ; <i32> [#uses=3]
-       %gep1 = getelementptr [2 x i32]* %P, i32 %INDVAR, i64 0         ; <i32*> [#uses=1]
+       %gep1 = getelementptr [2 x i32], [2 x i32]* %P, i32 %INDVAR, i64 0              ; <i32*> [#uses=1]
        store i32 0, i32* %gep1
-       %gep2 = getelementptr [2 x i32]* %P, i32 %INDVAR, i64 1         ; <i32*> [#uses=1]
+       %gep2 = getelementptr [2 x i32], [2 x i32]* %P, i32 %INDVAR, i64 1              ; <i32*> [#uses=1]
        store i32 0, i32* %gep2
        %INDVAR2 = add i32 %INDVAR, 1           ; <i32> [#uses=1]
        %cond = call i1 @pred( )                ; <i1> [#uses=1]