]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - test/OpenMP/teams_distribute_parallel_for_private_messages.cpp
Vendor import of clang trunk r351319 (just before the release_80 branch
[FreeBSD/FreeBSD.git] / test / OpenMP / teams_distribute_parallel_for_private_messages.cpp
1 // RUN: %clang_cc1 -verify -fopenmp %s
2
3 // RUN: %clang_cc1 -verify -fopenmp-simd %s
4
5 void foo() {
6 }
7
8 bool foobool(int argc) {
9   return argc;
10 }
11
12 struct S1; // expected-note {{declared here}} expected-note {{forward declaration of 'S1'}}
13 extern S1 a;
14 class S2 {
15   mutable int a;
16 public:
17   S2():a(0) { }
18   static float S2s; // expected-note {{predetermined as shared}}
19 };
20 const S2 b;
21 const S2 ba[5];
22 class S3 {
23   int a;
24 public:
25   S3():a(0) { }
26 };
27 const S3 c; // expected-note {{'c' defined here}}
28 const S3 ca[5]; // expected-note {{'ca' defined here}}
29 extern const int f;  // expected-note {{'f' declared here}}
30 class S4 {
31   int a;
32   S4(); // expected-note {{implicitly declared private here}}
33 public:
34   S4(int v):a(v) { }
35 };
36 class S5 { 
37   int a;
38   S5():a(0) {} // expected-note {{implicitly declared private here}}
39 public:
40   S5(int v):a(v) { }
41 };
42
43 S3 h;
44 #pragma omp threadprivate(h) // expected-note {{defined as threadprivate or thread local}}
45
46
47 int main(int argc, char **argv) {
48   const int d = 5;  // expected-note {{'d' defined here}}
49   const int da[5] = { 0 }; // expected-note {{'da' defined here}}
50   S4 e(4);
51   S5 g(5);
52   int i;
53   int &j = i;
54
55   #pragma omp target
56   #pragma omp teams distribute parallel for private // expected-error {{expected '(' after 'private'}}
57   for (int k = 0; k < argc; ++k) ++k;
58
59   #pragma omp target
60   #pragma omp teams distribute parallel for private ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
61   for (int k = 0; k < argc; ++k) ++k;
62
63   #pragma omp target
64   #pragma omp teams distribute parallel for private () // expected-error {{expected expression}}
65   for (int k = 0; k < argc; ++k) ++k;
66
67   #pragma omp target
68   #pragma omp teams distribute parallel for private (argc // expected-error {{expected ')'}} expected-note {{to match this '('}}
69   for (int k = 0; k < argc; ++k) ++k;
70
71   #pragma omp target
72   #pragma omp teams distribute parallel for private (argc, // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
73   for (int k = 0; k < argc; ++k) ++k;
74
75   #pragma omp target
76   #pragma omp teams distribute parallel for private (argc > 0 ? argv[1] : argv[2]) // expected-error {{expected variable name}}
77   for (int k = 0; k < argc; ++k) ++k;
78
79   #pragma omp target
80   #pragma omp teams distribute parallel for private (argc)
81   for (int k = 0; k < argc; ++k) ++k;
82
83   #pragma omp target
84   #pragma omp teams distribute parallel for private (S1) // expected-error {{'S1' does not refer to a value}}
85   for (int k = 0; k < argc; ++k) ++k;
86
87   #pragma omp target
88   #pragma omp teams distribute parallel for private (a, b, c, d, f) // expected-error {{private variable with incomplete type 'S1'}} expected-error 1 {{const-qualified variable without mutable fields cannot be private}} expected-error 2 {{const-qualified variable cannot be private}}
89   for (int k = 0; k < argc; ++k) ++k;
90
91   #pragma omp target
92   #pragma omp teams distribute parallel for private (argv[1]) // expected-error {{expected variable name}}
93   for (int k = 0; k < argc; ++k) ++k;
94
95   #pragma omp target
96   #pragma omp teams distribute parallel for private(ba)
97   for (int k = 0; k < argc; ++k) ++k;
98
99   #pragma omp target
100   #pragma omp teams distribute parallel for private(ca) // expected-error {{const-qualified variable without mutable fields cannot be private}}
101   for (int k = 0; k < argc; ++k) ++k;
102
103   #pragma omp target
104   #pragma omp teams distribute parallel for private(da) // expected-error {{const-qualified variable cannot be private}}
105   for (int k = 0; k < argc; ++k) ++k;
106
107   #pragma omp target
108   #pragma omp teams distribute parallel for private(S2::S2s) // expected-error {{shared variable cannot be private}}
109   for (int k = 0; k < argc; ++k) ++k;
110
111   #pragma omp target
112   #pragma omp teams distribute parallel for private(e, g) // expected-error {{calling a private constructor of class 'S4'}} expected-error {{calling a private constructor of class 'S5'}}
113   for (int k = 0; k < argc; ++k) ++k;
114
115   #pragma omp target
116   #pragma omp teams distribute parallel for private(h) // expected-error {{threadprivate or thread local variable cannot be private}}
117   for (int k = 0; k < argc; ++k) ++k;
118
119   #pragma omp target
120   #pragma omp teams distribute parallel for shared(i)
121   for (int k = 0; k < argc; ++k) ++k;
122
123   #pragma omp target
124   #pragma omp teams distribute parallel for firstprivate(i), private(i) // expected-error {{firstprivate variable cannot be private}} expected-note {{defined as firstprivate}}
125   for (int k = 0; k < argc; ++k) ++k;
126
127   #pragma omp target
128   #pragma omp teams distribute parallel for private(j)
129   for (int k = 0; k < argc; ++k) ++k;
130
131   #pragma omp target
132   #pragma omp teams distribute parallel for reduction(+:i)
133   for (int k = 0; k < argc; ++k) ++k;
134
135   #pragma omp distribute private(i)
136   for (int k = 0; k < 10; ++k) {
137     #pragma omp target
138     #pragma omp teams distribute parallel for private(i)
139     for (int x = 0; x < 10; ++x) foo();
140   }
141
142   #pragma omp target
143   #pragma omp teams distribute parallel for firstprivate(i)
144   for (int k = 0; k < 10; ++k) {
145   }
146
147   return 0;
148 }