xref: /llvm-project/polly/test/IstAstInfo/simple-run-time-condition.ll (revision e1f056f692d869708c1898d9d65a69ac5584a0ed)
1; RUN: opt %loadNPMPolly '-passes=print<polly-ast>' -polly-precise-inbounds -polly-precise-fold-accesses -disable-output < %s | FileCheck %s
2
3target 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-S128"
4
5; void foo(long n, long m, int o, double A[n][m], long p, long q) {
6;
7; if (o >= 0)
8;   for (long i = 0; i < n; i++)
9;     for (long j = 0; j < m; j++)
10;         A[i+p][j+q] = 1.0;
11; else
12;   for (long i = 0; i < n; i++)
13;     for (long j = 0; j < m; j++)
14;         A[i+p][j+q-100] = 1.0;
15;
16
17; This test case is meant to verify that the run-time condition generated
18; for the delinearization is simplified such that conditions that would not
19; cause any code to be executed are not generated.
20
21; CHECK: if (((o >= 1 && q <= 0 && m + q >= 0) || (o <= 0 && m + q >= 100 && q <= 100)) && 0 == ((o <= 0 && n >= 1 && m + q >= 9223372036854775909) || (o <= 0 && m >= 1 && n >= 1 && q <= -9223372036854775709)))
22
23; CHECK:     if (o <= 0) {
24; CHECK:       for (int c0 = 0; c0 < n; c0 += 1)
25; CHECK:         for (int c1 = 0; c1 < m; c1 += 1)
26; CHECK:           Stmt_for_j_1(c0, c1);
27; CHECK:     } else
28; CHECK:       for (int c0 = 0; c0 < n; c0 += 1)
29; CHECK:         for (int c1 = 0; c1 < m; c1 += 1)
30; CHECK:           Stmt_for_j(c0, c1);
31
32; CHECK: else
33; CHECK:     {  /* original code */ }
34
35define void @foo(i64 %n, i64 %m, i64 %o, ptr %A, i64 %p, i64 %q) {
36entry:
37  br label %cond
38
39cond:
40  %cmp = icmp sgt i64 %o, 0
41  br i1 %cmp, label %for.i, label %for.i.1
42
43for.i:
44  %i = phi i64 [ 0, %cond ], [ %i.inc, %for.i.inc ]
45  br label %for.j
46
47for.j:
48  %j = phi i64 [ 0, %for.i ], [ %j.inc, %for.j.inc ]
49  %offset0 = add nsw i64 %i, %p
50  %subscript0 = mul i64 %offset0, %m
51  %offset1 = add nsw i64 %j, %q
52  %subscript1 = add i64 %offset1, %subscript0
53  %idx = getelementptr inbounds double, ptr %A, i64 %subscript1
54  store double 1.0, ptr %idx
55  br label %for.j.inc
56
57for.j.inc:
58  %j.inc = add nsw i64 %j, 1
59  %j.exitcond = icmp eq i64 %j.inc, %m
60  br i1 %j.exitcond, label %for.i.inc, label %for.j
61
62for.i.inc:
63  %i.inc = add nsw i64 %i, 1
64  %i.exitcond = icmp eq i64 %i.inc, %n
65  br i1 %i.exitcond, label %end, label %for.i
66
67for.i.1:
68  %i.1 = phi i64 [ 0, %cond ], [ %i.inc.1, %for.i.inc.1 ]
69  br label %for.j.1
70
71for.j.1:
72  %j.1 = phi i64 [ 0, %for.i.1 ], [ %j.inc.1, %for.j.inc.1 ]
73  %offset0.1 = add nsw i64 %i.1, %p
74  %subscript0.1 = mul i64 %offset0.1, %m
75  %offset1.1 = add nsw i64 %j.1, %q
76  %subscript1.1 = add i64 %offset1.1, %subscript0.1
77  %subscript1.2 = sub i64 %subscript1.1, 100
78  %idx.1 = getelementptr inbounds double, ptr %A, i64 %subscript1.2
79  store double 1.0, ptr %idx.1
80  br label %for.j.inc.1
81
82for.j.inc.1:
83  %j.inc.1 = add nsw i64 %j.1, 1
84  %j.exitcond.1 = icmp eq i64 %j.inc.1, %m
85  br i1 %j.exitcond.1, label %for.i.inc.1, label %for.j.1
86
87for.i.inc.1:
88  %i.inc.1 = add nsw i64 %i.1, 1
89  %i.exitcond.1 = icmp eq i64 %i.inc.1, %n
90  br i1 %i.exitcond.1, label %end, label %for.i.1
91
92end:
93  ret void
94}
95