[llvm-branch-commits] [CallSiteInfo][CallGraphSection] Extract and propagate indirect call type ids (PR #87575)
Paul Kirth via llvm-branch-commits
llvm-branch-commits at lists.llvm.org
Tue Apr 30 19:37:09 PDT 2024
================
@@ -488,6 +490,38 @@ class LLVM_EXTERNAL_VISIBILITY MachineFunction {
/// Callee type id.
ConstantInt *TypeId = nullptr;
+
+ CallSiteInfo() {}
+
+ /// Extracts the numeric type id from the CallBase's type operand bundle,
+ /// and sets TypeId. This is used as type id for the indirect call in the
+ /// call graph section.
+ CallSiteInfo(const CallBase &CB) {
+ // Call graph section needs numeric type id only for indirect calls.
+ if (!CB.isIndirectCall())
+ return;
+
+ auto Opt = CB.getOperandBundle(LLVMContext::OB_type);
+ if (!Opt.has_value()) {
+ errs() << "warning: cannot find indirect call type operand bundle for "
+ "call graph section\n";
+ return;
----------------
ilovepi wrote:
If you really need a diagnostic in these cases, you'll need to use one of the diagnostic handlers. Even if it was wrapped in `LLVM_DEBUG`, the existing warning has no context, so it isn't actionable to the user (e.g. no ability to know which function or call site is the problem). https://github.com/llvm/llvm-project/blob/b1b1bfa7bea0ce489b5ea9134e17a43c695df5ec/llvm/include/llvm/IR/DiagnosticInfo.h#L1036 is an example diagnostic I've implemented in the past, but I'm not 100% sure those are appropriate at this point in the backend. I think its probably fine, but you can probably check some of the other files under `CodeGen` to find a related example. I'll take a look tomorrow to see if I can point you in the right direction.
All in all, though I'd suggest dropping for now. But if you really need it, then you'll need to create a diagnostic type and use the `diagnose` (or is it `Report`?) API from the context (or the closest diagnostic handler ... I'd have to doublecheck). I'd also guard the diagnostic by checking if the call graph section is enabled. I believe you have a codegen flag for it, so you should be able to guard whatever you're spitting out only in cases where the message makes sense.
https://github.com/llvm/llvm-project/pull/87575
More information about the llvm-branch-commits
mailing list