1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
|
// RUN: %libomp-cxx-compile-and-run | FileCheck %s --match-full-lines
#ifndef HEADER
#define HEADER
#include <cstdlib>
#include <cstdio>
int main() {
printf("do\n");
#pragma omp parallel for collapse(3) num_threads(1)
for (int i = 0; i < 3; ++i)
#pragma omp tile sizes(3, 3)
for (int j = 0; j < 4; ++j)
for (int k = 0; k < 5; ++k)
printf("i=%d j=%d k=%d\n", i, j, k);
printf("done\n");
return EXIT_SUCCESS;
}
#endif /* HEADER */
// CHECK: do
// Full tile
// CHECK-NEXT: i=0 j=0 k=0
// CHECK-NEXT: i=0 j=0 k=1
// CHECK-NEXT: i=0 j=0 k=2
// CHECK-NEXT: i=0 j=1 k=0
// CHECK-NEXT: i=0 j=1 k=1
// CHECK-NEXT: i=0 j=1 k=2
// CHECK-NEXT: i=0 j=2 k=0
// CHECK-NEXT: i=0 j=2 k=1
// CHECK-NEXT: i=0 j=2 k=2
// Partial tile
// CHECK-NEXT: i=0 j=0 k=3
// CHECK-NEXT: i=0 j=0 k=4
// CHECK-NEXT: i=0 j=1 k=3
// CHECK-NEXT: i=0 j=1 k=4
// CHECK-NEXT: i=0 j=2 k=3
// CHECK-NEXT: i=0 j=2 k=4
// Partial tile
// CHECK-NEXT: i=0 j=3 k=0
// CHECK-NEXT: i=0 j=3 k=1
// CHECK-NEXT: i=0 j=3 k=2
// Partial tile
// CHECK-NEXT: i=0 j=3 k=3
// CHECK-NEXT: i=0 j=3 k=4
// Full tile
// CHECK-NEXT: i=1 j=0 k=0
// CHECK-NEXT: i=1 j=0 k=1
// CHECK-NEXT: i=1 j=0 k=2
// CHECK-NEXT: i=1 j=1 k=0
// CHECK-NEXT: i=1 j=1 k=1
// CHECK-NEXT: i=1 j=1 k=2
// CHECK-NEXT: i=1 j=2 k=0
// CHECK-NEXT: i=1 j=2 k=1
// CHECK-NEXT: i=1 j=2 k=2
// Partial tiles
// CHECK-NEXT: i=1 j=0 k=3
// CHECK-NEXT: i=1 j=0 k=4
// CHECK-NEXT: i=1 j=1 k=3
// CHECK-NEXT: i=1 j=1 k=4
// CHECK-NEXT: i=1 j=2 k=3
// CHECK-NEXT: i=1 j=2 k=4
// CHECK-NEXT: i=1 j=3 k=0
// CHECK-NEXT: i=1 j=3 k=1
// CHECK-NEXT: i=1 j=3 k=2
// CHECK-NEXT: i=1 j=3 k=3
// CHECK-NEXT: i=1 j=3 k=4
// Full tile
// CHECK-NEXT: i=2 j=0 k=0
// CHECK-NEXT: i=2 j=0 k=1
// CHECK-NEXT: i=2 j=0 k=2
// CHECK-NEXT: i=2 j=1 k=0
// CHECK-NEXT: i=2 j=1 k=1
// CHECK-NEXT: i=2 j=1 k=2
// CHECK-NEXT: i=2 j=2 k=0
// CHECK-NEXT: i=2 j=2 k=1
// CHECK-NEXT: i=2 j=2 k=2
// Partial tiles
// CHECK-NEXT: i=2 j=0 k=3
// CHECK-NEXT: i=2 j=0 k=4
// CHECK-NEXT: i=2 j=1 k=3
// CHECK-NEXT: i=2 j=1 k=4
// CHECK-NEXT: i=2 j=2 k=3
// CHECK-NEXT: i=2 j=2 k=4
// CHECK-NEXT: i=2 j=3 k=0
// CHECK-NEXT: i=2 j=3 k=1
// CHECK-NEXT: i=2 j=3 k=2
// CHECK-NEXT: i=2 j=3 k=3
// CHECK-NEXT: i=2 j=3 k=4
// CHECK-NEXT: done
|