1 // RUN: %clang_cc1 -verify=expected,omp45 -fopenmp-version=45 -fopenmp -ferror-limit 200 -std=c++11 -o - %s -Wuninitialized
2 // RUN: %clang_cc1 -verify=expected,omp50 -fopenmp-version=50 -fopenmp -ferror-limit 200 -std=c++11 -o - %s -Wuninitialized
3
4 // RUN: %clang_cc1 -verify=expected,omp45 -fopenmp-version=45 -fopenmp-simd -ferror-limit 200 -std=c++11 -o - %s -Wuninitialized
5 // RUN: %clang_cc1 -verify=expected,omp50 -fopenmp-version=50 -fopenmp-simd -ferror-limit 200 -std=c++11 -o - %s -Wuninitialized
6
7 // RUN: %clang_cc1 -verify=expected,omp50 -fopenmp-version=51 -DOMP51 -fopenmp -ferror-limit 100 -std=c++11 -o - %s -Wuninitialized
8 // RUN: %clang_cc1 -verify=expected,omp50 -fopenmp-version=51 -DOMP51 -fopenmp-simd -ferror-limit 100 -std=c++11 -o - %s -Wuninitialized
9
xxx(int argc)10 void xxx(int argc) {
11 int x; // expected-note {{initialize the variable 'x' to silence this warning}}
12 #pragma omp task
13 argc = x; // expected-warning {{variable 'x' is uninitialized when used here}}
14 }
15
foo()16 void foo() {
17 #pragma omp task detach(0) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{'omp_event_handle_t' type not found; include <omp.h>}}
18 ;
19 }
20
21 typedef unsigned long omp_event_handle_t;
22 namespace {
23 static int y = 0;
24 }
25 static int x = 0;
26
27 #pragma omp task // expected-error {{unexpected OpenMP directive '#pragma omp task'}}
28
29 class S {
S(const S & s)30 S(const S &s) { a = s.a + 12; } // expected-note 16 {{implicitly declared private here}}
31 int a;
32
33 public:
S()34 S() : a(0) {}
S(int a)35 S(int a) : a(a) {}
operator int()36 operator int() { return a; }
operator ++()37 S &operator++() { return *this; }
operator +(const S &)38 S operator+(const S &) { return *this; }
39 };
40
41 class S1 {
42 int a;
43
44 public:
S1()45 S1() : a(0) {}
operator ++()46 S1 &operator++() { return *this; }
47 S1(const S1 &) = delete; // expected-note 2 {{'S1' has been explicitly marked deleted here}}
48 };
49
50 template <class T>
foo()51 int foo() {
52 T a;
53 T &b = a;
54 int r;
55 S1 s1;
56 // expected-error@+1 2 {{call to deleted constructor of 'S1'}}
57 #pragma omp task
58 ++s1;
59 #pragma omp task default(none) // expected-note 2 {{explicit data sharing attribute requested here}}
60 #pragma omp task default(shared)
61 ++a; // expected-error 2 {{variable 'a' must have explicitly specified data sharing attributes}}
62 #ifdef OMP51
63 #pragma omp task default(firstprivate) // expected-note 4 {{explicit data sharing attribute requested here}}
64 #pragma omp task
65 {
66 ++x; // expected-error 2 {{variable 'x' must have explicitly specified data sharing attributes}}
67 ++y; // expected-error 2 {{variable 'y' must have explicitly specified data sharing attributes}}
68 }
69 #endif
70
71 #pragma omp task default(none) // expected-note 2 {{explicit data sharing attribute requested here}}
72 #pragma omp task
73 // expected-error@+1 {{calling a private constructor of class 'S'}}
74 ++a; // expected-error 2 {{variable 'a' must have explicitly specified data sharing attributes}}
75 #pragma omp task
76 #pragma omp task
77 // expected-error@+1 {{calling a private constructor of class 'S'}}
78 ++a; // expected-error {{calling a private constructor of class 'S'}}
79 #pragma omp task default(shared)
80 #pragma omp task
81 // expected-error@+1 {{calling a private constructor of class 'S'}}
82 ++a;
83 #pragma omp parallel shared(a)
84 #pragma omp task
85 #pragma omp task
86 ++a;
87 #pragma omp parallel shared(a)
88 #pragma omp task default(shared)
89 #pragma omp task
90 ++a;
91 #pragma omp task
92 #pragma omp parallel
93 ++a; // expected-error {{calling a private constructor of class 'S'}}
94 // expected-error@+2 {{calling a private constructor of class 'S'}}
95 #pragma omp task
96 ++b;
97 #pragma omp task
98 // expected-error@+1 2 {{calling a private constructor of class 'S'}}
99 #pragma omp parallel shared(a, b)
100 ++a, ++b;
101 // expected-note@+1 2 {{defined as reduction}}
102 #pragma omp parallel reduction(+ : r)
103 // expected-error@+1 2 {{argument of a reduction clause of a parallel construct must not appear in a firstprivate clause on a task construct}}
104 #pragma omp task firstprivate(r)
105 ++r;
106 // expected-note@+1 2 {{defined as reduction}}
107 #pragma omp parallel reduction(+ : r)
108 #pragma omp task default(shared)
109 // expected-error@+1 2 {{reduction variables may not be accessed in an explicit task}}
110 ++r;
111 // expected-note@+1 2 {{defined as reduction}}
112 #pragma omp parallel reduction(+ : r)
113 #pragma omp task
114 // expected-error@+1 2 {{reduction variables may not be accessed in an explicit task}}
115 ++r;
116 #pragma omp parallel
117 // expected-note@+1 2 {{defined as reduction}}
118 #pragma omp for reduction(+ : r)
119 for (int i = 0; i < 10; ++i)
120 // expected-error@+1 2 {{argument of a reduction clause of a for construct must not appear in a firstprivate clause on a task construct}}
121 #pragma omp task firstprivate(r)
122 ++r;
123 #pragma omp parallel
124 // expected-note@+1 2 {{defined as reduction}}
125 #pragma omp for reduction(+ : r)
126 for (int i = 0; i < 10; ++i)
127 #pragma omp task default(shared)
128 // expected-error@+1 2 {{reduction variables may not be accessed in an explicit task}}
129 ++r;
130 #pragma omp parallel
131 // expected-note@+1 2 {{defined as reduction}}
132 #pragma omp for reduction(+ : r)
133 for (int i = 0; i < 10; ++i)
134 #pragma omp task
135 // expected-error@+1 2 {{reduction variables may not be accessed in an explicit task}}
136 ++r;
137 // expected-note@+1 {{non-shared variable in a task construct is predetermined as firstprivate}}
138 #pragma omp task
139 // expected-error@+2 {{reduction variable must be shared}}
140 // expected-error@+1 {{region cannot be closely nested inside 'task' region; perhaps you forget to enclose 'omp for' directive into a parallel region?}}
141 #pragma omp for reduction(+ : r)
142 ++r;
143 // expected-error@+1 {{directive '#pragma omp task' cannot contain more than one 'untied' clause}}
144 #pragma omp task untied untied
145 ++r;
146 // expected-error@+1 {{directive '#pragma omp task' cannot contain more than one 'mergeable' clause}}
147 #pragma omp task mergeable mergeable
148 ++r;
149 volatile omp_event_handle_t evt;
150 const omp_event_handle_t cevt = 0;
151 omp_event_handle_t sevt;
152 omp_event_handle_t &revt = sevt;
153 #pragma omp task detach // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{expected '(' after 'detach'}}
154 #pragma omp task detach( // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
155 #pragma omp task detach() // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{expected expression}}
156 #pragma omp task detach(a) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{expected variable of the 'omp_event_handle_t' type, not 'int'}} omp50-error {{expected variable of the 'omp_event_handle_t' type, not 'S'}}
157 ;
158 #pragma omp task detach(evt) detach(evt) // omp45-error 2 {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{directive '#pragma omp task' cannot contain more than one 'detach' clause}}
159 #pragma omp task detach(cevt) detach(revt) // omp45-error 2 {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{directive '#pragma omp task' cannot contain more than one 'detach' clause}} omp50-error {{expected variable of the 'omp_event_handle_t' type, not 'const omp_event_handle_t' (aka 'const unsigned long')}} omp50-error {{expected variable of the 'omp_event_handle_t' type, not 'omp_event_handle_t &' (aka 'unsigned long &')}}
160 #pragma omp task detach(evt) mergeable // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{'mergeable' and 'detach' clause are mutually exclusive and may not appear on the same directive}} omp50-note {{'detach' clause is specified here}}
161 ;
162 #pragma omp task mergeable detach(evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{'detach' and 'mergeable' clause are mutually exclusive and may not appear on the same directive}} omp50-note {{'mergeable' clause is specified here}}
163 #pragma omp task detach(-evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{expected variable of the 'omp_event_handle_t' type}}
164 ;
165 #pragma omp task detach(evt) shared(evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}}
166 #pragma omp task detach(evt) firstprivate(evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}}
167 ;
168 return a + b;
169 }
170
main(int argc,char ** argv)171 int main(int argc, char **argv) {
172 int a;
173 int &b = a;
174 S sa;
175 S &sb = sa;
176 int r;
177 #pragma omp task { // expected-warning {{extra tokens at the end of '#pragma omp task' are ignored}}
178 foo();
179 #pragma omp task( // expected-warning {{extra tokens at the end of '#pragma omp task' are ignored}}
180 foo();
181 #pragma omp task[ // expected-warning {{extra tokens at the end of '#pragma omp task' are ignored}}
182 foo();
183 #pragma omp task] // expected-warning {{extra tokens at the end of '#pragma omp task' are ignored}}
184 foo();
185 #pragma omp task) // expected-warning {{extra tokens at the end of '#pragma omp task' are ignored}}
186 foo();
187 #pragma omp task } // expected-warning {{extra tokens at the end of '#pragma omp task' are ignored}}
188 foo();
189 #pragma omp task
190 // expected-warning@+1 {{extra tokens at the end of '#pragma omp task' are ignored}}
191 #pragma omp task unknown()
192 foo();
193 L1:
194 foo();
195 #pragma omp task
196 ;
197 #pragma omp task
198 {
199 goto L1; // expected-error {{use of undeclared label 'L1'}}
200 argc++;
201 }
202
203 for (int i = 0; i < 10; ++i) {
204 switch (argc) {
205 case (0):
206 #pragma omp task
207 {
208 foo();
209 break; // expected-error {{'break' statement not in loop or switch statement}}
210 continue; // expected-error {{'continue' statement not in loop statement}}
211 }
212 default:
213 break;
214 }
215 }
216 #pragma omp task default(none) // expected-note {{explicit data sharing attribute requested here}}
217 ++argc; // expected-error {{variable 'argc' must have explicitly specified data sharing attributes}}
218
219 goto L2; // expected-error {{use of undeclared label 'L2'}}
220 #pragma omp task
221 L2:
222 foo();
223 #pragma omp task
224 {
225 return 1; // expected-error {{cannot return from OpenMP region}}
226 }
227
228 [[]] // expected-error {{an attribute list cannot appear here}}
229 #pragma omp task
230 for (int n = 0; n < 100; ++n) {
231 }
232
233 #pragma omp task default(none) // expected-note {{explicit data sharing attribute requested here}}
234 #pragma omp task default(shared)
235 ++a; // expected-error {{variable 'a' must have explicitly specified data sharing attributes}}
236 #pragma omp task default(none) // expected-note {{explicit data sharing attribute requested here}}
237 #pragma omp task
238 ++a; // expected-error {{variable 'a' must have explicitly specified data sharing attributes}}
239 #pragma omp task default(shared)
240 #pragma omp task
241 ++a;
242 #pragma omp task
243 #pragma omp parallel
244 ++a;
245 #pragma omp task
246 ++b;
247 #pragma omp task
248 #pragma omp parallel shared(a, b)
249 ++a, ++b;
250 #pragma omp task default(none) // expected-note {{explicit data sharing attribute requested here}}
251 #pragma omp task default(shared)
252 ++sa; // expected-error {{variable 'sa' must have explicitly specified data sharing attributes}}
253 #pragma omp task default(none) // expected-note {{explicit data sharing attribute requested here}}
254 #pragma omp task
255 // expected-error@+1 {{calling a private constructor of class 'S'}}
256 ++sa; // expected-error {{variable 'sa' must have explicitly specified data sharing attributes}}
257 #pragma omp task
258 #pragma omp task
259 // expected-error@+1 {{calling a private constructor of class 'S'}}
260 ++sa; // expected-error {{calling a private constructor of class 'S'}}
261 #pragma omp task default(shared)
262 #pragma omp task
263 // expected-error@+1 {{calling a private constructor of class 'S'}}
264 ++sa;
265 #pragma omp parallel shared(sa)
266 #pragma omp task
267 #pragma omp task
268 ++sa;
269 #pragma omp parallel shared(sa)
270 #pragma omp task default(shared)
271 #pragma omp task
272 ++sa;
273 #pragma omp task
274 #pragma omp parallel
275 ++sa; // expected-error {{calling a private constructor of class 'S'}}
276 // expected-error@+2 {{calling a private constructor of class 'S'}}
277 #pragma omp task
278 ++sb;
279 // expected-error@+2 2 {{calling a private constructor of class 'S'}}
280 #pragma omp task
281 #pragma omp parallel shared(sa, sb)
282 ++sa, ++sb;
283 // expected-note@+1 2 {{defined as reduction}}
284 #pragma omp parallel reduction(+ : r)
285 // expected-error@+1 {{argument of a reduction clause of a parallel construct must not appear in a firstprivate clause on a task construct}}
286 #pragma omp task firstprivate(r)
287 // expected-error@+1 {{reduction variables may not be accessed in an explicit task}}
288 ++r;
289 // expected-note@+1 {{defined as reduction}}
290 #pragma omp parallel reduction(+ : r)
291 #pragma omp task default(shared)
292 // expected-error@+1 {{reduction variables may not be accessed in an explicit task}}
293 ++r;
294 // expected-note@+1 {{defined as reduction}}
295 #pragma omp parallel reduction(+ : r)
296 #pragma omp task
297 // expected-error@+1 {{reduction variables may not be accessed in an explicit task}}
298 ++r;
299 #pragma omp parallel
300 // expected-note@+1 2 {{defined as reduction}}
301 #pragma omp for reduction(+ : r)
302 for (int i = 0; i < 10; ++i)
303 // expected-error@+1 {{argument of a reduction clause of a for construct must not appear in a firstprivate clause on a task construct}}
304 #pragma omp task firstprivate(r)
305 // expected-error@+1 {{reduction variables may not be accessed in an explicit task}}
306 ++r;
307 #pragma omp parallel
308 // expected-note@+1 {{defined as reduction}}
309 #pragma omp for reduction(+ : r)
310 for (int i = 0; i < 10; ++i)
311 #pragma omp task default(shared)
312 // expected-error@+1 {{reduction variables may not be accessed in an explicit task}}
313 ++r;
314 #pragma omp parallel
315 // expected-note@+1 {{defined as reduction}}
316 #pragma omp for reduction(+ : r)
317 for (int i = 0; i < 10; ++i)
318 #pragma omp task
319 // expected-error@+1 {{reduction variables may not be accessed in an explicit task}}
320 ++r;
321 // expected-note@+1 {{non-shared variable in a task construct is predetermined as firstprivate}}
322 #pragma omp task
323 // expected-error@+2 {{reduction variable must be shared}}
324 // expected-error@+1 {{region cannot be closely nested inside 'task' region; perhaps you forget to enclose 'omp for' directive into a parallel region?}}
325 #pragma omp for reduction(+ : r)
326 ++r;
327 // expected-error@+1 {{directive '#pragma omp task' cannot contain more than one 'untied' clause}}
328 #pragma omp task untied untied
329 ++r;
330 // expected-error@+1 {{directive '#pragma omp task' cannot contain more than one 'mergeable' clause}}
331 #pragma omp task mergeable mergeable
332 ++r;
333 volatile omp_event_handle_t evt;
334 omp_event_handle_t sevt;
335 const omp_event_handle_t cevt = evt;
336 omp_event_handle_t &revt = sevt;
337 #pragma omp task detach // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{expected '(' after 'detach'}}
338 #pragma omp task detach( // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}}
339 #pragma omp task detach() // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{expected expression}}
340 #pragma omp task detach(a) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{expected variable of the 'omp_event_handle_t' type, not 'int'}}
341 #pragma omp task detach(evt) detach(evt) // omp45-error 2 {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{directive '#pragma omp task' cannot contain more than one 'detach' clause}}
342 #pragma omp task detach(cevt) detach(revt) // omp45-error 2 {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} expected-error {{directive '#pragma omp task' cannot contain more than one 'detach' clause}} omp50-error {{expected variable of the 'omp_event_handle_t' type, not 'const omp_event_handle_t' (aka 'const unsigned long')}} omp50-error {{expected variable of the 'omp_event_handle_t' type, not 'omp_event_handle_t &' (aka 'unsigned long &')}}
343 #pragma omp task detach(evt) mergeable // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{'mergeable' and 'detach' clause are mutually exclusive and may not appear on the same directive}} omp50-note {{'detach' clause is specified here}}
344 ;
345 #pragma omp task mergeable detach(evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{'detach' and 'mergeable' clause are mutually exclusive and may not appear on the same directive}} omp50-note {{'mergeable' clause is specified here}}
346 #pragma omp task detach(-evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}} omp50-error {{expected variable of the 'omp_event_handle_t' type}}
347 ;
348 #pragma omp task detach(evt) shared(evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}}
349 #pragma omp task detach(evt) firstprivate(evt) // omp45-error {{unexpected OpenMP clause 'detach' in directive '#pragma omp task'}}
350 ;
351 // expected-note@+2 {{in instantiation of function template specialization 'foo<int>' requested here}}
352 // expected-note@+1 {{in instantiation of function template specialization 'foo<S>' requested here}}
353 return foo<int>() + foo<S>();
354 }
355
356