1 // RUN: %clang_cc1 -verify -fopenmp %s 2 3 void foo() { 4 } 5 6 bool foobool(int argc) { 7 return argc; 8 } 9 10 struct S1; // expected-note 2 {{declared here}} expected-note 2 {{forward declaration of 'S1'}} 11 extern S1 a; 12 class S2 { 13 mutable int a; 14 public: 15 S2():a(0) { } 16 }; 17 const S2 b; 18 const S2 ba[5]; 19 class S3 { 20 int a; 21 public: 22 S3():a(0) { } 23 }; 24 const S3 ca[5]; 25 class S4 { 26 int a; 27 S4(); // expected-note {{implicitly declared private here}} 28 public: 29 S4(int v) : a(v) { 30 #pragma omp simd private(a) private(this->a) 31 for (int k = 0; k < v; ++k) 32 ++this->a; 33 } 34 }; 35 class S5 { 36 int a; 37 S5():a(0) {} // expected-note {{implicitly declared private here}} 38 public: 39 S5(int v):a(v) { } 40 S5 &operator=(S5 &s) { 41 #pragma omp simd private(a) private(this->a) private(s.a) // expected-error {{expected variable name or data member of current class}} 42 for (int k = 0; k < s.a; ++k) 43 ++s.a; 44 return *this; 45 } 46 }; 47 48 template <typename T> 49 class S6 { 50 public: 51 T a; 52 53 S6() : a(0) {} 54 S6(T v) : a(v) { 55 #pragma omp simd private(a) private(this->a) 56 for (int k = 0; k < v; ++k) 57 ++this->a; 58 } 59 S6 &operator=(S6 &s) { 60 #pragma omp simd private(a) private(this->a) private(s.a) // expected-error {{expected variable name or data member of current class}} 61 for (int k = 0; k < s.a; ++k) 62 ++s.a; 63 return *this; 64 } 65 }; 66 67 template <typename T> 68 class S7 : public T { 69 T a; 70 S7() : a(0) {} 71 72 public: 73 S7(T v) : a(v) { 74 #pragma omp simd private(a) private(this->a) private(T::a) 75 for (int k = 0; k < a.a; ++k) 76 ++this->a.a; 77 } 78 S7 &operator=(S7 &s) { 79 #pragma omp simd private(a) private(this->a) private(s.a) private(s.T::a) // expected-error 2 {{expected variable name or data member of current class}} 80 for (int k = 0; k < s.a.a; ++k) 81 ++s.a.a; 82 return *this; 83 } 84 }; 85 86 S3 h; 87 #pragma omp threadprivate(h) // expected-note 2 {{defined as threadprivate or thread local}} 88 89 template<class I, class C> int foomain(I argc, C **argv) { 90 I e(4); 91 I g(5); 92 int i; 93 int &j = i; 94 #pragma omp simd private // expected-error {{expected '(' after 'private'}} 95 for (int k = 0; k < argc; ++k) ++k; 96 #pragma omp simd private ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} 97 for (int k = 0; k < argc; ++k) ++k; 98 #pragma omp simd private () // expected-error {{expected expression}} 99 for (int k = 0; k < argc; ++k) ++k; 100 #pragma omp simd private (argc // expected-error {{expected ')'}} expected-note {{to match this '('}} 101 for (int k = 0; k < argc; ++k) ++k; 102 #pragma omp simd private (argc, // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} 103 for (int k = 0; k < argc; ++k) ++k; 104 #pragma omp simd private (argc > 0 ? argv[1] : argv[2]) // expected-error {{expected variable name}} 105 for (int k = 0; k < argc; ++k) ++k; 106 #pragma omp simd private (argc) 107 for (int k = 0; k < argc; ++k) ++k; 108 #pragma omp simd private (S1) // expected-error {{'S1' does not refer to a value}} 109 for (int k = 0; k < argc; ++k) ++k; 110 #pragma omp simd private (a, b) // expected-error {{private variable with incomplete type 'S1'}} 111 for (int k = 0; k < argc; ++k) ++k; 112 #pragma omp simd private (argv[1]) // expected-error {{expected variable name}} 113 for (int k = 0; k < argc; ++k) ++k; 114 #pragma omp simd private(e, g) 115 for (int k = 0; k < argc; ++k) ++k; 116 #pragma omp simd private(h) // expected-error {{threadprivate or thread local variable cannot be private}} 117 for (int k = 0; k < argc; ++k) ++k; 118 #pragma omp simd shared(i) // expected-error {{unexpected OpenMP clause 'shared' in directive '#pragma omp simd'}} 119 for (int k = 0; k < argc; ++k) ++k; 120 #pragma omp parallel 121 { 122 int v = 0; 123 int i; 124 #pragma omp simd private(i) 125 for (int k = 0; k < argc; ++k) { i = k; v += i; } 126 } 127 #pragma omp parallel shared(i) 128 #pragma omp parallel private(i) 129 #pragma omp simd private(j) 130 for (int k = 0; k < argc; ++k) ++k; 131 #pragma omp simd private(i) 132 for (int k = 0; k < argc; ++k) ++k; 133 return 0; 134 } 135 136 namespace A { 137 double x; 138 #pragma omp threadprivate(x) // expected-note {{defined as threadprivate or thread local}} 139 } 140 namespace B { 141 using A::x; 142 } 143 144 int main(int argc, char **argv) { 145 S4 e(4); 146 S5 g(5); 147 S6<float> s6(0.0) , s6_0(1.0); 148 S7<S6<float> > s7(0.0) , s7_0(1.0); 149 int i; 150 int &j = i; 151 #pragma omp simd private // expected-error {{expected '(' after 'private'}} 152 for (int k = 0; k < argc; ++k) ++k; 153 #pragma omp simd private ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} 154 for (int k = 0; k < argc; ++k) ++k; 155 #pragma omp simd private () // expected-error {{expected expression}} 156 for (int k = 0; k < argc; ++k) ++k; 157 #pragma omp simd private (argc // expected-error {{expected ')'}} expected-note {{to match this '('}} 158 for (int k = 0; k < argc; ++k) ++k; 159 #pragma omp simd private (argc, // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} 160 for (int k = 0; k < argc; ++k) ++k; 161 #pragma omp simd private (argc > 0 ? argv[1] : argv[2]) // expected-error {{expected variable name}} 162 for (int k = 0; k < argc; ++k) ++k; 163 #pragma omp simd private (argc) 164 for (int k = 0; k < argc; ++k) ++k; 165 #pragma omp simd private (S1) // expected-error {{'S1' does not refer to a value}} 166 for (int k = 0; k < argc; ++k) ++k; 167 #pragma omp simd private (a, b) // expected-error {{private variable with incomplete type 'S1'}} 168 for (int k = 0; k < argc; ++k) ++k; 169 #pragma omp simd private (argv[1]) // expected-error {{expected variable name}} 170 for (int k = 0; k < argc; ++k) ++k; 171 #pragma omp simd private(e, g) // expected-error {{calling a private constructor of class 'S4'}} expected-error {{calling a private constructor of class 'S5'}} 172 for (int k = 0; k < argc; ++k) ++k; 173 #pragma omp simd private(h, B::x) // expected-error 2 {{threadprivate or thread local variable cannot be private}} 174 for (int k = 0; k < argc; ++k) ++k; 175 #pragma omp simd shared(i) // expected-error {{unexpected OpenMP clause 'shared' in directive '#pragma omp simd'}} 176 for (int k = 0; k < argc; ++k) ++k; 177 #pragma omp parallel 178 { 179 int i; 180 #pragma omp simd private(i) 181 for (int k = 0; k < argc; ++k) ++k; 182 } 183 #pragma omp parallel shared(i) 184 #pragma omp parallel private(i) 185 #pragma omp simd private(j) 186 for (int k = 0; k < argc; ++k) ++k; 187 #pragma omp simd private(i) 188 for (int k = 0; k < argc; ++k) ++k; 189 190 s6 = s6_0; // expected-note {{in instantiation of member function 'S6<float>::operator=' requested here}} 191 s7 = s7_0; // expected-note {{in instantiation of member function 'S7<S6<float> >::operator=' requested here}} 192 return foomain(argc, argv); // expected-note {{in instantiation of function template specialization 'foomain<int, char>' requested here}} 193 } 194 195