2018-05-15 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / testsuite / gcc.dg / graphite / pr35356-2.c
blob957fb91791fefb05c195b0da57458ddcb339acac
1 /* { dg-options "-O2 -fgraphite-identity -fdump-tree-graphite-all" } */
3 int a[100];
5 int
6 foo (int bar, int n, int k)
8 int i;
10 for (i = 0; i < n; i++)
11 if (i == k)
12 a[i] = 1;
13 else
14 a[i] = i;
16 return a[bar];
19 /* We should generate the following:
21 | for (i = 0; i < min (n, k); i++)
22 | a[i] = i;
23 | if (k >= 0 && k < n)
24 | a[k] = 1;
25 | for (i = max(k+1,0); i < n; i++)
26 | a[i] = i;
28 XXX: At the moment we generate to protect loops that are executed zero times.
30 | if (0 < min (n, k) + 1)
31 | for (i = 0; i < min (n, k); i++)
32 | a[i] = i;
33 | if (k >= 0 && k < n)
34 | a[k] = 1;
35 | if (0 < max(n, k) + 1)
36 | for (i = max(k+1,0); i < n; i++)
37 | a[i] = i;
41 /* { dg-final { scan-tree-dump-times "for\[^\n\]+\n\[^\n\]+if" 0 "graphite" } } */