[clang] [clang] Implement function pointer type discrimination (PR #96992)

Eli Friedman via cfe-commits cfe-commits at lists.llvm.org
Fri Jun 28 11:34:27 PDT 2024


================
@@ -2220,6 +2220,11 @@ llvm::Constant *ConstantLValueEmitter::emitPointerAuthPointer(const Expr *E) {
 
   // The assertions here are all checked by Sema.
   assert(Result.Val.isLValue());
+  auto *Base = Result.Val.getLValueBase().get<const ValueDecl *>();
+  if (auto *Decl = dyn_cast_or_null<FunctionDecl>(Base)) {
+    assert(Result.Val.getLValueOffset().isZero());
+    return CGM.getRawFunctionPointer(Decl);
----------------
efriedma-quic wrote:

Why is this code not part of ConstantEmitter()?

https://github.com/llvm/llvm-project/pull/96992


More information about the cfe-commits mailing list