| // RUN: %clang_cc1 -verify=expected,omp45 -fopenmp -fopenmp-version=45 -std=c++11 %s -Wuninitialized | 
 | // RUN: %clang_cc1 -verify=expected,omp50 -fopenmp -fopenmp-version=50 -std=c++11 %s -Wuninitialized | 
 | // RUN: %clang_cc1 -verify=expected,omp51 -fopenmp -fopenmp-version=51 -std=c++11 %s -Wuninitialized | 
 |  | 
 | // RUN: %clang_cc1 -verify=expected,omp45 -fopenmp-simd -fopenmp-version=45 -std=c++11 %s -Wuninitialized | 
 | // RUN: %clang_cc1 -verify=expected,omp50 -fopenmp-simd -fopenmp-version=50 -std=c++11 %s -Wuninitialized | 
 | // RUN: %clang_cc1 -verify=expected,omp51 -fopenmp-simd -fopenmp-version=51 -std=c++11 %s -Wuninitialized | 
 |  | 
 | void xxx(int argc) { | 
 |   int x; // expected-note {{initialize the variable 'x' to silence this warning}} | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |   for (int i = 0; i < 10; ++i) | 
 |     argc = x; // expected-warning {{variable 'x' is uninitialized when used here}} | 
 | } | 
 |  | 
 | void foo() { | 
 | } | 
 |  | 
 | static int pvt; | 
 | #pragma omp threadprivate(pvt) | 
 |  | 
 | #pragma omp teams distribute parallel for // expected-error {{unexpected OpenMP directive '#pragma omp teams distribute parallel for'}} | 
 |  | 
 | int main(int argc, char **argv) { | 
 |   #pragma omp target | 
 |   #pragma omp teams distribute parallel for | 
 |   f; // expected-error {{use of undeclared identifier 'f'}} | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for { // expected-warning {{extra tokens at the end of '#pragma omp teams distribute parallel for' are ignored}} | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for ( // expected-warning {{extra tokens at the end of '#pragma omp teams distribute parallel for' are ignored}} | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for[ // expected-warning {{extra tokens at the end of '#pragma omp teams distribute parallel for' are ignored}} | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for] // expected-warning {{extra tokens at the end of '#pragma omp teams distribute parallel for' are ignored}} | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for) // expected-warning {{extra tokens at the end of '#pragma omp teams distribute parallel for' are ignored}} | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for } // expected-warning {{extra tokens at the end of '#pragma omp teams distribute parallel for' are ignored}} | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for linear(argc) // expected-error {{unexpected OpenMP clause 'linear' in directive '#pragma omp teams distribute parallel for'}} | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | // expected-warning@+2 {{extra tokens at the end of '#pragma omp teams distribute parallel for' are ignored}} | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for unknown() | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | L1: | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |   for (int i = 0; i < argc; ++i) | 
 |     foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |   for (int i = 0; i < argc; ++i) { | 
 |     goto L1; // expected-error {{use of undeclared label 'L1'}} | 
 |     argc++; | 
 |   } | 
 |  | 
 |   for (int i = 0; i < 10; ++i) { | 
 |     switch (argc) { | 
 |     case (0): | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |       for (int i = 0; i < argc; ++i) { | 
 |         foo(); | 
 |         break; // expected-error {{'break' statement cannot be used in OpenMP for loop}} | 
 |         continue; | 
 |       } | 
 |     default: | 
 |       break; | 
 |     } | 
 |   } | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for default(none) // expected-note {{explicit data sharing attribute requested here}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ++argc; // expected-error {{ariable 'argc' must have explicitly specified data sharing attributes}} | 
 |  | 
 |   goto L2; // expected-error {{use of undeclared label 'L2'}} | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |   for (int i = 0; i < argc; ++i) | 
 |   L2: | 
 |   foo(); | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |   for (int i = 0; i < argc; ++i) { | 
 |     return 1; // expected-error {{cannot return from OpenMP region}} | 
 |   } | 
 |  | 
 |   [[]] // expected-error {{an attribute list cannot appear here}} | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |       for (int n = 0; n < 100; ++n) { | 
 |   } | 
 |  | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for copyin(pvt) | 
 |   for (int n = 0; n < 100; ++n) {} | 
 |  | 
 |   return 0; | 
 | } | 
 |  | 
 | void test_ordered() { | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for ordered // expected-error {{unexpected OpenMP clause 'ordered' in directive '#pragma omp teams distribute parallel for'}} | 
 |   for (int i = 0; i < 16; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} expected-error {{expected '(' after 'order'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order( // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} expected-error {{expected ')'}} expected-note {{to match this '('}} omp50-error {{expected 'concurrent' in OpenMP clause 'order'}} omp51-error {{expected 'concurrent' in OpenMP clause 'order'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(none // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} expected-error {{expected ')'}} expected-note {{to match this '('}} omp50-error {{expected 'concurrent' in OpenMP clause 'order'}} omp51-error {{expected 'concurrent' in OpenMP clause 'order'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(concurrent // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} expected-error {{expected ')'}} expected-note {{to match this '('}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(concurrent) // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(unconstrained:) // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} omp50-error {{expected 'concurrent' in OpenMP clause 'order'}} omp51-error {{expected 'concurrent' in OpenMP clause 'order'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(reproducible:concurrent // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} expected-error {{expected ')'}} expected-note {{to match this '('}} omp50-error {{expected 'concurrent' in OpenMP clause 'order'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(reproducible:concurrent) // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} omp50-error {{expected 'concurrent' in OpenMP clause 'order'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(unconstrained:concurrent) // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} omp50-error {{expected 'concurrent' in OpenMP clause 'order'}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for order(concurrent) order(concurrent) // omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} omp45-error {{unexpected OpenMP clause 'order' in directive '#pragma omp teams distribute parallel for'}} omp51-error {{directive '#pragma omp teams distribute parallel for' cannot contain more than one 'order' clause}} | 
 |   for (int i = 0; i < 10; ++i) | 
 |     ; | 
 | } | 
 |  | 
 | void test_cancel() { | 
 | #pragma omp target | 
 | #pragma omp teams distribute parallel for | 
 |   for (int i = 0; i < 16; ++i) { | 
 | #pragma omp cancel for | 
 |     ; | 
 |   } | 
 | } | 
 |  |