remove the StructRetPromotion pass. It is unused, not maintained and
[oota-llvm.git] / test / Transforms / GVN / rle-phi-translate.ll
index b5311eec59c4c10ac79b876f7b8df2b7babe9fb7..6731f43c0d2b05b92a77cdbfcea46d3224b7b292 100644 (file)
-; RUN: llvm-as < %s | opt -gvn | llvm-dis | grep {%cv = phi i32}
-; RUN: llvm-as < %s | opt -gvn | llvm-dis | grep {%bv = phi i32}
+; RUN: opt < %s -gvn -S | FileCheck %s
+
 target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
 target triple = "i386-apple-darwin7"
 
-define i32 @g(i32* %b, i32* %c) nounwind {
+define i32 @test1(i32* %b, i32* %c) nounwind {
+; CHECK: @test1
 entry:
-       %g = alloca i32         ; <i32*> [#uses=4]
-       %t1 = icmp eq i32* %b, null             ; <i1> [#uses=1]
+       %g = alloca i32
+       %t1 = icmp eq i32* %b, null
        br i1 %t1, label %bb, label %bb1
 
-bb:            ; preds = %entry
-       %t2 = load i32* %c, align 4             ; <i32> [#uses=1]
-       %t3 = add i32 %t2, 1            ; <i32> [#uses=1]
+bb:
+       %t2 = load i32* %c, align 4
+       %t3 = add i32 %t2, 1
        store i32 %t3, i32* %g, align 4
        br label %bb2
 
 bb1:           ; preds = %entry
-       %t5 = load i32* %b, align 4             ; <i32> [#uses=1]
-       %t6 = add i32 %t5, 1            ; <i32> [#uses=1]
+       %t5 = load i32* %b, align 4
+       %t6 = add i32 %t5, 1
        store i32 %t6, i32* %g, align 4
        br label %bb2
 
 bb2:           ; preds = %bb1, %bb
-       %c_addr.0 = phi i32* [ %g, %bb1 ], [ %c, %bb ]          ; <i32*> [#uses=1]
-       %b_addr.0 = phi i32* [ %b, %bb1 ], [ %g, %bb ]          ; <i32*> [#uses=1]
-       %cv = load i32* %c_addr.0, align 4              ; <i32> [#uses=1]
-       %bv = load i32* %b_addr.0, align 4              ; <i32> [#uses=1]
-       %ret = add i32 %cv, %bv         ; <i32> [#uses=1]
+       %c_addr.0 = phi i32* [ %g, %bb1 ], [ %c, %bb ]
+       %b_addr.0 = phi i32* [ %b, %bb1 ], [ %g, %bb ]
+       %cv = load i32* %c_addr.0, align 4
+       %bv = load i32* %b_addr.0, align 4
+; CHECK: %bv = phi i32
+; CHECK: %cv = phi i32
+; CHECK-NOT: load
+; CHECK: ret i32
+       %ret = add i32 %cv, %bv
        ret i32 %ret
 }
 
+define i8 @test2(i1 %cond, i32* %b, i32* %c) nounwind {
+; CHECK: @test2
+entry:
+  br i1 %cond, label %bb, label %bb1
+
+bb:
+  %b1 = bitcast i32* %b to i8*
+  store i8 4, i8* %b1
+  br label %bb2
+
+bb1:
+  %c1 = bitcast i32* %c to i8*
+  store i8 92, i8* %c1
+  br label %bb2
+
+bb2:
+  %d = phi i32* [ %c, %bb1 ], [ %b, %bb ]
+  %d1 = bitcast i32* %d to i8*
+  %dv = load i8* %d1
+; CHECK: %dv = phi i8 [ 92, %bb1 ], [ 4, %bb ]
+; CHECK-NOT: load
+; CHECK: ret i8 %dv
+  ret i8 %dv
+}
+
+define i32 @test3(i1 %cond, i32* %b, i32* %c) nounwind {
+; CHECK: @test3
+entry:
+  br i1 %cond, label %bb, label %bb1
+
+bb:
+  %b1 = getelementptr i32* %b, i32 17
+  store i32 4, i32* %b1
+  br label %bb2
+
+bb1:
+  %c1 = getelementptr i32* %c, i32 7
+  store i32 82, i32* %c1
+  br label %bb2
+
+bb2:
+  %d = phi i32* [ %c, %bb1 ], [ %b, %bb ]
+  %i = phi i32 [ 7, %bb1 ], [ 17, %bb ]
+  %d1 = getelementptr i32* %d, i32 %i
+  %dv = load i32* %d1
+; CHECK: %dv = phi i32 [ 82, %bb1 ], [ 4, %bb ]
+; CHECK-NOT: load
+; CHECK: ret i32 %dv
+  ret i32 %dv
+}
+
+; PR5313
+define i32 @test4(i1 %cond, i32* %b, i32* %c) nounwind {
+; CHECK: @test4
+entry:
+  br i1 %cond, label %bb, label %bb1
+
+bb:
+  store i32 4, i32* %b
+  br label %bb2
+
+bb1:
+  %c1 = getelementptr i32* %c, i32 7
+  store i32 82, i32* %c1
+  br label %bb2
+
+bb2:
+  %d = phi i32* [ %c, %bb1 ], [ %b, %bb ]
+  %i = phi i32 [ 7, %bb1 ], [ 0, %bb ]
+  %d1 = getelementptr i32* %d, i32 %i
+  %dv = load i32* %d1
+; CHECK: %dv = phi i32 [ 82, %bb1 ], [ 4, %bb ]
+; CHECK-NOT: load
+; CHECK: ret i32 %dv
+  ret i32 %dv
+}
+
+
+
+; void test5(int N, double* G) {
+;   for (long j = 1; j < 1000; j++)
+;     G[j] = G[j] + G[j-1];
+; }
+;
+; Should compile into one load in the loop.
+define void @test5(i32 %N, double* nocapture %G) nounwind ssp {
+; CHECK: @test5
+bb.nph:
+  br label %for.body
+
+for.body:
+  %indvar = phi i64 [ 0, %bb.nph ], [ %tmp, %for.body ]
+  %arrayidx6 = getelementptr double* %G, i64 %indvar
+  %tmp = add i64 %indvar, 1
+  %arrayidx = getelementptr double* %G, i64 %tmp
+  %tmp3 = load double* %arrayidx
+  %tmp7 = load double* %arrayidx6
+  %add = fadd double %tmp3, %tmp7
+  store double %add, double* %arrayidx
+  %exitcond = icmp eq i64 %tmp, 999
+  br i1 %exitcond, label %for.end, label %for.body
+; CHECK: for.body:
+; CHECK: phi double
+; CHECK: load double
+; CHECK-NOT: load double
+; CHECK: br i1
+for.end:
+  ret void
+}