diff options
author | Samuel Antao <sfantao@us.ibm.com> | 2016-01-19 20:04:50 +0000 |
---|---|---|
committer | Samuel Antao <sfantao@us.ibm.com> | 2016-01-19 20:04:50 +0000 |
commit | 725907603205e62fc02e2cfc40cdf3719774bf6f (patch) | |
tree | 4515b906368a389bc63fc7bff38b860c2165b266 /clang/test/OpenMP/target_exit_data_device_messages.cpp | |
parent | d4af297df1b0dc442622494214c67fb4a9848d43 (diff) | |
download | bcm5719-llvm-725907603205e62fc02e2cfc40cdf3719774bf6f.tar.gz bcm5719-llvm-725907603205e62fc02e2cfc40cdf3719774bf6f.zip |
[OpenMP] Parsing + sema for "target exit data" directive.
Patch by Arpith Jacob. Thanks!
llvm-svn: 258177
Diffstat (limited to 'clang/test/OpenMP/target_exit_data_device_messages.cpp')
-rw-r--r-- | clang/test/OpenMP/target_exit_data_device_messages.cpp | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/clang/test/OpenMP/target_exit_data_device_messages.cpp b/clang/test/OpenMP/target_exit_data_device_messages.cpp new file mode 100644 index 00000000000..d9ce0ddd7ea --- /dev/null +++ b/clang/test/OpenMP/target_exit_data_device_messages.cpp @@ -0,0 +1,29 @@ +// RUN: %clang_cc1 -triple x86_64-apple-macos10.7.0 -verify -fopenmp -ferror-limit 100 -o - %s + +void foo() { +} + +bool foobool(int argc) { + return argc; +} + +struct S1; // expected-note {{declared here}} + +int main(int argc, char **argv) { + int i; + #pragma omp target exit data map(from: i) device // expected-error {{expected '(' after 'device'}} + #pragma omp target exit data map(from: i) device ( // expected-error {{expected expression}} expected-error {{expected ')'}} expected-note {{to match this '('}} + #pragma omp target exit data map(from: i) device () // expected-error {{expected expression}} + #pragma omp target exit data map(from: i) device (argc // expected-error {{expected ')'}} expected-note {{to match this '('}} + #pragma omp target exit data map(from: i) device (argc)) // expected-warning {{extra tokens at the end of '#pragma omp target exit data' are ignored}} +#pragma omp target exit data map(from: i) device (argc > 0 ? argv[1] : argv[2]) // expected-error {{expression must have integral or unscoped enumeration type, not 'char *'}} + #pragma omp target exit data map(from: i) device (argc + argc) + #pragma omp target exit data map(from: i) device (argc), device (argc+1) // expected-error {{directive '#pragma omp target exit data' cannot contain more than one 'device' clause}} + #pragma omp target exit data map(from: i) device (S1) // expected-error {{'S1' does not refer to a value}} + #pragma omp target exit data map(from: i) device (-2) // expected-error {{argument to 'device' clause must be a non-negative integer value}} + #pragma omp target exit data map(from: i) device (-10u) + #pragma omp target exit data map(from: i) device (3.14) // expected-error {{expression must have integral or unscoped enumeration type, not 'double'}} + foo(); + + return 0; +} |