[clang] [Clang][attr] Add 'cfi_salt' attribute (PR #141846)
Erich Keane via cfe-commits
cfe-commits at lists.llvm.org
Tue Aug 5 08:45:08 PDT 2025
================
@@ -7941,6 +7942,32 @@ static bool handleFunctionTypeAttr(TypeProcessingState &state, ParsedAttr &attr,
return true;
}
+ if (attr.getKind() == ParsedAttr::AT_CFISalt) {
+ if (attr.getNumArgs() == 0)
+ return true;
+
+ // Delay if this is not a function type.
+ StringRef Argument;
+ if (!S.checkStringLiteralArgumentAttr(attr, 0, Argument))
+ return false;
+
+ // Delay if this is not a function type.
+ if (!unwrapped.isFunctionType())
+ return false;
+
+ const auto *FnTy = unwrapped.get()->getAs<FunctionProtoType>();
+ if (!FnTy)
----------------
erichkeane wrote:
It DOES look like that, but he is perhaps correct that `handleFunctionTypeAttr` only works on prototype-functions? I just want to make sure that we either:
- diagnose (not silently ignore) here
- Are already diagnosing elsewhere and don't get here in this case, at which point this could be a `castAs`
- Diagnose elsewhere, BUT still get here: we should perhaps understand how that happens.
https://github.com/llvm/llvm-project/pull/141846
More information about the cfe-commits
mailing list