lebedev.ri added a comment. ping
================ Comment at: clang/lib/CodeGen/CGCall.cpp:5402-5411 + if (SanOpts.has(SanitizerKind::ExceptionEscape) && + ExceptionEscapeUBLastInvokeSrcLoc) { + llvm::Constant *CheckSourceLocation = EmitCheckSourceLocation(Loc); + Builder.CreateStore( + CheckSourceLocation, + Address(ExceptionEscapeUBLastInvokeSrcLoc, + CheckSourceLocation->getType(), ---------------- lebedev.ri wrote: > @rjmccall > So there are two issues: > 1. `getInvokeDest()` isn't necessarily called just before creating an > `invoke`, see e.g. `-EHa` handling in `CodeGenFunction::PopCleanupBlock()` > 2. Even if we ignore that, we need to do this for *every* `invoke`, not just > those going to the our UB landing pad, consider: > https://godbolt.org/z/qTeKor41a <- the invoke leads to a normal landing pad, > yet we immediately rethrow the just-caught exception, and now end up in the > UB landing pad. > > So i'm not really seeing an alternative path here? @rjmccall do you agree with my reasoning here? Perhaps there is some other solution that i'm not seeing, other than not having the source location? Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D137381/new/ https://reviews.llvm.org/D137381 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits