diff options
| author | Samuel Antao <sfantao@us.ibm.com> | 2016-07-28 14:25:09 +0000 |
|---|---|---|
| committer | Samuel Antao <sfantao@us.ibm.com> | 2016-07-28 14:25:09 +0000 |
| commit | 6890b09634890ed9f145531d11d9982a31140533 (patch) | |
| tree | 27e7c9f2ecaad2c6cc4a4e805c8bf2b4af472628 /clang/test/OpenMP/target_is_device_ptr_messages.cpp | |
| parent | cc10b85789a03b2b32d5b9c5873cdbb1ecac82b0 (diff) | |
| download | bcm5719-llvm-6890b09634890ed9f145531d11d9982a31140533.tar.gz bcm5719-llvm-6890b09634890ed9f145531d11d9982a31140533.zip | |
[OpenMP] Code generation for the is_device_ptr clause
Summary: This patch adds support for the is_device_ptr clause. It expands SEMA to use the mappable expression logic that can only be tested with code generation in place and check conflicts with other data sharing related clauses using the mappable expressions infrastructure.
Reviewers: hfinkel, carlo.bertolli, arpith-jacob, kkwli0, ABataev
Subscribers: caomhin, cfe-commits
Differential Revision: https://reviews.llvm.org/D22788
llvm-svn: 276978
Diffstat (limited to 'clang/test/OpenMP/target_is_device_ptr_messages.cpp')
| -rw-r--r-- | clang/test/OpenMP/target_is_device_ptr_messages.cpp | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/clang/test/OpenMP/target_is_device_ptr_messages.cpp b/clang/test/OpenMP/target_is_device_ptr_messages.cpp index 634e16114e1..8cd1426081a 100644 --- a/clang/test/OpenMP/target_is_device_ptr_messages.cpp +++ b/clang/test/OpenMP/target_is_device_ptr_messages.cpp @@ -142,6 +142,7 @@ T tmain(T argc) { T *&z = k; T aa[10]; auto &raa = aa; + S6 *ps; #pragma omp target is_device_ptr // expected-error {{expected '(' after 'is_device_ptr'}} {} #pragma omp target is_device_ptr( // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{expected expression}} @@ -178,6 +179,22 @@ T tmain(T argc) { {} #pragma omp target is_device_ptr(da) // OK {} +#pragma omp target map(ps) is_device_ptr(ps) // expected-error{{variable already marked as mapped in current construct}} expected-note{{used here}} + {} +#pragma omp target is_device_ptr(ps) map(ps) // expected-error{{variable already marked as mapped in current construct}} expected-note{{used here}} + {} +#pragma omp target map(ps->a) is_device_ptr(ps) // expected-error{{variable already marked as mapped in current construct}} expected-note{{used here}} + {} +#pragma omp target is_device_ptr(ps) map(ps->a) // expected-error{{pointer cannot be mapped along with a section derived from itself}} expected-note{{used here}} + {} +#pragma omp target is_device_ptr(ps) firstprivate(ps) // expected-error{{firstprivate variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} + {} +#pragma omp target firstprivate(ps) is_device_ptr(ps) // expected-error{{firstprivate variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} expected-note{{defined as firstprivate}} + {} +#pragma omp target is_device_ptr(ps) private(ps) // expected-error{{private variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} + {} +#pragma omp target private(ps) is_device_ptr(ps) // expected-error{{private variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} expected-note{{defined as private}} + {} return 0; } @@ -194,6 +211,7 @@ int main(int argc, char **argv) { int *&z = k; int aa[10]; auto &raa = aa; + S6 *ps; #pragma omp target is_device_ptr // expected-error {{expected '(' after 'is_device_ptr'}} {} #pragma omp target is_device_ptr( // expected-error {{expected ')'}} expected-note {{to match this '('}} expected-error {{expected expression}} @@ -230,5 +248,21 @@ int main(int argc, char **argv) { {} #pragma omp target is_device_ptr(da) // OK {} +#pragma omp target map(ps) is_device_ptr(ps) // expected-error{{variable already marked as mapped in current construct}} expected-note{{used here}} + {} +#pragma omp target is_device_ptr(ps) map(ps) // expected-error{{variable already marked as mapped in current construct}} expected-note{{used here}} + {} +#pragma omp target map(ps->a) is_device_ptr(ps) // expected-error{{variable already marked as mapped in current construct}} expected-note{{used here}} + {} +#pragma omp target is_device_ptr(ps) map(ps->a) // expected-error{{pointer cannot be mapped along with a section derived from itself}} expected-note{{used here}} + {} +#pragma omp target is_device_ptr(ps) firstprivate(ps) // expected-error{{firstprivate variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} + {} +#pragma omp target firstprivate(ps) is_device_ptr(ps) // expected-error{{firstprivate variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} expected-note{{defined as firstprivate}} + {} +#pragma omp target is_device_ptr(ps) private(ps) // expected-error{{private variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} + {} +#pragma omp target private(ps) is_device_ptr(ps) // expected-error{{private variable cannot be in a is_device_ptr clause in '#pragma omp target' directive}} expected-note{{defined as private}} + {} return tmain<int, 3>(argc); // expected-note {{in instantiation of function template specialization 'tmain<int, 3>' requested here}} } |

