jdoerfert added a comment.

In D71179#1774444 <https://reviews.llvm.org/D71179#1774444>, @ABataev wrote:

> I read the spec and don't think that we need all this complex stuff for the 
> implementation. Yiu need judt to check at the codegen phase if the function 
> must be emitted or not. We don't even need to move context checksnfrom 
> codegen, because with the current semantics all the checkscan be safely 
> performed at the codegen phase.


For better or worse we need this and it is actually a natural reuse of the 
multi-versioning code. We need this because:

1. For the begin/end version we cannot even parse anything in a context that 
does not match at encounter time, e.g. the `kind(fpga)` context in 
`clang/test/AST/ast-dump-openmp-begin-declare-variant.c`.
2. For the 5.0 version we cannot use the `replaceAllUses` approach currently 
implemented in `tryEmitDeclareVariant` as soon as we have the construct context 
selector trait. That means we will have to resolve the call target earlier 
anyway.

(FWIW, I wrote this part of the SPEC.)


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D71179/new/

https://reviews.llvm.org/D71179



_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to