// RUN: %clang_cc1 -triple x86_64-apple-macos10.7.0 -verify -fopenmp -fnoopenmp-use-tls -ferror-limit 100 -emit-llvm -o - %s // RUN: %clang_cc1 -triple x86_64-apple-macos10.7.0 -verify -fopenmp -ferror-limit 100 -emit-llvm -o - %s // RUN: %clang_cc1 -triple x86_64-apple-macos10.7.0 -verify -fopenmp-simd -fnoopenmp-use-tls -ferror-limit 100 -emit-llvm -o - %s // RUN: %clang_cc1 -triple x86_64-apple-macos10.7.0 -verify -fopenmp-simd -ferror-limit 100 -emit-llvm -o - %s #pragma omp allocate // expected-error {{expected '(' after 'allocate'}} #pragma omp allocate( // expected-error {{expected identifier}} expected-error {{expected ')'}} expected-note {{to match this '('}} #pragma omp allocate() // expected-error {{expected identifier}} #pragma omp allocate(1) // expected-error {{expected unqualified-id}} struct CompleteSt { int a; }; struct CompleteSt1 { #pragma omp allocate(1) // expected-error {{expected unqualified-id}} int a; } d; // expected-note {{'d' defined here}} int a; // expected-note {{'a' defined here}} #pragma omp allocate(a) #pragma omp allocate(u) // expected-error {{use of undeclared identifier 'u'}} #pragma omp allocate(d, a) int foo() { // expected-note {{declared here}} static int l; #pragma omp allocate(l)) // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} return (a); } #pragma omp allocate(a)( // expected-warning@-1 {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate(a)[ // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate(a) { // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate(a)) // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate(a)] // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate(a) } // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate a // expected-error {{expected '(' after 'allocate'}} #pragma omp allocate(d // expected-error {{expected ')'}} expected-note {{to match this '('}} #pragma omp allocate(d)) // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} int x, y; #pragma omp allocate(x)) // expected-warning {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate(y)), // expected-warning@-1 {{extra tokens at the end of '#pragma omp allocate' are ignored}} #pragma omp allocate(a, d) #pragma omp allocate(d.a) // expected-error {{expected identifier}} #pragma omp allocate((float)a) // expected-error {{expected unqualified-id}} int foa; // expected-note {{'foa' declared here}} #pragma omp allocate(faa) // expected-error {{use of undeclared identifier 'faa'; did you mean 'foa'?}} #pragma omp allocate(foo) // expected-error {{'foo' is not a global variable, static local variable or static data member}} #pragma omp allocate(int a = 2) // expected-error {{expected unqualified-id}} struct IncompleteSt; extern IncompleteSt e; #pragma omp allocate(e) int &f = a; #pragma omp allocate(f) class TestClass { private: int a; // expected-note {{declared here}} static int b; // expected-note {{'b' declared here}} TestClass() : a(0) {} public: TestClass(int aaa) : a(aaa) {} #pragma omp allocate(b, a) // expected-error {{'a' is not a global variable, static local variable or static data member}} } g(10); #pragma omp allocate(b) // expected-error {{use of undeclared identifier 'b'}} #pragma omp allocate(TestClass::b) // expected-error {{'#pragma omp allocate' must appear in the scope of the 'TestClass::b' variable declaration}} #pragma omp allocate(g) namespace ns { int m; #pragma omp allocate(m, m) } // namespace ns #pragma omp allocate(m) // expected-error {{use of undeclared identifier 'm'}} #pragma omp allocate(ns::m) #pragma omp allocate(ns \ : m) // expected-error {{unexpected ':' in nested name specifier; did you mean '::'?}} const int h = 12; const volatile int i = 10; #pragma omp allocate(h, i) template class TempClass { private: T a; TempClass() : a() {} public: TempClass(T aaa) : a(aaa) {} static T s; #pragma omp allocate(s) }; #pragma omp allocate(s) // expected-error {{use of undeclared identifier 's'}} static __thread int t; #pragma omp allocate(t) // Register "0" is currently an invalid register for global register variables. // Use "esp" instead of "0". // register int reg0 __asm__("0"); register int reg0 __asm__("esp"); #pragma omp allocate(reg0) int o; // expected-note {{candidate found by name lookup is 'o'}} #pragma omp allocate(o) namespace { int o; // expected-note {{candidate found by name lookup is '(anonymous namespace)::o'}} #pragma omp allocate(o) #pragma omp allocate(o) } // namespace #pragma omp allocate(o) // expected-error {{reference to 'o' is ambiguous}} #pragma omp allocate(::o) int main(int argc, char **argv) { int x, y = argc; static double d1; static double d2; static double d3; // expected-note {{'d3' defined here}} static double d4; static TestClass LocalClass(y); #pragma omp allocate(LocalClass) d.a = a; d2++; ; #pragma omp allocate(argc + y) // expected-error {{expected identifier}} #pragma omp allocate(argc, y) #pragma omp allocate(d2) #pragma omp allocate(d1) { ++a; d2 = 0; #pragma omp allocate(d3) // expected-error {{'#pragma omp allocate' must appear in the scope of the 'd3' variable declaration}} } #pragma omp allocate(d3) label: #pragma omp allocate(d4) // expected-error {{'#pragma omp allocate' cannot be an immediate substatement}} #pragma omp allocate(a) // expected-error {{'#pragma omp allocate' must appear in the scope of the 'a' variable declaration}} return (y); #pragma omp allocate(d) // expected-error {{'#pragma omp allocate' must appear in the scope of the 'd' variable declaration}} #pragma omp parallel allocate(d) // expected-error {{the referenced item is not found in any private clause on the same directive}} ; }