Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / clang / test / OpenMP / metadirective_ast_print.c
blobddd5b8633cc5013b31487c8a78df3bc1a04a22fd
1 // RUN: %clang_cc1 -verify -fopenmp -triple x86_64-unknown-linux-gnu -x c -std=c99 -ast-print %s -o - | FileCheck %s
3 // RUN: %clang_cc1 -verify -fopenmp-simd -triple x86_64-unknown-linux-gnu -x c -std=c99 -ast-print %s -o - | FileCheck %s
5 // RUN: %clang_cc1 -verify -fopenmp -triple amdgcn-amd-amdhsa -x c -std=c99 -ast-print %s -o - | FileCheck %s --check-prefix=CHECK-AMDGCN
7 // RUN: %clang_cc1 -verify -fopenmp-simd -triple amdgcn-amd-amdhsa -x c -std=c99 -ast-print %s -o - | FileCheck %s --check-prefix=CHECK-AMDGCN
8 // expected-no-diagnostics
10 #ifndef HEADER
11 #define HEADER
13 void bar(void);
15 #define N 10
16 void foo(void) {
17 #pragma omp metadirective when(device = {kind(cpu)} \
18 : parallel) default()
19 bar();
20 #pragma omp metadirective when(implementation = {vendor(score(0) \
21 : llvm)}, \
22 device = {kind(cpu)} \
23 : parallel) default(target teams)
24 bar();
25 #pragma omp metadirective when(device = {kind(gpu)} \
26 : target teams) when(implementation = {vendor(llvm)} \
27 : parallel) default()
28 bar();
29 #pragma omp metadirective default(target) when(implementation = {vendor(score(5) \
30 : llvm)}, \
31 device = {kind(cpu, host)} \
32 : parallel)
33 bar();
34 #pragma omp metadirective when(user = {condition(N > 10)} \
35 : target) when(user = {condition(N == 10)} \
36 : parallel)
37 bar();
38 #pragma omp metadirective when(device = {kind(host)} \
39 : parallel for)
40 for (int i = 0; i < 100; i++)
42 #pragma omp metadirective when(implementation = {extension(match_all)} \
43 : parallel) default(parallel for)
44 for (int i = 0; i < 100; i++)
46 #pragma omp metadirective when(implementation = {extension(match_any)} \
47 : parallel) default(parallel for)
48 for (int i = 0; i < 100; i++)
50 #pragma omp metadirective when(implementation = {extension(match_none)} \
51 : parallel) default(parallel for)
52 for (int i = 0; i < 100; i++)
55 // Test metadirective with nested OpenMP directive.
56 int array[16];
57 #pragma omp metadirective when(user = {condition(1)} \
58 : parallel for)
59 for (int i = 0; i < 16; i++) {
60 #pragma omp simd
61 for (int j = 0; j < 16; j++)
62 array[i] = i;
65 #pragma omp metadirective when(device={arch("amdgcn")}: \
66 teams distribute parallel for)\
67 default(parallel for)
68 for (int i = 0; i < 100; i++)
72 // CHECK: void bar(void);
73 // CHECK: void foo(void)
74 // CHECK-NEXT: #pragma omp parallel
75 // CHECK-NEXT: bar()
76 // CHECK-NEXT: #pragma omp parallel
77 // CHECK-NEXT: bar()
78 // CHECK-NEXT: #pragma omp parallel
79 // CHECK-NEXT: bar()
80 // CHECK-NEXT: #pragma omp parallel
81 // CHECK-NEXT: bar()
82 // CHECK-NEXT: #pragma omp parallel
83 // CHECK-NEXT: bar()
84 // CHECK-NEXT: #pragma omp parallel for
85 // CHECK-NEXT: for (int i = 0; i < 100; i++)
86 // CHECK: #pragma omp parallel
87 // CHECK-NEXT: for (int i = 0; i < 100; i++)
88 // CHECK: #pragma omp parallel for
89 // CHECK-NEXT: for (int i = 0; i < 100; i++)
90 // CHECK: #pragma omp parallel
91 // CHECK-NEXT: for (int i = 0; i < 100; i++)
92 // CHECK: #pragma omp parallel for
93 // CHECK-NEXT: for (int i = 0; i < 16; i++) {
94 // CHECK-NEXT: #pragma omp simd
95 // CHECK-NEXT: for (int j = 0; j < 16; j++)
96 // CHECK-AMDGCN: #pragma omp teams distribute parallel for
97 // CHECK-AMDGCN-NEXT: for (int i = 0; i < 100; i++)
99 #endif