[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// RUN: llvm-tblgen -gen-directive-decl -I %p/../../include %s | FileCheck -match-full-lines %s
|
|
|
|
// RUN: llvm-tblgen -gen-directive-impl -I %p/../../include %s | FileCheck -match-full-lines %s -check-prefix=IMPL
|
[openmp] Base of tablegen generated OpenMP common declaration
Summary:
As discussed previously when landing patch for OpenMP in Flang, the idea is
to share common part of the OpenMP declaration between the different Frontend.
While doing this it was thought that moving to tablegen instead of Macros will also
give a cleaner and more powerful way of generating these declaration.
This first part of a future series of patches is setting up the base .td file for
DirectiveLanguage as well as the OpenMP version of it. The base file is meant to
be used by other directive language such as OpenACC.
In this first patch, the Directive and Clause enums are generated with tablegen
instead of the macros on OMPConstants.h. The next pacth will extend this
to other enum and move the Flang frontend to use it.
Reviewers: jdoerfert, DavidTruby, fghanim, ABataev, jdenny, hfinkel, jhuber6, kiranchandramohan, kiranktp
Reviewed By: jdoerfert, jdenny
Subscribers: arphaman, martong, cfe-commits, mgorny, yaxunl, hiraditya, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #openmp, #clang
Differential Revision: https://reviews.llvm.org/D81736
2020-06-23 21:29:50 +08:00
|
|
|
|
|
|
|
include "llvm/Frontend/Directive/DirectiveBase.td"
|
|
|
|
|
|
|
|
def TestDirectiveLanguage : DirectiveLanguage {
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
let name = "Tdl";
|
[openmp] Base of tablegen generated OpenMP common declaration
Summary:
As discussed previously when landing patch for OpenMP in Flang, the idea is
to share common part of the OpenMP declaration between the different Frontend.
While doing this it was thought that moving to tablegen instead of Macros will also
give a cleaner and more powerful way of generating these declaration.
This first part of a future series of patches is setting up the base .td file for
DirectiveLanguage as well as the OpenMP version of it. The base file is meant to
be used by other directive language such as OpenACC.
In this first patch, the Directive and Clause enums are generated with tablegen
instead of the macros on OMPConstants.h. The next pacth will extend this
to other enum and move the Flang frontend to use it.
Reviewers: jdoerfert, DavidTruby, fghanim, ABataev, jdenny, hfinkel, jhuber6, kiranchandramohan, kiranktp
Reviewed By: jdoerfert, jdenny
Subscribers: arphaman, martong, cfe-commits, mgorny, yaxunl, hiraditya, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #openmp, #clang
Differential Revision: https://reviews.llvm.org/D81736
2020-06-23 21:29:50 +08:00
|
|
|
|
|
|
|
let cppNamespace = "tdl";
|
|
|
|
let directivePrefix = "TDLD_";
|
|
|
|
let clausePrefix = "TDLC_";
|
2020-07-11 08:11:11 +08:00
|
|
|
let includeHeader = "tdl.h.inc";
|
2020-08-11 22:43:56 +08:00
|
|
|
let flangClauseBaseClass = "TdlClause";
|
[openmp] Base of tablegen generated OpenMP common declaration
Summary:
As discussed previously when landing patch for OpenMP in Flang, the idea is
to share common part of the OpenMP declaration between the different Frontend.
While doing this it was thought that moving to tablegen instead of Macros will also
give a cleaner and more powerful way of generating these declaration.
This first part of a future series of patches is setting up the base .td file for
DirectiveLanguage as well as the OpenMP version of it. The base file is meant to
be used by other directive language such as OpenACC.
In this first patch, the Directive and Clause enums are generated with tablegen
instead of the macros on OMPConstants.h. The next pacth will extend this
to other enum and move the Flang frontend to use it.
Reviewers: jdoerfert, DavidTruby, fghanim, ABataev, jdenny, hfinkel, jhuber6, kiranchandramohan, kiranktp
Reviewed By: jdoerfert, jdenny
Subscribers: arphaman, martong, cfe-commits, mgorny, yaxunl, hiraditya, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #openmp, #clang
Differential Revision: https://reviews.llvm.org/D81736
2020-06-23 21:29:50 +08:00
|
|
|
}
|
|
|
|
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
def TDLC_ClauseA : Clause<"clausea"> {
|
|
|
|
let isImplicit = 1;
|
|
|
|
}
|
|
|
|
def TDLC_ClauseB : Clause<"clauseb"> {
|
|
|
|
let isDefault = 1;
|
2021-01-19 23:28:09 +08:00
|
|
|
let flangClass = "IntExpr";
|
2020-08-18 02:22:01 +08:00
|
|
|
let isValueList = 1;
|
|
|
|
}
|
|
|
|
def TDLC_ClauseC : Clause<"clausec"> {
|
2020-12-18 03:07:29 +08:00
|
|
|
let clangClass = "ClauseC";
|
2021-01-19 23:28:09 +08:00
|
|
|
let flangClass = "Name";
|
2020-08-18 02:22:01 +08:00
|
|
|
let defaultValue = "*";
|
|
|
|
let isValueOptional = 1;
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
}
|
2020-12-18 03:07:29 +08:00
|
|
|
def TDLC_ClauseD : Clause<"claused"> {
|
|
|
|
let clangClass = "ClauseD";
|
|
|
|
let isImplicit = 1;
|
|
|
|
}
|
[openmp] Base of tablegen generated OpenMP common declaration
Summary:
As discussed previously when landing patch for OpenMP in Flang, the idea is
to share common part of the OpenMP declaration between the different Frontend.
While doing this it was thought that moving to tablegen instead of Macros will also
give a cleaner and more powerful way of generating these declaration.
This first part of a future series of patches is setting up the base .td file for
DirectiveLanguage as well as the OpenMP version of it. The base file is meant to
be used by other directive language such as OpenACC.
In this first patch, the Directive and Clause enums are generated with tablegen
instead of the macros on OMPConstants.h. The next pacth will extend this
to other enum and move the Flang frontend to use it.
Reviewers: jdoerfert, DavidTruby, fghanim, ABataev, jdenny, hfinkel, jhuber6, kiranchandramohan, kiranktp
Reviewed By: jdoerfert, jdenny
Subscribers: arphaman, martong, cfe-commits, mgorny, yaxunl, hiraditya, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #openmp, #clang
Differential Revision: https://reviews.llvm.org/D81736
2020-06-23 21:29:50 +08:00
|
|
|
|
|
|
|
def TDL_DirA : Directive<"dira"> {
|
2020-07-07 10:19:43 +08:00
|
|
|
let allowedClauses = [
|
|
|
|
VersionedClause<TDLC_ClauseA, 2, 4>,
|
|
|
|
VersionedClause<TDLC_ClauseB, 2>
|
|
|
|
];
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
let isDefault = 1;
|
[openmp] Base of tablegen generated OpenMP common declaration
Summary:
As discussed previously when landing patch for OpenMP in Flang, the idea is
to share common part of the OpenMP declaration between the different Frontend.
While doing this it was thought that moving to tablegen instead of Macros will also
give a cleaner and more powerful way of generating these declaration.
This first part of a future series of patches is setting up the base .td file for
DirectiveLanguage as well as the OpenMP version of it. The base file is meant to
be used by other directive language such as OpenACC.
In this first patch, the Directive and Clause enums are generated with tablegen
instead of the macros on OMPConstants.h. The next pacth will extend this
to other enum and move the Flang frontend to use it.
Reviewers: jdoerfert, DavidTruby, fghanim, ABataev, jdenny, hfinkel, jhuber6, kiranchandramohan, kiranktp
Reviewed By: jdoerfert, jdenny
Subscribers: arphaman, martong, cfe-commits, mgorny, yaxunl, hiraditya, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #openmp, #clang
Differential Revision: https://reviews.llvm.org/D81736
2020-06-23 21:29:50 +08:00
|
|
|
}
|
|
|
|
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// CHECK: #ifndef LLVM_Tdl_INC
|
|
|
|
// CHECK-NEXT: #define LLVM_Tdl_INC
|
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: namespace llvm {
|
|
|
|
// CHECK-NEXT: class StringRef;
|
|
|
|
// CHECK-NEXT: namespace tdl {
|
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: enum class Directive {
|
|
|
|
// CHECK-NEXT: TDLD_dira,
|
|
|
|
// CHECK-NEXT: };
|
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: static constexpr std::size_t Directive_enumSize = 1;
|
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: enum class Clause {
|
|
|
|
// CHECK-NEXT: TDLC_clausea,
|
|
|
|
// CHECK-NEXT: TDLC_clauseb,
|
2020-08-18 02:22:01 +08:00
|
|
|
// CHECK-NEXT: TDLC_clausec,
|
2020-12-18 03:07:29 +08:00
|
|
|
// CHECK-NEXT: TDLC_claused,
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// CHECK-NEXT: };
|
|
|
|
// CHECK-EMPTY:
|
2020-12-18 03:07:29 +08:00
|
|
|
// CHECK-NEXT: static constexpr std::size_t Clause_enumSize = 4;
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: // Enumeration helper functions
|
|
|
|
// CHECK-NEXT: Directive getTdlDirectiveKind(llvm::StringRef Str);
|
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: llvm::StringRef getTdlDirectiveName(Directive D);
|
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: Clause getTdlClauseKind(llvm::StringRef Str);
|
|
|
|
// CHECK-EMPTY:
|
|
|
|
// CHECK-NEXT: llvm::StringRef getTdlClauseName(Clause C);
|
|
|
|
// CHECK-EMPTY:
|
2020-07-07 10:19:43 +08:00
|
|
|
// CHECK-NEXT: /// Return true if \p C is a valid clause for \p D in version \p Version.
|
|
|
|
// CHECK-NEXT: bool isAllowedClauseForDirective(Directive D, Clause C, unsigned Version);
|
|
|
|
// CHECK-EMPTY:
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// CHECK-NEXT: } // namespace tdl
|
|
|
|
// CHECK-NEXT: } // namespace llvm
|
|
|
|
// CHECK-NEXT: #endif // LLVM_Tdl_INC
|
|
|
|
|
2021-03-23 21:10:04 +08:00
|
|
|
// IMPL: #ifdef GEN_FLANG_DIRECTIVE_CLAUSE_SETS
|
|
|
|
// IMPL-NEXT: #undef GEN_FLANG_DIRECTIVE_CLAUSE_SETS
|
2020-07-11 08:11:11 +08:00
|
|
|
// IMPL-EMPTY:
|
2021-03-23 21:10:04 +08:00
|
|
|
// IMPL-NEXT: namespace llvm {
|
|
|
|
// IMPL-NEXT: namespace tdl {
|
2020-07-11 08:11:11 +08:00
|
|
|
// IMPL-EMPTY:
|
2021-03-23 21:10:04 +08:00
|
|
|
// IMPL-NEXT: // Sets for dira
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: static allowedClauses_TDLD_dira {
|
|
|
|
// IMPL-NEXT: llvm::tdl::Clause::TDLC_clausea,
|
|
|
|
// IMPL-NEXT: llvm::tdl::Clause::TDLC_clauseb,
|
|
|
|
// IMPL-NEXT: };
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: static allowedOnceClauses_TDLD_dira {
|
|
|
|
// IMPL-NEXT: };
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: static allowedExclusiveClauses_TDLD_dira {
|
|
|
|
// IMPL-NEXT: };
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: static requiredClauses_TDLD_dira {
|
|
|
|
// IMPL-NEXT: };
|
|
|
|
// IMPL-NEXT: } // namespace tdl
|
|
|
|
// IMPL-NEXT: } // namespace llvm
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_FLANG_DIRECTIVE_CLAUSE_SETS
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #ifdef GEN_FLANG_DIRECTIVE_CLAUSE_MAP
|
|
|
|
// IMPL-NEXT: #undef GEN_FLANG_DIRECTIVE_CLAUSE_MAP
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: {
|
|
|
|
// IMPL-NEXT: {llvm::tdl::Directive::TDLD_dira,
|
|
|
|
// IMPL-NEXT: {
|
|
|
|
// IMPL-NEXT: llvm::tdl::allowedClauses_TDLD_dira,
|
|
|
|
// IMPL-NEXT: llvm::tdl::allowedOnceClauses_TDLD_dira,
|
|
|
|
// IMPL-NEXT: llvm::tdl::allowedExclusiveClauses_TDLD_dira,
|
|
|
|
// IMPL-NEXT: llvm::tdl::requiredClauses_TDLD_dira,
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-NEXT: },
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_FLANG_DIRECTIVE_CLAUSE_MAP
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #ifdef GEN_FLANG_CLAUSE_PARSER_CLASSES
|
|
|
|
// IMPL-NEXT: #undef GEN_FLANG_CLAUSE_PARSER_CLASSES
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: EMPTY_CLASS(Clausea);
|
|
|
|
// IMPL-NEXT: WRAPPER_CLASS(Clauseb, std::list<IntExpr>);
|
|
|
|
// IMPL-NEXT: WRAPPER_CLASS(Clausec, std::optional<Name>);
|
|
|
|
// IMPL-NEXT: EMPTY_CLASS(Claused);
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_FLANG_CLAUSE_PARSER_CLASSES
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #ifdef GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST
|
|
|
|
// IMPL-NEXT: #undef GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: Clausea
|
|
|
|
// IMPL-NEXT: , Clauseb
|
|
|
|
// IMPL-NEXT: , Clausec
|
|
|
|
// IMPL-NEXT: , Claused
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_FLANG_CLAUSE_PARSER_CLASSES_LIST
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #ifdef GEN_FLANG_DUMP_PARSE_TREE_CLAUSES
|
|
|
|
// IMPL-NEXT: #undef GEN_FLANG_DUMP_PARSE_TREE_CLAUSES
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: NODE(TdlClause, Clausea)
|
|
|
|
// IMPL-NEXT: NODE(TdlClause, Clauseb)
|
|
|
|
// IMPL-NEXT: NODE(TdlClause, Clausec)
|
|
|
|
// IMPL-NEXT: NODE(TdlClause, Claused)
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_FLANG_DUMP_PARSE_TREE_CLAUSES
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #ifdef GEN_FLANG_CLAUSE_UNPARSE
|
|
|
|
// IMPL-NEXT: #undef GEN_FLANG_CLAUSE_UNPARSE
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: void Before(const TdlClause::Clausea &) { Word("CLAUSEA"); }
|
|
|
|
// IMPL-NEXT: void Unparse(const TdlClause::Clauseb &x) {
|
|
|
|
// IMPL-NEXT: Word("CLAUSEB");
|
|
|
|
// IMPL-NEXT: Put("(");
|
|
|
|
// IMPL-NEXT: Walk(x.v, ",");
|
|
|
|
// IMPL-NEXT: Put(")");
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-NEXT: void Unparse(const TdlClause::Clausec &x) {
|
|
|
|
// IMPL-NEXT: Word("CLAUSEC");
|
|
|
|
// IMPL-NEXT: Put("(");
|
|
|
|
// IMPL-NEXT: if (x.v.has_value())
|
|
|
|
// IMPL-NEXT: Walk(x.v);
|
|
|
|
// IMPL-NEXT: else
|
|
|
|
// IMPL-NEXT: Put("*");
|
|
|
|
// IMPL-NEXT: Put(")");
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-NEXT: void Before(const TdlClause::Claused &) { Word("CLAUSED"); }
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_FLANG_CLAUSE_UNPARSE
|
|
|
|
|
|
|
|
// IMPL: #ifdef GEN_CLANG_CLAUSE_CLASS
|
|
|
|
// IMPL-NEXT: #undef GEN_CLANG_CLAUSE_CLASS
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #ifndef CLAUSE
|
|
|
|
// IMPL-NEXT: #define CLAUSE(Enum, Str, Implicit)
|
|
|
|
// IMPL-NEXT: #endif
|
|
|
|
// IMPL-NEXT: #ifndef CLAUSE_CLASS
|
|
|
|
// IMPL-NEXT: #define CLAUSE_CLASS(Enum, Str, Class)
|
|
|
|
// IMPL-NEXT: #endif
|
|
|
|
// IMPL-NEXT: #ifndef CLAUSE_NO_CLASS
|
|
|
|
// IMPL-NEXT: #define CLAUSE_NO_CLASS(Enum, Str)
|
|
|
|
// IMPL-NEXT: #endif
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #define __CLAUSE(Name, Class) \
|
|
|
|
// IMPL-NEXT: CLAUSE(TDLC_##Name, #Name, /* Implicit */ false) \
|
|
|
|
// IMPL-NEXT: CLAUSE_CLASS(TDLC_##Name, #Name, Class)
|
|
|
|
// IMPL-NEXT: #define __CLAUSE_NO_CLASS(Name) \
|
|
|
|
// IMPL-NEXT: CLAUSE(TDLC_##Name, #Name, /* Implicit */ false) \
|
|
|
|
// IMPL-NEXT: CLAUSE_NO_CLASS(TDLC_##Name, #Name)
|
|
|
|
// IMPL-NEXT: #define __IMPLICIT_CLAUSE_CLASS(Name, Str, Class) \
|
|
|
|
// IMPL-NEXT: CLAUSE(TDLC_##Name, Str, /* Implicit */ true) \
|
|
|
|
// IMPL-NEXT: CLAUSE_CLASS(TDLC_##Name, Str, Class)
|
|
|
|
// IMPL-NEXT: #define __IMPLICIT_CLAUSE_NO_CLASS(Name, Str) \
|
|
|
|
// IMPL-NEXT: CLAUSE(TDLC_##Name, Str, /* Implicit */ true) \
|
|
|
|
// IMPL-NEXT: CLAUSE_NO_CLASS(TDLC_##Name, Str)
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: __IMPLICIT_CLAUSE_NO_CLASS(clausea, "clausea")
|
|
|
|
// IMPL-NEXT: __CLAUSE_NO_CLASS(clauseb)
|
|
|
|
// IMPL-NEXT: __CLAUSE(clausec, ClauseC)
|
|
|
|
// IMPL-NEXT: __IMPLICIT_CLAUSE_CLASS(claused, "claused", ClauseD)
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #undef __IMPLICIT_CLAUSE_NO_CLASS
|
|
|
|
// IMPL-NEXT: #undef __IMPLICIT_CLAUSE_CLASS
|
|
|
|
// IMPL-NEXT: #undef __CLAUSE
|
|
|
|
// IMPL-NEXT: #undef CLAUSE_NO_CLASS
|
|
|
|
// IMPL-NEXT: #undef CLAUSE_CLASS
|
|
|
|
// IMPL-NEXT: #undef CLAUSE
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_CLANG_CLAUSE_CLASS
|
|
|
|
|
|
|
|
// IMPL: #ifdef GEN_DIRECTIVES_IMPL
|
|
|
|
// IMPL-NEXT: #undef GEN_DIRECTIVES_IMPL
|
2020-07-11 08:11:11 +08:00
|
|
|
// IMPL-EMPTY:
|
[flang][openmp] Check clauses allowed semantic with tablegen generated map
Summary:
This patch is enabling the generation of clauses enum sets for semantics check in Flang through
tablegen. Enum sets and directive - sets map is generated by the new tablegen infrsatructure for OpenMP
and other directive languages.
The semantic checks for OpenMP are modified to use this newly generated map.
Reviewers: DavidTruby, sscalpone, kiranchandramohan, ichoyjx, jdoerfert
Reviewed By: DavidTruby, ichoyjx
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D83326
2020-07-12 00:42:05 +08:00
|
|
|
// IMPL-NEXT: Directive llvm::tdl::getTdlDirectiveKind(llvm::StringRef Str) {
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// IMPL-NEXT: return llvm::StringSwitch<Directive>(Str)
|
|
|
|
// IMPL-NEXT: .Case("dira",TDLD_dira)
|
|
|
|
// IMPL-NEXT: .Default(TDLD_dira);
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: llvm::StringRef llvm::tdl::getTdlDirectiveName(Directive Kind) {
|
|
|
|
// IMPL-NEXT: switch (Kind) {
|
|
|
|
// IMPL-NEXT: case TDLD_dira:
|
|
|
|
// IMPL-NEXT: return "dira";
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-NEXT: llvm_unreachable("Invalid Tdl Directive kind");
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: Clause llvm::tdl::getTdlClauseKind(llvm::StringRef Str) {
|
|
|
|
// IMPL-NEXT: return llvm::StringSwitch<Clause>(Str)
|
|
|
|
// IMPL-NEXT: .Case("clausea",TDLC_clauseb)
|
|
|
|
// IMPL-NEXT: .Case("clauseb",TDLC_clauseb)
|
2020-08-18 02:22:01 +08:00
|
|
|
// IMPL-NEXT: .Case("clausec",TDLC_clausec)
|
2020-12-18 03:07:29 +08:00
|
|
|
// IMPL-NEXT: .Case("claused",TDLC_clauseb)
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// IMPL-NEXT: .Default(TDLC_clauseb);
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: llvm::StringRef llvm::tdl::getTdlClauseName(Clause Kind) {
|
|
|
|
// IMPL-NEXT: switch (Kind) {
|
|
|
|
// IMPL-NEXT: case TDLC_clausea:
|
|
|
|
// IMPL-NEXT: return "clausea";
|
|
|
|
// IMPL-NEXT: case TDLC_clauseb:
|
|
|
|
// IMPL-NEXT: return "clauseb";
|
2020-08-18 02:22:01 +08:00
|
|
|
// IMPL-NEXT: case TDLC_clausec:
|
|
|
|
// IMPL-NEXT: return "clausec";
|
2020-12-18 03:07:29 +08:00
|
|
|
// IMPL-NEXT: case TDLC_claused:
|
|
|
|
// IMPL-NEXT: return "claused";
|
[openmp] Move Directive and Clause helper function to tablegen
Summary:
Follow up to D81736. Move getOpenMPDirectiveKind, getOpenMPClauseKind, getOpenMPDirectiveName and
getOpenMPClauseName to the new tablegen code generation. The code is generated in a new file named OMP.cpp.inc
Reviewers: jdoerfert, jdenny, thakis
Reviewed By: jdoerfert, jdenny
Subscribers: mgorny, yaxunl, hiraditya, guansong, sstefan1, llvm-commits, thakis
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D82405
2020-07-01 02:36:37 +08:00
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-NEXT: llvm_unreachable("Invalid Tdl Clause kind");
|
2020-07-07 10:19:43 +08:00
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: bool llvm::tdl::isAllowedClauseForDirective(Directive D, Clause C, unsigned Version) {
|
|
|
|
// IMPL-NEXT: assert(unsigned(D) <= llvm::tdl::Directive_enumSize);
|
|
|
|
// IMPL-NEXT: assert(unsigned(C) <= llvm::tdl::Clause_enumSize);
|
2020-07-09 07:54:34 +08:00
|
|
|
// IMPL-NEXT: switch (D) {
|
|
|
|
// IMPL-NEXT: case TDLD_dira:
|
|
|
|
// IMPL-NEXT: switch (C) {
|
|
|
|
// IMPL-NEXT: case TDLC_clausea:
|
|
|
|
// IMPL-NEXT: return 2 <= Version && 4 >= Version;
|
|
|
|
// IMPL-NEXT: case TDLC_clauseb:
|
|
|
|
// IMPL-NEXT: return 2 <= Version && 2147483647 >= Version;
|
|
|
|
// IMPL-NEXT: default:
|
|
|
|
// IMPL-NEXT: return false;
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-NEXT: break;
|
|
|
|
// IMPL-NEXT: }
|
|
|
|
// IMPL-NEXT: llvm_unreachable("Invalid Tdl Directive kind");
|
2020-07-07 10:19:43 +08:00
|
|
|
// IMPL-NEXT: }
|
2021-03-23 21:10:04 +08:00
|
|
|
// IMPL-EMPTY:
|
|
|
|
// IMPL-NEXT: #endif // GEN_DIRECTIVES_IMPL
|