1 // RUN: %clang_cc1 -x c++ -std=c++11 -verify -fopenmp %s 2 3 struct B { 4 static int ib[20]; // expected-note 0 {{'B::ib' declared here}} 5 static constexpr int bfoo() { return 8; } 6 }; 7 namespace X { 8 B x; // expected-note {{'x' defined here}} 9 }; 10 constexpr int bfoo() { return 4; } 11 12 int **z; 13 const int C1 = 1; 14 const int C2 = 2; 15 void test_aligned_colons(int *&rp) 16 { 17 int *B = 0; 18 19 #pragma omp target 20 #pragma omp teams distribute simd aligned(B:bfoo()) 21 for (int i = 0; i < 10; ++i) ; 22 23 #pragma omp target 24 #pragma omp teams distribute simd aligned(B::ib:B:bfoo()) // expected-error {{unexpected ':' in nested name specifier; did you mean '::'}} 25 for (int i = 0; i < 10; ++i) ; 26 27 #pragma omp target 28 #pragma omp teams distribute simd aligned(B:B::bfoo()) 29 for (int i = 0; i < 10; ++i) ; 30 31 #pragma omp target 32 #pragma omp teams distribute simd aligned(z:B:bfoo()) // expected-error {{unexpected ':' in nested name specifier; did you mean '::'?}} 33 for (int i = 0; i < 10; ++i) ; 34 35 #pragma omp target 36 #pragma omp teams distribute simd aligned(B:B::bfoo()) 37 for (int i = 0; i < 10; ++i) ; 38 39 #pragma omp target 40 #pragma omp teams distribute simd aligned(X::x : ::z) // expected-error {{integral constant expression must have integral or unscoped enumeration type, not 'int **'}} expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'B'}} 41 for (int i = 0; i < 10; ++i) ; 42 43 #pragma omp target 44 #pragma omp teams distribute simd aligned(B,rp,::z: X::x) // expected-error {{integral constant expression must have integral or unscoped enumeration type, not 'B'}} 45 for (int i = 0; i < 10; ++i) ; 46 47 #pragma omp target 48 #pragma omp teams distribute simd aligned(::z) 49 for (int i = 0; i < 10; ++i) ; 50 51 #pragma omp target 52 #pragma omp teams distribute simd aligned(B::bfoo()) // expected-error {{expected variable name}} 53 for (int i = 0; i < 10; ++i) ; 54 55 #pragma omp target 56 #pragma omp teams distribute simd aligned(B::ib,B:C1+C2) // expected-warning {{aligned clause will be ignored because the requested alignment is not a power of 2}} 57 for (int i = 0; i < 10; ++i) ; 58 } 59 60 // expected-note@+1 {{'num' defined here}} 61 template<int L, class T, class N> T test_template(T* arr, N num) { 62 N i; 63 T sum = (T)0; 64 T ind2 = - num * L; 65 // Negative number is passed as L. 66 67 #pragma omp target 68 #pragma omp teams distribute simd aligned(arr:L) // expected-error {{argument to 'aligned' clause must be a strictly positive integer value}} 69 for (i = 0; i < num; ++i) { 70 T cur = arr[(int)ind2]; 71 ind2 += L; 72 sum += cur; 73 } 74 75 #pragma omp target 76 #pragma omp teams distribute simd aligned(num:4) // expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'int'}} 77 for (i = 0; i < num; ++i); 78 79 return T(); 80 } 81 82 template<int LEN> int test_warn() { 83 int *ind2 = 0; 84 #pragma omp target 85 #pragma omp teams distribute simd aligned(ind2:LEN) // expected-error {{argument to 'aligned' clause must be a strictly positive integer value}} 86 for (int i = 0; i < 100; i++) { 87 ind2 += LEN; 88 } 89 return 0; 90 } 91 92 struct S1; // expected-note 2 {{declared here}} 93 extern S1 a; // expected-note {{'a' declared here}} 94 class S2 { 95 mutable int a; 96 public: 97 S2():a(0) { } 98 }; 99 const S2 b; // expected-note 1 {{'b' defined here}} 100 const S2 ba[5]; 101 class S3 { 102 int a; 103 public: 104 S3():a(0) { } 105 }; 106 const S3 ca[5]; 107 class S4 { 108 int a; 109 S4(); 110 public: 111 S4(int v):a(v) { } 112 }; 113 class S5 { 114 int a; 115 S5():a(0) {} 116 public: 117 S5(int v):a(v) { } 118 }; 119 120 S3 h; // expected-note 2 {{'h' defined here}} 121 #pragma omp threadprivate(h) 122 123 template<class I, class C> int foomain(I argc, C **argv) { 124 I e(argc); 125 I g(argc); 126 int i; // expected-note {{'i' defined here}} 127 // expected-note@+1 {{declared here}} 128 int &j = i; 129 130 #pragma omp target 131 #pragma omp teams distribute simd aligned // expected-error {{expected '(' after 'aligned'}} 132 for (I k = 0; k < argc; ++k) ++k; 133 134 #pragma omp target 135 #pragma omp teams distribute simd aligned ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} 136 for (I k = 0; k < argc; ++k) ++k; 137 138 #pragma omp target 139 #pragma omp teams distribute simd aligned () // expected-error {{expected expression}} 140 for (I k = 0; k < argc; ++k) ++k; 141 142 #pragma omp target 143 #pragma omp teams distribute simd aligned (argc // expected-error {{expected ')'}} expected-note {{to match this '('}} 144 for (I k = 0; k < argc; ++k) ++k; 145 146 #pragma omp target 147 #pragma omp teams distribute simd aligned (argc, // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} 148 for (I k = 0; k < argc; ++k) ++k; 149 150 // FIXME: Should argc really be a pointer? 151 #pragma omp target 152 #pragma omp teams distribute simd aligned (*argc > 0 ? argv[1] : argv[2]) // expected-error {{expected variable name}} 153 for (I k = 0; k < argc; ++k) ++k; 154 155 #pragma omp target 156 #pragma omp teams distribute simd aligned (argc : 5) // expected-warning {{aligned clause will be ignored because the requested alignment is not a power of 2}} 157 for (I k = 0; k < argc; ++k) ++k; 158 159 #pragma omp target 160 #pragma omp teams distribute simd aligned (S1) // expected-error {{'S1' does not refer to a value}} 161 for (I k = 0; k < argc; ++k) ++k; 162 163 #pragma omp target 164 #pragma omp teams distribute simd aligned (argv[1]) // expected-error {{expected variable name}} 165 for (I k = 0; k < argc; ++k) ++k; 166 167 #pragma omp target 168 #pragma omp teams distribute simd aligned(e, g) 169 for (I k = 0; k < argc; ++k) ++k; 170 171 #pragma omp target 172 #pragma omp teams distribute simd aligned(h) // expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'S3'}} 173 for (I k = 0; k < argc; ++k) ++k; 174 175 #pragma omp target 176 #pragma omp teams distribute simd aligned(i) // expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'int'}} 177 for (I k = 0; k < argc; ++k) ++k; 178 179 #pragma omp parallel 180 { 181 int *v = 0; 182 I i; 183 #pragma omp target 184 #pragma omp teams distribute simd aligned(v:16) 185 for (I k = 0; k < argc; ++k) { i = k; v += 2; } 186 } 187 float *f; 188 189 #pragma omp target 190 #pragma omp teams distribute simd aligned(f) 191 for (I k = 0; k < argc; ++k) ++k; 192 193 int v = 0; 194 195 #pragma omp target 196 #pragma omp teams distribute simd aligned(f:j) // expected-note {{initializer of 'j' is not a constant expression}} expected-error {{expression is not an integral constant expression}} 197 198 for (I k = 0; k < argc; ++k) { ++k; v += j; } 199 200 #pragma omp target 201 #pragma omp teams distribute simd aligned(f) 202 for (I k = 0; k < argc; ++k) ++k; 203 204 return 0; 205 } 206 207 // expected-note@+1 2 {{'argc' defined here}} 208 int main(int argc, char **argv) { 209 double darr[100]; 210 // expected-note@+1 {{in instantiation of function template specialization 'test_template<-4, double, int>' requested here}} 211 test_template<-4>(darr, 4); 212 test_warn<4>(); // ok 213 // expected-note@+1 {{in instantiation of function template specialization 'test_warn<0>' requested here}} 214 test_warn<0>(); 215 216 int i; 217 int &j = i; 218 219 #pragma omp target 220 #pragma omp teams distribute simd aligned // expected-error {{expected '(' after 'aligned'}} 221 for (int k = 0; k < argc; ++k) ++k; 222 223 #pragma omp target 224 #pragma omp teams distribute simd aligned ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} 225 for (int k = 0; k < argc; ++k) ++k; 226 227 #pragma omp target 228 #pragma omp teams distribute simd aligned () // expected-error {{expected expression}} 229 for (int k = 0; k < argc; ++k) ++k; 230 231 #pragma omp target 232 #pragma omp teams distribute simd aligned (argv // expected-error {{expected ')'}} expected-note {{to match this '('}} 233 for (int k = 0; k < argc; ++k) ++k; 234 235 #pragma omp target 236 #pragma omp teams distribute simd aligned (argc, // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'int'}} 237 for (int k = 0; k < argc; ++k) ++k; 238 239 #pragma omp target 240 #pragma omp teams 241 #pragma omp distribute simd aligned (argc > 0 ? argv[1] : argv[2]) // expected-error {{expected variable name}} 242 for (int k = 0; k < argc; ++k) ++k; 243 244 #pragma omp target 245 #pragma omp teams 246 #pragma omp distribute simd aligned (argc) // expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'int'}} 247 for (int k = 0; k < argc; ++k) ++k; 248 249 #pragma omp target 250 #pragma omp teams distribute simd aligned (S1) // expected-error {{'S1' does not refer to a value}} 251 for (int k = 0; k < argc; ++k) ++k; 252 253 #pragma omp target 254 #pragma omp teams distribute simd aligned (a, b) // expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'S1'}} expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'S2'}} 255 for (int k = 0; k < argc; ++k) ++k; 256 257 #pragma omp target 258 #pragma omp teams distribute simd aligned (argv[1]) // expected-error {{expected variable name}} 259 for (int k = 0; k < argc; ++k) ++k; 260 261 #pragma omp target 262 #pragma omp teams distribute simd aligned(h) // expected-error {{argument of aligned clause should be array, pointer, reference to array or reference to pointer, not 'S3'}} 263 for (int k = 0; k < argc; ++k) ++k; 264 265 int *pargc = &argc; 266 // expected-note@+1 {{in instantiation of function template specialization 'foomain<int *, char>' requested here}} 267 foomain<int*,char>(pargc,argv); 268 return 0; 269 } 270 271