Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / Analysis / LoopAccessAnalysis / forward-loop-carried.ll
blob650887f2f6f5164fc986d08f463bc7d331665f39
1 ; RUN: opt -passes='print<access-info>' -disable-output  < %s 2>&1 | FileCheck %s
3 ;   for (unsigned i = 0; i < 100; i++) {
4 ;     A[i+8] = B[i] + 2;
5 ;     C[i] = A[i] * 2;
6 ;   }
8 target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
10 define void @f(ptr %A, ptr %B, ptr %C, i64 %N) {
12 ; CHECK: Dependences:
13 ; CHECK-NEXT: Forward:
14 ; CHECK-NEXT:   store i32 %a_p1, ptr %Aidx_ahead, align 4 ->
15 ; CHECK-NEXT:   %a = load i32, ptr %Aidx, align 4
17 entry:
18   br label %for.body
20 for.body:                                         ; preds = %for.body, %entry
21   %indvars.iv = phi i64 [ 0, %entry ], [ %indvars.iv.next, %for.body ]
22   %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1
24   %idx = add nuw nsw i64 %indvars.iv, 8
26   %Aidx_ahead = getelementptr inbounds i32, ptr %A, i64 %idx
27   %Bidx = getelementptr inbounds i32, ptr %B, i64 %indvars.iv
28   %Cidx = getelementptr inbounds i32, ptr %C, i64 %indvars.iv
29   %Aidx = getelementptr inbounds i32, ptr %A, i64 %indvars.iv
31   %b = load i32, ptr %Bidx, align 4
32   %a_p1 = add i32 %b, 2
33   store i32 %a_p1, ptr %Aidx_ahead, align 4
35   %a = load i32, ptr %Aidx, align 4
36   %c = mul i32 %a, 2
37   store i32 %c, ptr %Cidx, align 4
39   %exitcond = icmp eq i64 %indvars.iv.next, %N
40   br i1 %exitcond, label %for.end, label %for.body
42 for.end:                                          ; preds = %for.body
43   ret void