[PATCH] D93051: [Flang][openmp] Add semantic checks for OpenMP critical construct.

sameeran joshi via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Dec 10 09:35:43 PST 2020


sameeranjoshi created this revision.
sameeranjoshi added reviewers: kiranchandramohan, clementval, kiranktp, tskeith, klausler.
Herald added subscribers: guansong, yaxunl.
sameeranjoshi requested review of this revision.
Herald added a reviewer: jdoerfert.
Herald added a subscriber: sstefan1.
Herald added a project: LLVM.

Name resolution was probably failing in bug reported at
https://bugs.llvm.org/show_bug.cgi?id=48145
as the omp critical construct needs a new symbol for the name which was
missing. This is fixed by creating a new symbol during name resolution
for a new flag `OmpCriticalLock`.

Upgrade to OMP-5.0 standard.

Checks for restrictions from OMP-5.0 are added.

- If a name is specified on a critical directive, the same name must also be specified on the

end critical directive.

- If no name appears on the critical directive, no name can appear on the end critical

directive.

- Unless the effect is as if hint(omp_sync_hint_none) was specified, the critical

construct must specify a name.

A new routine `CheckNameMatching` mostly follows `CheckEndName` from `resolve-labels.cpp`.


Repository:
  rG LLVM Github Monorepo

https://reviews.llvm.org/D93051

Files:
  flang/include/flang/Parser/parse-tree.h
  flang/lib/Parser/openmp-parsers.cpp
  flang/lib/Parser/unparse.cpp
  flang/lib/Semantics/check-directive-structure.h
  flang/lib/Semantics/check-omp-structure.cpp
  flang/lib/Semantics/check-omp-structure.h
  flang/lib/Semantics/resolve-directives.cpp
  flang/test/Semantics/omp-clause-validity01.f90
  flang/test/Semantics/omp-sync-critical01.f90
  flang/test/Semantics/omp-sync-critical02.f90

-------------- next part --------------
A non-text attachment was scrubbed...
Name: D93051.310940.patch
Type: text/x-patch
Size: 15792 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20201210/a0a895ae/attachment.bin>


More information about the llvm-commits mailing list