blob: d1a2373c9a48ee587c2c1a69646358ae2ff39d40 [file] [log] [blame]
Tobias Grosserd1e33e72015-02-19 05:31:07 +00001; RUN: opt -S %loadPolly -polly-detect-unprofitable -basicaa -polly-dependences-analysis-type=value-based -polly-dce -polly-dce-precise-steps=2 -polly-ast -analyze -polly-no-early-exit < %s | FileCheck %s -check-prefix=CHECK
Tobias Grosser37eb4222014-02-20 21:43:54 +00002target datalayout = "e-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:0:64-s0:64:64-f80:128:128-n8:16:32:64"
3target triple = "x86_64-pc-linux-gnu"
4;
5; for(i = 0; i < 200; i++ )
6; A[i] = 2;
7;
8; for (i = 0; i < 50; i++ )
9; A[i] = 5;
10;
11; for (i = 0; i < 70; i++ )
12; A[i] = A[i] + 5;
13;
14; for (i = 100; i < 110; i++ )
15; A[i] = i;
16;
17define void @main() nounwind uwtable {
18entry:
19 %A = alloca [200 x i32], align 16
20 br label %for.body.1
21
22for.body.1:
23 %indvar.1 = phi i64 [ 0, %entry ], [ %indvar.next.1, %for.body.1 ]
David Blaikiebad3ff22015-02-27 19:20:19 +000024 %arrayidx.1 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.1
Tobias Grosser37eb4222014-02-20 21:43:54 +000025 store i32 2, i32* %arrayidx.1, align 4
26 %indvar.next.1 = add i64 %indvar.1, 1
27 %exitcond.1 = icmp ne i64 %indvar.next.1, 200
28 br i1 %exitcond.1, label %for.body.1, label %exit.1
29
30exit.1:
31 br label %for.body.2
32
33for.body.2:
34 %indvar.2 = phi i64 [ 0, %exit.1 ], [ %indvar.next.2, %for.body.2 ]
David Blaikiebad3ff22015-02-27 19:20:19 +000035 %arrayidx.2 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.2
Tobias Grosser37eb4222014-02-20 21:43:54 +000036 store i32 5, i32* %arrayidx.2, align 4
37 %indvar.next.2 = add i64 %indvar.2, 1
38 %exitcond.2 = icmp ne i64 %indvar.next.2, 50
39 br i1 %exitcond.2, label %for.body.2, label %exit.2
40
41exit.2:
42 br label %for.body.3
43
44for.body.3:
45 %indvar.3 = phi i64 [ 0, %exit.2 ], [ %indvar.next.3, %for.body.3 ]
David Blaikiebad3ff22015-02-27 19:20:19 +000046 %arrayidx.3 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.3
Tobias Grosser37eb4222014-02-20 21:43:54 +000047 %val = load i32* %arrayidx.3, align 4
48 %add = add nsw i32 %val, 5
49 store i32 %add, i32* %arrayidx.3, align 4
50 %indvar.next.3 = add i64 %indvar.3, 1
51 %exitcond.3 = icmp ne i64 %indvar.next.3, 70
52 br i1 %exitcond.3, label %for.body.3 , label %exit.3
53
54exit.3:
55 br label %for.body.4
56
57for.body.4:
58 %indvar.4 = phi i64 [ 0, %exit.3 ], [ %indvar.next.4, %for.body.4 ]
59 %indvar.plus = add i64 %indvar.4, 100
60 %trunc = trunc i64 %indvar.plus to i32
David Blaikiebad3ff22015-02-27 19:20:19 +000061 %arrayidx.4 = getelementptr [200 x i32], [200 x i32]* %A, i64 0, i64 %indvar.plus
Tobias Grosser37eb4222014-02-20 21:43:54 +000062 store i32 %trunc, i32* %arrayidx.4, align 4
63 %indvar.next.4 = add i64 %indvar.4, 1
64 %exitcond.4 = icmp ne i64 %indvar.next.4, 10
65 br i1 %exitcond.4, label %for.body.4, label %exit.4
66
67exit.4:
68 ret void
69}
70
Tobias Grosser817d51d2014-02-21 20:51:46 +000071; CHECK: for (int c1 = 50; c1 <= 99; c1 += 1)
72; CHECK: Stmt_for_body_1(c1);
73; CHECK: for (int c1 = 110; c1 <= 199; c1 += 1)
Tobias Grosser37eb4222014-02-20 21:43:54 +000074; CHECK: Stmt_for_body_1(c1);
75; CHECK: for (int c1 = 0; c1 <= 49; c1 += 1)
76; CHECK: Stmt_for_body_2(c1);
77; CHECK: for (int c1 = 0; c1 <= 69; c1 += 1)
78; CHECK: Stmt_for_body_3(c1);
79; CHECK: for (int c1 = 0; c1 <= 9; c1 += 1)