[flang] [llvm] [flang][OpenMP]Add support for fail clause (PR #118683)
Kiran Chandramohan via llvm-commits
llvm-commits at lists.llvm.org
Sat Dec 7 14:04:58 PST 2024
================
@@ -114,6 +114,11 @@ class SemanticsVisitor : public virtual BaseChecker, public virtual C... {
context_.set_location(std::nullopt);
}
+ // This is necessary to avoid "walking" into the Fail clause,
+ // which confuses the CheckAllowed into thinking there's another
+ // memoryorder, when it's actually the argument to the fail clause.
+ bool Pre(const parser::OmpFailClause &) { return false; }
----------------
kiranchandramohan wrote:
I was asking whether this solution will prevent the ability to perform the following semantic check from the OpenMP 5.2 standard.
-> `acq_rel` and `release` cannot be specified as arguments to the `fail` clause.
If you do not want to change the parse-tree representation, an alternative solution could be to remember whether we are visiting the FailClause and only call `CheckAllowedClause` for the MemoryOrder clauses if we are not inside the FailClause. Something like the following (only done for Release MemoryOrder clause).
```
+void OmpStructureChecker::Enter(const parser::OmpFailClause &) {
+ CheckAllowedClause(llvm::omp::Clause::OMPC_fail);
+ isFailClause = true;
+}
+
+void OmpStructureChecker::Leave(const parser::OmpFailClause &) {
+ isFailClause = false;
+}
+
+void OmpStructureChecker::Enter(const parser::OmpClause::Release &) {
+ if(!isFailClause) {
+ CheckAllowedClause(llvm::omp::Clause::OMPC_release);
+ }
+}
```
Note: The above code will also involve removing the CHECK_SIMPLE_CLAUSE entries for the Release MemoryOrder clause, adding isFailClause as a member of OmpStructureChecker, and adding the Enter and Leave signatures in OmpStructureChecker for the OmpFailClause.
https://github.com/llvm/llvm-project/pull/118683
More information about the llvm-commits
mailing list