diff options
author | Carlo Bertolli <cbertol@us.ibm.com> | 2016-07-13 15:37:16 +0000 |
---|---|---|
committer | Carlo Bertolli <cbertol@us.ibm.com> | 2016-07-13 15:37:16 +0000 |
commit | 39ba7a70d528a5d2cdf53f102b412c90f931414c (patch) | |
tree | 64221dc51284f6434fd66732b85f87e52578a16b /test/OpenMP/target_data_use_device_ptr_ast_print.cpp | |
parent | 4e7c8ba2f78c17974062fc0f239f4ed0b87ed611 (diff) |
[OpenMP] Initial implementation of parse+sema for clause use_device_ptr of 'target data'
http://reviews.llvm.org/D21904
This patch is similar to the implementation of 'private' clause: it adds a list of private pointers to be used within the target data region to store the device pointers returned by the runtime.
Please refer to the following document for a full description of what the runtime witll return in this case (page 10 and 11):
https://github.com/clang-omp/OffloadingDesign
I am happy to answer any question related to the runtime interface to help reviewing this patch.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@275271 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/OpenMP/target_data_use_device_ptr_ast_print.cpp')
-rw-r--r-- | test/OpenMP/target_data_use_device_ptr_ast_print.cpp | 154 |
1 files changed, 154 insertions, 0 deletions
diff --git a/test/OpenMP/target_data_use_device_ptr_ast_print.cpp b/test/OpenMP/target_data_use_device_ptr_ast_print.cpp new file mode 100644 index 0000000000..4e3253b279 --- /dev/null +++ b/test/OpenMP/target_data_use_device_ptr_ast_print.cpp @@ -0,0 +1,154 @@ +// RxUN: %clang_cc1 -verify -fopenmp -std=c++11 -ast-print %s | FileCheck %s +// RUN: %clang_cc1 -fopenmp -x c++ -std=c++11 -emit-pch -o %t %s +// RUN: %clang_cc1 -fopenmp -std=c++11 -include-pch %t -fsyntax-only -verify %s -ast-print | FileCheck %s +// expected-no-diagnostics + +#ifndef HEADER +#define HEADER + +struct ST { + int *a; +}; +struct SA { + int i, j; + int *k = &j; + int *&z = k; + void func(int arg) { +#pragma omp target data map(tofrom: i) use_device_ptr(k) + {} +#pragma omp target data map(tofrom: i) use_device_ptr(z) + {} + return; + } +}; +// CHECK: struct SA +// CHECK: void func( +// CHECK: #pragma omp target data map(tofrom: this->i) use_device_ptr(this->k) +// CHECK: #pragma omp target data map(tofrom: this->i) use_device_ptr(this->z) +struct SB { + unsigned A; + unsigned B; + float Arr[100]; + float *Ptr; + float *foo() { + return &Arr[0]; + } +}; + +struct SC { + unsigned A : 2; + unsigned B : 3; + unsigned C; + unsigned D; + float Arr[100]; + SB S; + SB ArrS[100]; + SB *PtrS; + SB *&RPtrS; + float *Ptr; + + SC(SB *&_RPtrS) : RPtrS(_RPtrS) {} +}; + +union SD { + unsigned A; + float B; +}; + +struct S1; +extern S1 a; +class S2 { + mutable int a; +public: + S2():a(0) { } + S2(S2 &s2):a(s2.a) { } + static float S2s; + static const float S2sc; +}; +const float S2::S2sc = 0; +const S2 b; +const S2 ba[5]; +class S3 { + int a; +public: + S3():a(0) { } + S3(S3 &s3):a(s3.a) { } +}; +const S3 c; +const S3 ca[5]; +extern const int f; +class S4 { + int a; + S4(); + S4(const S4 &s4); +public: + S4(int v):a(v) { } +}; +class S5 { + int a; + S5():a(0) {} + S5(const S5 &s5):a(s5.a) { } +public: + S5(int v):a(v) { } +}; + +S3 h; +#pragma omp threadprivate(h) + +typedef int from; + +template <typename T> +T tmain(T argc) { + T i; + T &j = i; + T *k = &j; + T *&z = k; +#pragma omp target data map(tofrom: i) use_device_ptr(k) + {} +#pragma omp target data map(tofrom: i) use_device_ptr(z) + {} + return 0; +} + +// CHECK: template <typename T = int> int tmain(int argc) { +// CHECK-NEXT: int i; +// CHECK-NEXT: int &j = i; +// CHECK-NEXT: int *k = &j; +// CHECK-NEXT: int *&z = k; +// CHECK-NEXT: #pragma omp target data map(tofrom: i) use_device_ptr(k) +// CHECK-NEXT: { +// CHECK-NEXT: } +// CHECK-NEXT: #pragma omp target data map(tofrom: i) use_device_ptr(z) + +// CHECK: template <typename T = int *> int *tmain(int *argc) { +// CHECK-NEXT: int *i; +// CHECK-NEXT: int *&j = i; +// CHECK-NEXT: int **k = &j; +// CHECK-NEXT: int **&z = k; +// CHECK-NEXT: #pragma omp target data map(tofrom: i) use_device_ptr(k) +// CHECK-NEXT: { +// CHECK-NEXT: } +// CHECK-NEXT: #pragma omp target data map(tofrom: i) use_device_ptr(z) + +// CHECK-LABEL: int main(int argc, char **argv) { +int main(int argc, char **argv) { + int i; + int &j = i; + int *k = &j; + int *&z = k; +// CHECK-NEXT: int i; +// CHECK-NEXT: int &j = i; +// CHECK-NEXT: int *k = &j; +// CHECK-NEXT: int *&z = k; +#pragma omp target data map(tofrom: i) use_device_ptr(k) +// CHECK-NEXT: #pragma omp target data map(tofrom: i) use_device_ptr(k) + {} +// CHECK-NEXT: { +// CHECK-NEXT: } +#pragma omp target data map(tofrom: i) use_device_ptr(z) +// CHECK-NEXT: #pragma omp target data map(tofrom: i) use_device_ptr(z) + {} + return tmain<int>(argc) + (*tmain<int*>(&argc)); +} + +#endif |