diff options
Diffstat (limited to 'test/OpenMP/for_simd_private_messages.cpp')
| -rw-r--r-- | test/OpenMP/for_simd_private_messages.cpp | 12 | 
1 files changed, 10 insertions, 2 deletions
| diff --git a/test/OpenMP/for_simd_private_messages.cpp b/test/OpenMP/for_simd_private_messages.cpp index 016a5ec6b581..96885c859e99 100644 --- a/test/OpenMP/for_simd_private_messages.cpp +++ b/test/OpenMP/for_simd_private_messages.cpp @@ -1,4 +1,4 @@ -// RUN: %clang_cc1 -verify -fopenmp=libiomp5 %s +// RUN: %clang_cc1 -verify -fopenmp %s  void foo() {  } @@ -108,6 +108,14 @@ int foomain(I argc, C **argv) {    return 0;  } +namespace A { +double x; +#pragma omp threadprivate(x) // expected-note {{defined as threadprivate or thread local}} +} +namespace B { +using A::x; +} +  int main(int argc, char **argv) {    S4 e(4);    S5 g(5); @@ -146,7 +154,7 @@ int main(int argc, char **argv) {  #pragma omp for simd private(e, g) // expected-error {{calling a private constructor of class 'S4'}} expected-error {{calling a private constructor of class 'S5'}}    for (int k = 0; k < argc; ++k)      ++k; -#pragma omp for simd private(h) // expected-error {{threadprivate or thread local variable cannot be private}} +#pragma omp for simd private(h, B::x) // expected-error 2 {{threadprivate or thread local variable cannot be private}}    for (int k = 0; k < argc; ++k)      ++k;  #pragma omp for simd shared(i) // expected-error {{unexpected OpenMP clause 'shared' in directive '#pragma omp for simd'}} | 
