2020-02-25 23:11:52 +08:00
|
|
|
//===-- lib/Semantics/check-omp-structure.h ---------------------*- C++ -*-===//
|
2019-06-26 07:18:51 +08:00
|
|
|
//
|
2019-12-21 04:52:07 +08:00
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
2019-06-26 07:18:51 +08:00
|
|
|
//
|
2020-01-11 04:12:03 +08:00
|
|
|
//===----------------------------------------------------------------------===//
|
2019-06-26 07:18:51 +08:00
|
|
|
|
|
|
|
// OpenMP structure validity check list
|
|
|
|
// 1. invalid clauses on directive
|
|
|
|
// 2. invalid repeated clauses on directive
|
|
|
|
// 3. TODO: invalid nesting of regions
|
|
|
|
|
|
|
|
#ifndef FORTRAN_SEMANTICS_CHECK_OMP_STRUCTURE_H_
|
|
|
|
#define FORTRAN_SEMANTICS_CHECK_OMP_STRUCTURE_H_
|
|
|
|
|
2020-08-06 02:20:26 +08:00
|
|
|
#include "check-directive-structure.h"
|
2020-02-25 23:11:52 +08:00
|
|
|
#include "flang/Common/enum-set.h"
|
|
|
|
#include "flang/Parser/parse-tree.h"
|
|
|
|
#include "flang/Semantics/semantics.h"
|
[flang][openmp] Use common Directive and Clause enum from llvm/Frontend
Summary:
This patch is removing the custom enumeration for OpenMP Directives and Clauses and replace them
with the newly tablegen generated one from llvm/Frontend. This is a first patch and some will follow to share the same
infrastructure where possible. The next patch should use the clauses allowance defined in the tablegen file.
Reviewers: jdoerfert, DavidTruby, sscalpone, kiranchandramohan, ichoyjx
Reviewed By: DavidTruby, ichoyjx
Subscribers: jholewinski, cfe-commits, dblaikie, MaskRay, ymandel, ichoyjx, mgorny, yaxunl, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #flang, #clang
Differential Revision: https://reviews.llvm.org/D82906
2020-07-02 08:57:11 +08:00
|
|
|
#include "llvm/Frontend/OpenMP/OMPConstants.h"
|
|
|
|
|
|
|
|
using OmpDirectiveSet = Fortran::common::EnumSet<llvm::omp::Directive,
|
|
|
|
llvm::omp::Directive_enumSize>;
|
|
|
|
|
|
|
|
using OmpClauseSet =
|
|
|
|
Fortran::common::EnumSet<llvm::omp::Clause, llvm::omp::Clause_enumSize>;
|
|
|
|
|
[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
|
|
|
#define GEN_FLANG_DIRECTIVE_CLAUSE_SETS
|
2020-12-18 03:07:29 +08:00
|
|
|
#include "llvm/Frontend/OpenMP/OMP.inc"
|
[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
|
|
|
|
[flang][openmp] Use common Directive and Clause enum from llvm/Frontend
Summary:
This patch is removing the custom enumeration for OpenMP Directives and Clauses and replace them
with the newly tablegen generated one from llvm/Frontend. This is a first patch and some will follow to share the same
infrastructure where possible. The next patch should use the clauses allowance defined in the tablegen file.
Reviewers: jdoerfert, DavidTruby, sscalpone, kiranchandramohan, ichoyjx
Reviewed By: DavidTruby, ichoyjx
Subscribers: jholewinski, cfe-commits, dblaikie, MaskRay, ymandel, ichoyjx, mgorny, yaxunl, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #flang, #clang
Differential Revision: https://reviews.llvm.org/D82906
2020-07-02 08:57:11 +08:00
|
|
|
namespace llvm {
|
|
|
|
namespace omp {
|
|
|
|
static OmpDirectiveSet parallelSet{Directive::OMPD_distribute_parallel_do,
|
|
|
|
Directive::OMPD_distribute_parallel_do_simd, Directive::OMPD_parallel,
|
|
|
|
Directive::OMPD_parallel_do, Directive::OMPD_parallel_do_simd,
|
|
|
|
Directive::OMPD_parallel_sections, Directive::OMPD_parallel_workshare,
|
|
|
|
Directive::OMPD_target_parallel, Directive::OMPD_target_parallel_do,
|
|
|
|
Directive::OMPD_target_parallel_do_simd,
|
|
|
|
Directive::OMPD_target_teams_distribute_parallel_do,
|
|
|
|
Directive::OMPD_target_teams_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do_simd};
|
|
|
|
static OmpDirectiveSet doSet{Directive::OMPD_distribute_parallel_do,
|
2021-04-30 04:12:28 +08:00
|
|
|
Directive::OMPD_distribute_parallel_do_simd, Directive::OMPD_parallel_do,
|
|
|
|
Directive::OMPD_parallel_do_simd, Directive::OMPD_do,
|
|
|
|
Directive::OMPD_do_simd, Directive::OMPD_target_parallel_do,
|
|
|
|
Directive::OMPD_target_parallel_do_simd,
|
[flang][openmp] Use common Directive and Clause enum from llvm/Frontend
Summary:
This patch is removing the custom enumeration for OpenMP Directives and Clauses and replace them
with the newly tablegen generated one from llvm/Frontend. This is a first patch and some will follow to share the same
infrastructure where possible. The next patch should use the clauses allowance defined in the tablegen file.
Reviewers: jdoerfert, DavidTruby, sscalpone, kiranchandramohan, ichoyjx
Reviewed By: DavidTruby, ichoyjx
Subscribers: jholewinski, cfe-commits, dblaikie, MaskRay, ymandel, ichoyjx, mgorny, yaxunl, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #flang, #clang
Differential Revision: https://reviews.llvm.org/D82906
2020-07-02 08:57:11 +08:00
|
|
|
Directive::OMPD_target_teams_distribute_parallel_do,
|
|
|
|
Directive::OMPD_target_teams_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do_simd};
|
|
|
|
static OmpDirectiveSet doSimdSet{Directive::OMPD_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_parallel_do_simd, Directive::OMPD_do_simd,
|
|
|
|
Directive::OMPD_target_parallel_do_simd,
|
|
|
|
Directive::OMPD_target_teams_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do_simd};
|
2021-04-30 04:12:28 +08:00
|
|
|
static OmpDirectiveSet workShareSet{
|
|
|
|
OmpDirectiveSet{Directive::OMPD_workshare,
|
|
|
|
Directive::OMPD_parallel_workshare, Directive::OMPD_parallel_sections,
|
|
|
|
Directive::OMPD_sections, Directive::OMPD_single} |
|
|
|
|
doSet};
|
[flang][openmp] Use common Directive and Clause enum from llvm/Frontend
Summary:
This patch is removing the custom enumeration for OpenMP Directives and Clauses and replace them
with the newly tablegen generated one from llvm/Frontend. This is a first patch and some will follow to share the same
infrastructure where possible. The next patch should use the clauses allowance defined in the tablegen file.
Reviewers: jdoerfert, DavidTruby, sscalpone, kiranchandramohan, ichoyjx
Reviewed By: DavidTruby, ichoyjx
Subscribers: jholewinski, cfe-commits, dblaikie, MaskRay, ymandel, ichoyjx, mgorny, yaxunl, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #flang, #clang
Differential Revision: https://reviews.llvm.org/D82906
2020-07-02 08:57:11 +08:00
|
|
|
static OmpDirectiveSet taskloopSet{
|
|
|
|
Directive::OMPD_taskloop, Directive::OMPD_taskloop_simd};
|
|
|
|
static OmpDirectiveSet targetSet{Directive::OMPD_target,
|
|
|
|
Directive::OMPD_target_parallel, Directive::OMPD_target_parallel_do,
|
|
|
|
Directive::OMPD_target_parallel_do_simd, Directive::OMPD_target_simd,
|
|
|
|
Directive::OMPD_target_teams, Directive::OMPD_target_teams_distribute,
|
|
|
|
Directive::OMPD_target_teams_distribute_simd};
|
|
|
|
static OmpDirectiveSet simdSet{Directive::OMPD_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_distribute_simd, Directive::OMPD_parallel_do_simd,
|
|
|
|
Directive::OMPD_do_simd, Directive::OMPD_simd,
|
|
|
|
Directive::OMPD_target_parallel_do_simd,
|
|
|
|
Directive::OMPD_target_teams_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_target_teams_distribute_simd, Directive::OMPD_target_simd,
|
|
|
|
Directive::OMPD_taskloop_simd,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_teams_distribute_simd};
|
2021-04-29 20:29:58 +08:00
|
|
|
static OmpDirectiveSet teamSet{Directive::OMPD_teams,
|
|
|
|
Directive::OMPD_teams_distribute,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_do_simd,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_for,
|
|
|
|
Directive::OMPD_teams_distribute_parallel_for_simd,
|
|
|
|
Directive::OMPD_teams_distribute_simd};
|
[flang][openmp] Use common Directive and Clause enum from llvm/Frontend
Summary:
This patch is removing the custom enumeration for OpenMP Directives and Clauses and replace them
with the newly tablegen generated one from llvm/Frontend. This is a first patch and some will follow to share the same
infrastructure where possible. The next patch should use the clauses allowance defined in the tablegen file.
Reviewers: jdoerfert, DavidTruby, sscalpone, kiranchandramohan, ichoyjx
Reviewed By: DavidTruby, ichoyjx
Subscribers: jholewinski, cfe-commits, dblaikie, MaskRay, ymandel, ichoyjx, mgorny, yaxunl, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #flang, #clang
Differential Revision: https://reviews.llvm.org/D82906
2020-07-02 08:57:11 +08:00
|
|
|
static OmpDirectiveSet taskGeneratingSet{
|
|
|
|
OmpDirectiveSet{Directive::OMPD_task} | taskloopSet};
|
2021-03-20 02:54:06 +08:00
|
|
|
static OmpDirectiveSet nestedOrderedErrSet{Directive::OMPD_critical,
|
|
|
|
Directive::OMPD_ordered, Directive::OMPD_atomic, Directive::OMPD_task,
|
|
|
|
Directive::OMPD_taskloop};
|
2021-04-30 04:12:28 +08:00
|
|
|
static OmpDirectiveSet nestedWorkshareErrSet{
|
|
|
|
OmpDirectiveSet{Directive::OMPD_task, Directive::OMPD_taskloop,
|
|
|
|
Directive::OMPD_critical, Directive::OMPD_ordered,
|
|
|
|
Directive::OMPD_atomic, Directive::OMPD_master} |
|
|
|
|
workShareSet};
|
2021-05-14 02:56:07 +08:00
|
|
|
static OmpDirectiveSet nestedMasterErrSet{
|
|
|
|
OmpDirectiveSet{llvm::omp::Directive::OMPD_atomic} | taskGeneratingSet |
|
|
|
|
workShareSet};
|
2021-06-19 03:37:36 +08:00
|
|
|
static OmpDirectiveSet nestedBarrierErrSet{
|
|
|
|
OmpDirectiveSet{Directive::OMPD_critical, Directive::OMPD_ordered,
|
|
|
|
Directive::OMPD_atomic, Directive::OMPD_master} |
|
|
|
|
taskGeneratingSet | workShareSet};
|
2021-01-31 00:45:09 +08:00
|
|
|
static OmpClauseSet privateSet{
|
|
|
|
Clause::OMPC_private, Clause::OMPC_firstprivate, Clause::OMPC_lastprivate};
|
|
|
|
static OmpClauseSet privateReductionSet{
|
|
|
|
OmpClauseSet{Clause::OMPC_reduction} | privateSet};
|
[flang][openmp] Use common Directive and Clause enum from llvm/Frontend
Summary:
This patch is removing the custom enumeration for OpenMP Directives and Clauses and replace them
with the newly tablegen generated one from llvm/Frontend. This is a first patch and some will follow to share the same
infrastructure where possible. The next patch should use the clauses allowance defined in the tablegen file.
Reviewers: jdoerfert, DavidTruby, sscalpone, kiranchandramohan, ichoyjx
Reviewed By: DavidTruby, ichoyjx
Subscribers: jholewinski, cfe-commits, dblaikie, MaskRay, ymandel, ichoyjx, mgorny, yaxunl, guansong, jfb, sstefan1, aaron.ballman, llvm-commits
Tags: #llvm, #flang, #clang
Differential Revision: https://reviews.llvm.org/D82906
2020-07-02 08:57:11 +08:00
|
|
|
} // namespace omp
|
|
|
|
} // namespace llvm
|
2019-06-26 07:18:51 +08:00
|
|
|
|
|
|
|
namespace Fortran::semantics {
|
|
|
|
|
2021-01-31 00:45:09 +08:00
|
|
|
// Mapping from 'Symbol' to 'Source' to keep track of the variables
|
|
|
|
// used in multiple clauses
|
|
|
|
using SymbolSourceMap = std::multimap<const Symbol *, parser::CharBlock>;
|
|
|
|
// Multimap to check the triple <current_dir, enclosing_dir, enclosing_clause>
|
|
|
|
using DirectivesClauseTriple = std::multimap<llvm::omp::Directive,
|
|
|
|
std::pair<llvm::omp::Directive, const OmpClauseSet>>;
|
|
|
|
|
2020-08-06 02:20:26 +08:00
|
|
|
class OmpStructureChecker
|
|
|
|
: public DirectiveStructureChecker<llvm::omp::Directive, llvm::omp::Clause,
|
|
|
|
parser::OmpClause, llvm::omp::Clause_enumSize> {
|
2019-06-26 07:18:51 +08:00
|
|
|
public:
|
2020-08-06 02:20:26 +08:00
|
|
|
OmpStructureChecker(SemanticsContext &context)
|
|
|
|
: DirectiveStructureChecker(context,
|
|
|
|
#define GEN_FLANG_DIRECTIVE_CLAUSE_MAP
|
2020-12-18 03:07:29 +08:00
|
|
|
#include "llvm/Frontend/OpenMP/OMP.inc"
|
2020-08-06 02:20:26 +08:00
|
|
|
) {
|
|
|
|
}
|
2021-01-15 13:42:49 +08:00
|
|
|
using llvmOmpClause = const llvm::omp::Clause;
|
2019-06-26 07:18:51 +08:00
|
|
|
|
2019-07-10 05:08:50 +08:00
|
|
|
void Enter(const parser::OpenMPConstruct &);
|
2019-06-26 07:18:51 +08:00
|
|
|
void Enter(const parser::OpenMPLoopConstruct &);
|
|
|
|
void Leave(const parser::OpenMPLoopConstruct &);
|
[flang] [OpenMP] parse tree changes for `OpenMPLoopConstruct` (flang-compiler/f18#656)
1. Following Block and Sections constructs, re-structure loop related
constructs into `{Begin, Loop, End}`. Being part of the work in
PR flang-compiler/f18#599, the `Loop` and `End` nodes are optional during parser. They
should be filled in during the phase of `CanonicalizationOfOmp`. This
commit is solely for the parse tree change. So, after this commit,
PR flang-compiler/f18#599 needs to be changed accordingly.
2. Removed parse tree nodes for `END DO` and `END DO SIMD`. Similar to
Block and Sections constructs, `End` node now accepts clauses too,
the validity checks are deferred into Semantics. This is more genernal
and error message could be better.
3. With this commit alone, assertion error would occur when `End` directive
is present, for example `!$OMP END DO` because the `End` node is not
moved into `OpenMPLoopConstruct` yet. Again, PR flang-compiler/f18#599 will handle that.
More tests will be added in PR flang-compiler/f18#599 and during the future Semantics work.
Original-commit: flang-compiler/f18@8cd1932fd61fa67f8ad5abfd337cf7a223ea89f4
Reviewed-on: https://github.com/flang-compiler/f18/pull/656
2019-08-15 06:16:27 +08:00
|
|
|
void Enter(const parser::OmpEndLoopDirective &);
|
2019-06-26 07:18:51 +08:00
|
|
|
|
|
|
|
void Enter(const parser::OpenMPBlockConstruct &);
|
|
|
|
void Leave(const parser::OpenMPBlockConstruct &);
|
2021-09-17 21:53:07 +08:00
|
|
|
void Leave(const parser::OmpBeginBlockDirective &);
|
[flang] [OpenMP] parse tree changes for `OpenMPBlockConstruct` (flang-compiler/f18#632)
* [OpenMP] parse tree changes for `OpenMPBlockConstruct`
1. merge `Workshare` and `Single` into `OpenMPBlockConstruct` because
they both accept structured-block and syntax is similar to other block
directives.
2. `OpenMPBlockConstruct` changes to structure like `{Begin, Block, End}`,
where `Begin` and `End` are tuple of `{Directive, ClauseList}`.
3. Updated the check-omp-structure.* for necessary parts. Added all the END
directive enumeration types that may have clauses.
More tests will be added during Semantics.
* [OpenMP] Update on Tim's suggestion
1. Fix unspecified enumeration for `OmpDirective` in the `OmpContext`.
This is through getting rid of `PushContext(source)` function to
make sure whenever it is about to push a NEW context, directive
source location and enumeration are available. To do that, I moved
around all the switches for directive into high level `Construct`'s
`Enter` node. Besides fixing the issue, the side benefit is that
whenever we call `GetContext().directive`, we are sure that the
`directive` here was set already.
2. When `Enter` the `OmpEndBlockDirective` node, partial context
information, such as directive source location or legal clause lists,
needs to be reset. The new directive source location should be
`OmpEndBlockDirective`'s `source`. The enumeration `directive`
should not be reset for the END directives that do not accept
clauses because nothing needs to be checked (for example any clause
that is on `END PARALLEL` is illegal).
Original-commit: flang-compiler/f18@e5bd6b7ba0fbe9006f3e431260428b194f2d2616
Reviewed-on: https://github.com/flang-compiler/f18/pull/632
2019-08-10 06:11:20 +08:00
|
|
|
void Enter(const parser::OmpEndBlockDirective &);
|
2021-03-13 01:22:21 +08:00
|
|
|
void Leave(const parser::OmpEndBlockDirective &);
|
2019-06-26 07:18:51 +08:00
|
|
|
|
2019-08-02 05:32:33 +08:00
|
|
|
void Enter(const parser::OpenMPSectionsConstruct &);
|
|
|
|
void Leave(const parser::OpenMPSectionsConstruct &);
|
2019-08-14 23:42:28 +08:00
|
|
|
void Enter(const parser::OmpEndSectionsDirective &);
|
2021-03-13 01:22:21 +08:00
|
|
|
void Leave(const parser::OmpEndSectionsDirective &);
|
2019-08-02 05:32:33 +08:00
|
|
|
|
2019-08-06 05:51:02 +08:00
|
|
|
void Enter(const parser::OpenMPDeclareSimdConstruct &);
|
|
|
|
void Leave(const parser::OpenMPDeclareSimdConstruct &);
|
2020-10-17 00:36:12 +08:00
|
|
|
void Enter(const parser::OpenMPDeclarativeAllocate &);
|
|
|
|
void Leave(const parser::OpenMPDeclarativeAllocate &);
|
2019-08-21 01:23:56 +08:00
|
|
|
void Enter(const parser::OpenMPDeclareTargetConstruct &);
|
|
|
|
void Leave(const parser::OpenMPDeclareTargetConstruct &);
|
2020-10-17 00:36:12 +08:00
|
|
|
void Enter(const parser::OpenMPExecutableAllocate &);
|
|
|
|
void Leave(const parser::OpenMPExecutableAllocate &);
|
2021-09-15 00:22:03 +08:00
|
|
|
void Enter(const parser::OpenMPThreadprivate &);
|
|
|
|
void Leave(const parser::OpenMPThreadprivate &);
|
2019-08-02 05:32:33 +08:00
|
|
|
|
2019-08-07 02:59:40 +08:00
|
|
|
void Enter(const parser::OpenMPSimpleStandaloneConstruct &);
|
|
|
|
void Leave(const parser::OpenMPSimpleStandaloneConstruct &);
|
|
|
|
void Enter(const parser::OpenMPFlushConstruct &);
|
|
|
|
void Leave(const parser::OpenMPFlushConstruct &);
|
|
|
|
void Enter(const parser::OpenMPCancelConstruct &);
|
|
|
|
void Leave(const parser::OpenMPCancelConstruct &);
|
|
|
|
void Enter(const parser::OpenMPCancellationPointConstruct &);
|
|
|
|
void Leave(const parser::OpenMPCancellationPointConstruct &);
|
2020-10-07 02:18:08 +08:00
|
|
|
void Enter(const parser::OpenMPCriticalConstruct &);
|
|
|
|
void Leave(const parser::OpenMPCriticalConstruct &);
|
2020-12-14 15:11:39 +08:00
|
|
|
void Enter(const parser::OpenMPAtomicConstruct &);
|
|
|
|
void Leave(const parser::OpenMPAtomicConstruct &);
|
2019-08-07 02:59:40 +08:00
|
|
|
|
2019-07-02 04:55:06 +08:00
|
|
|
void Leave(const parser::OmpClauseList &);
|
2019-06-26 07:18:51 +08:00
|
|
|
void Enter(const parser::OmpClause &);
|
2020-12-14 15:11:39 +08:00
|
|
|
|
|
|
|
void Enter(const parser::OmpAtomicRead &);
|
|
|
|
void Leave(const parser::OmpAtomicRead &);
|
|
|
|
void Enter(const parser::OmpAtomicWrite &);
|
|
|
|
void Leave(const parser::OmpAtomicWrite &);
|
|
|
|
void Enter(const parser::OmpAtomicUpdate &);
|
|
|
|
void Leave(const parser::OmpAtomicUpdate &);
|
|
|
|
void Enter(const parser::OmpAtomicCapture &);
|
|
|
|
void Leave(const parser::OmpAtomic &);
|
2021-02-02 02:33:07 +08:00
|
|
|
|
|
|
|
#define GEN_FLANG_CLAUSE_CHECK_ENTER
|
|
|
|
#include "llvm/Frontend/OpenMP/OMP.inc"
|
2019-06-26 07:18:51 +08:00
|
|
|
|
2021-03-14 20:42:30 +08:00
|
|
|
// Get the OpenMP Clause Kind for the corresponding Parser class
|
|
|
|
template <typename A>
|
|
|
|
llvm::omp::Clause GetClauseKindForParserClass(const A &) {
|
|
|
|
#define GEN_FLANG_CLAUSE_PARSER_KIND_MAP
|
|
|
|
#include "llvm/Frontend/OpenMP/OMP.inc"
|
|
|
|
}
|
|
|
|
|
2019-06-26 07:18:51 +08:00
|
|
|
private:
|
|
|
|
bool HasInvalidWorksharingNesting(
|
|
|
|
const parser::CharBlock &, const OmpDirectiveSet &);
|
2021-04-09 02:33:04 +08:00
|
|
|
bool IsCloselyNestedRegion(const OmpDirectiveSet &set);
|
2021-04-29 20:29:58 +08:00
|
|
|
void HasInvalidTeamsNesting(
|
|
|
|
const llvm::omp::Directive &dir, const parser::CharBlock &source);
|
|
|
|
void HasInvalidDistributeNesting(const parser::OpenMPLoopConstruct &x);
|
2019-07-02 04:55:06 +08:00
|
|
|
// specific clause related
|
|
|
|
bool ScheduleModifierHasType(const parser::OmpScheduleClause &,
|
|
|
|
const parser::OmpScheduleModifierType::ModType &);
|
2020-11-05 16:55:06 +08:00
|
|
|
void CheckAllowedMapTypes(const parser::OmpMapType::Type &,
|
|
|
|
const std::list<parser::OmpMapType::Type> &);
|
2020-08-06 02:20:26 +08:00
|
|
|
llvm::StringRef getClauseName(llvm::omp::Clause clause) override;
|
|
|
|
llvm::StringRef getDirectiveName(llvm::omp::Directive directive) override;
|
2020-11-17 01:56:04 +08:00
|
|
|
|
|
|
|
void CheckDependList(const parser::DataRef &);
|
|
|
|
void CheckDependArraySection(
|
|
|
|
const common::Indirection<parser::ArrayElement> &, const parser::Name &);
|
2021-05-27 15:56:16 +08:00
|
|
|
bool IsDataRefTypeParamInquiry(const parser::DataRef *dataRef);
|
2021-04-22 23:45:19 +08:00
|
|
|
void CheckIsVarPartOfAnotherVar(
|
|
|
|
const parser::CharBlock &source, const parser::OmpObjectList &objList);
|
2021-10-17 22:05:57 +08:00
|
|
|
void CheckThreadprivateOrDeclareTargetVar(
|
|
|
|
const parser::OmpObjectList &objList);
|
2020-12-01 00:35:35 +08:00
|
|
|
void CheckIntentInPointer(
|
|
|
|
const parser::OmpObjectList &, const llvm::omp::Clause);
|
2021-01-31 00:45:09 +08:00
|
|
|
void GetSymbolsInObjectList(const parser::OmpObjectList &, SymbolSourceMap &);
|
|
|
|
void CheckDefinableObjects(SymbolSourceMap &, const llvm::omp::Clause);
|
|
|
|
void CheckPrivateSymbolsInOuterCxt(
|
|
|
|
SymbolSourceMap &, DirectivesClauseTriple &, const llvm::omp::Clause);
|
2021-01-15 13:42:49 +08:00
|
|
|
const parser::Name GetLoopIndex(const parser::DoConstruct *x);
|
|
|
|
void SetLoopInfo(const parser::OpenMPLoopConstruct &x);
|
|
|
|
void CheckIsLoopIvPartOfClause(
|
|
|
|
llvmOmpClause clause, const parser::OmpObjectList &ompObjectList);
|
2021-08-13 22:20:38 +08:00
|
|
|
bool CheckTargetBlockOnlyTeams(const parser::Block &);
|
2021-01-19 20:58:44 +08:00
|
|
|
void CheckWorkshareBlockStmts(const parser::Block &, parser::CharBlock);
|
2021-02-15 20:54:27 +08:00
|
|
|
|
|
|
|
void CheckLoopItrVariableIsInt(const parser::OpenMPLoopConstruct &x);
|
|
|
|
void CheckDoWhile(const parser::OpenMPLoopConstruct &x);
|
|
|
|
void CheckCycleConstraints(const parser::OpenMPLoopConstruct &x);
|
2022-01-24 12:32:58 +08:00
|
|
|
template <typename T, typename D> bool IsOperatorValid(const T &, const D &);
|
|
|
|
void CheckAtomicMemoryOrderClause(
|
|
|
|
const parser::OmpAtomicClauseList &, const parser::OmpAtomicClauseList &);
|
|
|
|
void CheckAtomicMemoryOrderClause(const parser::OmpAtomicClauseList &);
|
|
|
|
void CheckAtomicUpdateAssignmentStmt(const parser::AssignmentStmt &);
|
|
|
|
void CheckAtomicConstructStructure(const parser::OpenMPAtomicConstruct &);
|
2021-06-05 05:17:49 +08:00
|
|
|
void CheckDistLinear(const parser::OpenMPLoopConstruct &x);
|
2021-05-07 02:00:34 +08:00
|
|
|
void CheckSIMDNest(const parser::OpenMPConstruct &x);
|
2021-08-18 09:40:52 +08:00
|
|
|
void CheckTargetNest(const parser::OpenMPConstruct &x);
|
2021-08-13 20:19:01 +08:00
|
|
|
void CheckCancellationNest(
|
|
|
|
const parser::CharBlock &source, const parser::OmpCancelType::Type &type);
|
2021-02-15 20:54:27 +08:00
|
|
|
std::int64_t GetOrdCollapseLevel(const parser::OpenMPLoopConstruct &x);
|
|
|
|
void CheckIfDoOrderedClause(const parser::OmpBlockDirective &blkDirectiv);
|
2021-03-13 01:22:21 +08:00
|
|
|
bool CheckReductionOperators(const parser::OmpClause::Reduction &);
|
|
|
|
bool CheckIntrinsicOperator(
|
|
|
|
const parser::DefinedOperator::IntrinsicOperator &);
|
|
|
|
void CheckReductionTypeList(const parser::OmpClause::Reduction &);
|
2021-05-14 02:56:07 +08:00
|
|
|
void CheckMasterNesting(const parser::OpenMPBlockConstruct &x);
|
2021-09-17 21:53:07 +08:00
|
|
|
void ChecksOnOrderedAsBlock();
|
2021-06-19 03:37:36 +08:00
|
|
|
void CheckBarrierNesting(const parser::OpenMPSimpleStandaloneConstruct &x);
|
2021-09-17 21:53:07 +08:00
|
|
|
void ChecksOnOrderedAsStandalone();
|
2021-03-13 01:22:21 +08:00
|
|
|
void CheckReductionArraySection(const parser::OmpObjectList &ompObjectList);
|
|
|
|
void CheckIntentInPointerAndDefinable(
|
|
|
|
const parser::OmpObjectList &, const llvm::omp::Clause);
|
|
|
|
void CheckArraySection(const parser::ArrayElement &arrayElement,
|
|
|
|
const parser::Name &name, const llvm::omp::Clause clause);
|
|
|
|
void CheckMultipleAppearanceAcrossContext(
|
|
|
|
const parser::OmpObjectList &ompObjectList);
|
2021-03-14 20:42:30 +08:00
|
|
|
const parser::OmpObjectList *GetOmpObjectList(const parser::OmpClause &);
|
2021-05-13 21:52:01 +08:00
|
|
|
void CheckPredefinedAllocatorRestriction(const parser::CharBlock &source,
|
|
|
|
const parser::OmpObjectList &ompObjectList);
|
|
|
|
void CheckPredefinedAllocatorRestriction(
|
|
|
|
const parser::CharBlock &source, const parser::Name &name);
|
|
|
|
bool isPredefinedAllocator{false};
|
2021-08-13 22:20:38 +08:00
|
|
|
void EnterDirectiveNest(const int index) { directiveNest_[index]++; }
|
|
|
|
void ExitDirectiveNest(const int index) { directiveNest_[index]--; }
|
|
|
|
int GetDirectiveNest(const int index) { return directiveNest_[index]; }
|
|
|
|
|
2021-08-18 09:40:52 +08:00
|
|
|
enum directiveNestType {
|
|
|
|
SIMDNest,
|
|
|
|
TargetBlockOnlyTeams,
|
|
|
|
TargetNest,
|
|
|
|
LastType
|
|
|
|
};
|
2021-08-13 22:20:38 +08:00
|
|
|
int directiveNest_[LastType + 1] = {0};
|
2019-06-26 07:18:51 +08:00
|
|
|
};
|
2020-03-29 12:00:16 +08:00
|
|
|
} // namespace Fortran::semantics
|
|
|
|
#endif // FORTRAN_SEMANTICS_CHECK_OMP_STRUCTURE_H_
|