diff options
author | Kelvin Li <kkwli0@gmail.com> | 2016-07-06 04:45:38 +0000 |
---|---|---|
committer | Kelvin Li <kkwli0@gmail.com> | 2016-07-06 04:45:38 +0000 |
commit | 787f3fcc6b38ca500939f8610c5bff6e3396ce75 (patch) | |
tree | 65f1ec8e73711c7ba888b2122c82811db301f99d /clang/lib/Basic/OpenMPKinds.cpp | |
parent | 46e7555d4b94d73cf29257a25e2eaeb1e33e6bb6 (diff) | |
download | bcm5719-llvm-787f3fcc6b38ca500939f8610c5bff6e3396ce75.tar.gz bcm5719-llvm-787f3fcc6b38ca500939f8610c5bff6e3396ce75.zip |
[OpenMP] Sema and parsing for 'distribute simd' pragma
Summary: This patch is an implementation of sema and parsing for the OpenMP composite pragma 'distribute simd'.
Differential Revision: http://reviews.llvm.org/D22007
llvm-svn: 274604
Diffstat (limited to 'clang/lib/Basic/OpenMPKinds.cpp')
-rw-r--r-- | clang/lib/Basic/OpenMPKinds.cpp | 22 |
1 files changed, 18 insertions, 4 deletions
diff --git a/clang/lib/Basic/OpenMPKinds.cpp b/clang/lib/Basic/OpenMPKinds.cpp index f4ffb09cfa3..72fbc66dc3b 100644 --- a/clang/lib/Basic/OpenMPKinds.cpp +++ b/clang/lib/Basic/OpenMPKinds.cpp @@ -586,6 +586,16 @@ bool clang::isAllowedClauseForDirective(OpenMPDirectiveKind DKind, break; } break; + case OMPD_distribute_simd: + switch (CKind) { +#define OPENMP_DISTRIBUTE_SIMD_CLAUSE(Name) \ + case OMPC_##Name: \ + return true; +#include "clang/Basic/OpenMPKinds.def" + default: + break; + } + break; case OMPD_declare_target: case OMPD_end_declare_target: case OMPD_unknown: @@ -609,7 +619,8 @@ bool clang::isOpenMPLoopDirective(OpenMPDirectiveKind DKind) { DKind == OMPD_taskloop || DKind == OMPD_taskloop_simd || DKind == OMPD_distribute || DKind == OMPD_target_parallel_for || DKind == OMPD_distribute_parallel_for || - DKind == OMPD_distribute_parallel_for_simd; + DKind == OMPD_distribute_parallel_for_simd || + DKind == OMPD_distribute_simd; // TODO add next directives. } @@ -655,13 +666,15 @@ bool clang::isOpenMPTeamsDirective(OpenMPDirectiveKind DKind) { bool clang::isOpenMPSimdDirective(OpenMPDirectiveKind DKind) { return DKind == OMPD_simd || DKind == OMPD_for_simd || DKind == OMPD_parallel_for_simd || DKind == OMPD_taskloop_simd || - DKind == OMPD_distribute_parallel_for_simd; + DKind == OMPD_distribute_parallel_for_simd || + DKind == OMPD_distribute_simd; // TODO add next directives. } bool clang::isOpenMPDistributeDirective(OpenMPDirectiveKind Kind) { return Kind == OMPD_distribute || Kind == OMPD_distribute_parallel_for || - Kind == OMPD_distribute_parallel_for_simd; + Kind == OMPD_distribute_parallel_for_simd || + Kind == OMPD_distribute_simd; // TODO add next directives. } @@ -681,5 +694,6 @@ bool clang::isOpenMPTaskingDirective(OpenMPDirectiveKind Kind) { bool clang::isOpenMPLoopBoundSharingDirective(OpenMPDirectiveKind Kind) { return Kind == OMPD_distribute_parallel_for || - Kind == OMPD_distribute_parallel_for_simd; + Kind == OMPD_distribute_parallel_for_simd || + Kind == OMPD_distribute_simd; } |