diff options
author | Kelvin Li <kkwli0@gmail.com> | 2016-07-20 22:57:10 +0000 |
---|---|---|
committer | Kelvin Li <kkwli0@gmail.com> | 2016-07-20 22:57:10 +0000 |
commit | 986330c190fdecfe608b20449ba27491080afeba (patch) | |
tree | 79b6dd16ae472cc3f1d654c776cb707fd0277b82 /clang/lib/Basic | |
parent | fb64ebe313f0fa6e47db8236f40a27c73e08e396 (diff) | |
download | bcm5719-llvm-986330c190fdecfe608b20449ba27491080afeba.tar.gz bcm5719-llvm-986330c190fdecfe608b20449ba27491080afeba.zip |
[OpenMP] Sema and parsing for 'target simd' pragma
This patch is to implement sema and parsing for 'target simd' pragma.
Differential Revision: https://reviews.llvm.org/D22479
llvm-svn: 276203
Diffstat (limited to 'clang/lib/Basic')
-rw-r--r-- | clang/lib/Basic/OpenMPKinds.cpp | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/clang/lib/Basic/OpenMPKinds.cpp b/clang/lib/Basic/OpenMPKinds.cpp index d1e4779e2c7..ac89983d0ce 100644 --- a/clang/lib/Basic/OpenMPKinds.cpp +++ b/clang/lib/Basic/OpenMPKinds.cpp @@ -610,6 +610,16 @@ bool clang::isAllowedClauseForDirective(OpenMPDirectiveKind DKind, break; } break; + case OMPD_target_simd: + switch (CKind) { +#define OPENMP_TARGET_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: @@ -635,7 +645,7 @@ bool clang::isOpenMPLoopDirective(OpenMPDirectiveKind DKind) { DKind == OMPD_distribute_parallel_for || DKind == OMPD_distribute_parallel_for_simd || DKind == OMPD_distribute_simd || - DKind == OMPD_target_parallel_for_simd; + DKind == OMPD_target_parallel_for_simd || DKind == OMPD_target_simd; // TODO add next directives. } @@ -669,7 +679,7 @@ bool clang::isOpenMPTargetExecutionDirective(OpenMPDirectiveKind DKind) { // TODO add next directives. return DKind == OMPD_target || DKind == OMPD_target_parallel || DKind == OMPD_target_parallel_for || - DKind == OMPD_target_parallel_for_simd; + DKind == OMPD_target_parallel_for_simd || DKind == OMPD_target_simd; } bool clang::isOpenMPTargetDataManagementDirective(OpenMPDirectiveKind DKind) { @@ -685,7 +695,7 @@ 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_simd; + DKind == OMPD_distribute_simd || DKind == OMPD_target_simd; // TODO add next directives. } |