================
@@ -3779,6 +3828,25 @@ LValue CodeGenFunction::EmitDeclRefLValue(const
DeclRefExpr *E) {
// an enclosing scope.
if (const auto *BD = dyn_cast<BindingDecl>(ND)) {
if (E->refersToEnclosingVariableOrCapture()) {
+ // Try direct lookup first.
+ auto It = LocalDeclMap.find(BD->getCanonicalDecl());
+ if (It != LocalDeclMap.end()) {
+ return MakeAddrLValue(It->second, E->getType(), AlignmentSource::Decl);
+ }
+ // OpenMP case: binding was captured via its decomposed decl.
+ if (CapturedStmtInfo &&
+ CapturedStmtInfo->getKind() == CapturedRegionKind::CR_OpenMP &&
+ CGM.getLangOpts().OpenMP) {
+ auto NameIt = OMPPrivatizedBindingsByName.find(BD->getName());
----------------
alexey-bataev wrote:
Probably, need to use the decl identity, otherwise might be a conflict if
several BindingDecls with the same name from different DecompositionDecls are
live in overlapping OpenMP privatization scopes
https://github.com/llvm/llvm-project/pull/190832
_______________________________________________
cfe-commits mailing list
[email protected]
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits