xref: /llvm-project/openmp/runtime/test/worksharing/for/omp_collapse_many_int.c (revision 7db40463229bb1c9fb15b2107d878fe70d1eda65)
1 // RUN: %libomp-compile-and-run
2 // XFAIL: true
3 
4 // Non-rectangular loop collapsing.
5 //
6 // Nested loops conform to OpenMP 5.2 standard,
7 // inner loops bounds may depend on outer loops induction variables.
8 
9 #define LOOP_TYPES int
10 #define LOOP                                                                   \
11   for (i = iLB; i <= iUB; i += iStep)                                          \
12     for (j = i * jA1 + jA0; j <= i * jB1 + jB0; j += jStep)                    \
13       for (k = j * kA1 + kA0; k <= j * kB1 + kB0; k += kStep)
14 #include "collapse_test.inc"
15 
main()16 int main() {
17   int fail = 0;
18 
19   iLB = -2;
20   iUB = 3;
21   jA0 = -7;
22   jA1 = -1;
23   jB0 = 13;
24   jB1 = 3;
25   kA0 = -20;
26   kA1 = -2;
27   kB0 = 111;
28   kB1 = -1;
29   iStep = 5;
30   jStep = 9;
31   kStep = 10;
32   PRINTF("\nOne off iLB=%d; iUB=%d; jA0=%d; jA1=%d; jB0=%d; jB1=%d; kA0=%d; "
33          "kA1=%d; kB0=%d; kB1=%d; iStep=%d; jStep=%d; kStep=%d;\n",
34          iLB, iUB, jA0, jA1, jB0, jB1, kA0, kA1, kB0, kB1, iStep, jStep, kStep);
35   fail = fail || (test() == 0);
36 
37   if (!fail) {
38 
39     // NOTE: if a loop on some level won't execute  for all iterations of an
40     // outer loop, it still should work. Runtime doesn't require lower bounds to
41     // be <= upper bounds for all possible i, j, k.
42 
43     iLB = -2;
44     iUB = 3;
45     jA0 = -7;
46     jB0 = 5;
47     kA0 = -13;
48     kB0 = 37;
49 
50     for (kA1 = -2; kA1 <= 2; ++kA1) { // <=
51       for (kB1 = -2; kB1 <= 2; ++kB1) {
52         for (jA1 = -3; jA1 <= 3; ++jA1) {
53           for (jB1 = -3; jB1 <= 3; ++jB1) {
54             for (iStep = 1; iStep <= 3; ++iStep) {
55               for (jStep = 2; jStep <= 6; jStep += 2) {
56                 for (kStep = 2; kStep <= 8; kStep += 3) {
57                   PRINTF("\nTrying iLB=%d; iUB=%d; jA0=%d; jA1=%d; jB0=%d; "
58                          "jB1=%d; kA0=%d; kA1=%d; kB0=%d; kB1=%d; iStep=%d; "
59                          "jStep=%d; kStep=%d;\n",
60                          iLB, iUB, jA0, jA1, jB0, jB1, kA0, kA1, kB0, kB1,
61                          iStep, jStep, kStep);
62                   fail = fail || (test() == 0);
63                 }
64               }
65             }
66           }
67         }
68       }
69     }
70   }
71 
72   return fail;
73 }
74