ABataev added a comment.

In D71179#1774448 <https://reviews.llvm.org/D71179#1774448>, @jdoerfert wrote:

> 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`.


Ok, here we can check the context and just skip everything between begin/end 
pragmas just like if something like #ifdef...#endif is seen.

> 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.

I thought about this. Here we need to use a little bit different method, but 
again everything can be reolved at the codegen phase, no need to resolve it at 
parsing/sema. Plus, this is completely different problem and must be solved in 
the different patch.

> (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