[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / Transforms / LoopFusion / guarded.ll
blob1a131178d25e563215070b1bf529ae495b0b48a0
1 ; RUN: opt -S -loop-fusion < %s | FileCheck %s
3 @B = common global [1024 x i32] zeroinitializer, align 16
5 ; CHECK: void @dep_free_parametric
6 ; CHECK-next: entry:
7 ; CHECK: br i1 %{{.*}}, label %[[LOOP1PREHEADER:bb[0-9]*]], label %[[LOOP1SUCC:bb[0-9]+]]
8 ; CHECK: [[LOOP1PREHEADER]]
9 ; CHECK-NEXT: br label %[[LOOP1BODY:bb[0-9]*]]
10 ; CHECK: [[LOOP1BODY]]
11 ; CHECK: br i1 %{{.*}}, label %[[LOOP2BODY:bb[0-9]*]], label %[[LOOP2BODY]]
12 ; CHECK: [[LOOP2BODY]]
13 ; CHECK: br i1 %{{.*}}, label %[[LOOP1BODY]], label %[[LOOP2EXIT:bb[0-9]+]]
14 ; CHECK: [[LOOP2EXIT]]
15 ; CHECK: br label %[[LOOP1SUCC]]
16 ; CHECK: [[LOOP1SUCC]]
17 ; CHECK: ret void
18 define void @dep_free_parametric(i32* noalias %A, i64 %N) {
19 entry:
20   %cmp4 = icmp slt i64 0, %N
21   br i1 %cmp4, label %bb3, label %bb14
23 bb3:                               ; preds = %entry
24   br label %bb5
26 bb5:                                         ; preds = %bb3, %bb5
27   %i.05 = phi i64 [ %inc, %bb5 ], [ 0, %bb3 ]
28   %sub = sub nsw i64 %i.05, 3
29   %add = add nsw i64 %i.05, 3
30   %mul = mul nsw i64 %sub, %add
31   %rem = srem i64 %mul, %i.05
32   %conv = trunc i64 %rem to i32
33   %arrayidx = getelementptr inbounds i32, i32* %A, i64 %i.05
34   store i32 %conv, i32* %arrayidx, align 4
35   %inc = add nsw i64 %i.05, 1
36   %cmp = icmp slt i64 %inc, %N
37   br i1 %cmp, label %bb5, label %bb10
39 bb10:                                 ; preds = %bb5
40   br label %bb14
42 bb14:                                          ; preds = %bb10, %entry
43   %cmp31 = icmp slt i64 0, %N
44   br i1 %cmp31, label %bb8, label %bb12
46 bb8:                              ; preds = %bb14
47   br label %bb9
49 bb9:                                        ; preds = %bb8, %bb9
50   %i1.02 = phi i64 [ %inc14, %bb9 ], [ 0, %bb8 ]
51   %sub7 = sub nsw i64 %i1.02, 3
52   %add8 = add nsw i64 %i1.02, 3
53   %mul9 = mul nsw i64 %sub7, %add8
54   %rem10 = srem i64 %mul9, %i1.02
55   %conv11 = trunc i64 %rem10 to i32
56   %arrayidx12 = getelementptr inbounds [1024 x i32], [1024 x i32]* @B, i64 0, i64 %i1.02
57   store i32 %conv11, i32* %arrayidx12, align 4
58   %inc14 = add nsw i64 %i1.02, 1
59   %cmp3 = icmp slt i64 %inc14, %N
60   br i1 %cmp3, label %bb9, label %bb15
62 bb15:                               ; preds = %bb9
63   br label %bb12
65 bb12:                                        ; preds = %bb15, %bb14
66   ret void