[flang] [llvm] [flang][OpenMP]Add support for fail clause (PR #118683)

Mats Petersson via llvm-commits llvm-commits at lists.llvm.org
Mon Dec 9 03:46:55 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; }
----------------
Leporacanthicus wrote:

Ah, I see. As far as I can tell, there's nothing automatic (in OMP.td) that provides a help for the fail clause's memory order options. We'd have to write code for that somewhere. We already do a bunch of checking for memoryorder in the semantics of ATOMIC in general, and we also need to check that the fail clause doesn't appear outside of a COMPARE (at least I think that's how it's meant to work).

The alternative suggested would be a workable solution. In fact, I'm liking that more, mostly because it doesn't alter a generic class used everywhere. I'll implement that.

In both cases, we still need to know whether we're checking a memory order inside a fail clause or not - and I guess we would add an `else Say("Release memory order not allowed on FAIL clause")` in the not allowed cases (not exactly how it would be written, but conceptually).  

https://github.com/llvm/llvm-project/pull/118683


More information about the llvm-commits mailing list