Revert "[clang][DebugInfo] Add virtuality call-site target informatio… (#182343)

…n in DWARF. (#167666)"

This reverts commit 418ba6e8ae2cde7924388142b8ab90c636d2c21f.

The commit caused an ICE due to hitting unreachable in
llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp:1307

Fixes #182337
This commit is contained in:
Paul Kirth 2026-02-19 12:19:11 -08:00 committed by GitHub
parent 0dafeb97a4
commit ec8b9ca47d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
24 changed files with 23 additions and 381 deletions

View File

@ -6322,8 +6322,6 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo,
DI->EmitFuncDeclForCallSite(
CI, DI->getFunctionType(CalleeDecl, ResTy, Args), CalleeGlobalDecl);
}
// Generate call site target information.
DI->addCallTargetIfVirtual(CalleeDecl, CI);
}
return Ret;

View File

@ -4978,23 +4978,6 @@ void CGDebugInfo::EmitFunctionDecl(GlobalDecl GD, SourceLocation Loc,
Fn->setSubprogram(SP);
}
void CGDebugInfo::addCallTargetIfVirtual(const FunctionDecl *FD,
llvm::CallBase *CI) {
if (!shouldGenerateVirtualCallSite())
return;
if (!FD)
return;
assert(CI && "Invalid Call Instruction.");
if (!CI->isIndirectCall())
return;
// Always get the method declaration.
if (llvm::DISubprogram *MD = getFunctionDeclaration(FD))
CI->setMetadata(llvm::LLVMContext::MD_call_target, MD);
}
void CGDebugInfo::EmitFuncDeclForCallSite(llvm::CallBase *CallOrInvoke,
QualType CalleeType,
GlobalDecl CalleeGlobalDecl) {

View File

@ -682,9 +682,6 @@ public:
/// that it is supported and enabled.
llvm::DINode::DIFlags getCallSiteRelatedAttrs() const;
/// Add call target information.
void addCallTargetIfVirtual(const FunctionDecl *FD, llvm::CallBase *CI);
private:
/// Amend \p I's DebugLoc with \p Group (its source atom group) and \p
/// Rank (lower nonzero rank is higher precedence). Does nothing if \p I
@ -909,12 +906,6 @@ private:
/// If one exists, returns the linkage name of the specified \
/// (non-null) \c Method. Returns empty string otherwise.
llvm::StringRef GetMethodLinkageName(const CXXMethodDecl *Method) const;
/// Returns true if we should generate call target information.
bool shouldGenerateVirtualCallSite() const {
// Check general conditions for call site generation.
return (getCallSiteRelatedAttrs() != llvm::DINode::FlagZero);
}
};
/// A scoped helper to set the current debug location to the specified

View File

@ -1,48 +0,0 @@
// RUN: %clang_cc1 -triple=x86_64-linux -disable-llvm-passes -emit-llvm \
// RUN: -debug-info-kind=standalone -dwarf-version=5 -O1 %s \
// RUN: -o - | FileCheck %s -check-prefix CHECK-BASE
// Simple class with only virtual methods: inlined and not-inlined
//
// The following three scenarios are considered:
// - out-of-line defined virtual member function (f1)
// - declared-but-not-defined virtual member function (f2)
// - inline defined virtual member function (f3)
//
// 1) We check for a generated 'call_target' for: 'f1', 'f2' and 'f3'.
// 2) Check that the 'CBase' type is defined.
struct CBase {
virtual void f1();
virtual void f2();
virtual void f3() {}
};
void CBase::f1() {}
void bar(CBase *Base) {
Base->f1();
Base->f2();
Base->f3();
// Because this will instantiate the ctor, the CBase type should be defined.
CBase B;
B.f1();
}
// CHECK-BASE: %struct.CBase = type { ptr }
// CHECK-BASE: define {{.*}} @_Z3barP5CBase{{.*}} {
// CHECK-BASE: alloca %struct.CBase
// CHECK-BASE: call void %1{{.*}} !dbg {{![0-9]+}}, !call_target [[BASE_F1_DCL:![0-9]+]]
// CHECK-BASE: call void %3{{.*}} !dbg {{![0-9]+}}, !call_target [[BASE_F2_DCL:![0-9]+]]
// CHECK-BASE: call void %5{{.*}} !dbg {{![0-9]+}}, !call_target [[BASE_F3_DCL:![0-9]+]]
// CHECK-BASE: call void @_ZN5CBaseC1Ev{{.*}} !dbg {{![0-9]+}}
// CHECK-BASE: call void @_ZN5CBase2f1Ev{{.*}} !dbg {{![0-9]+}}
// CHECK-BASE: }
// CHECK-BASE: [[BASE_F1_DCL]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN5CBase2f1Ev", {{.*}}containingType
// CHECK-BASE: [[BASE_F2_DCL]] = {{.*}}!DISubprogram(name: "f2", linkageName: "_ZN5CBase2f2Ev", {{.*}}containingType
// CHECK-BASE: [[BASE_F3_DCL]] = {{.*}}!DISubprogram(name: "f3", linkageName: "_ZN5CBase2f3Ev", {{.*}}containingType
// CHECK-BASE: [[BASE_F1_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN5CBase2f1Ev", {{.*}}DISPFlagDefinition
// CHECK-BASE: [[BASE_F3_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "f3", linkageName: "_ZN5CBase2f3Ev", {{.*}}DISPFlagDefinition

View File

@ -1,58 +0,0 @@
// RUN: %clang_cc1 -triple=x86_64-linux -disable-llvm-passes -emit-llvm \
// RUN: -debug-info-kind=constructor -dwarf-version=5 -O1 %s \
// RUN: -o - | FileCheck %s -check-prefix CHECK-DERIVED
// Simple base and derived class with virtual and static methods:
// We check for:
// - a generated 'call_target' for 'f1'.
// - not generated 'call_target' for 'f3'.
struct CBase {
virtual void f1() {}
static void f3();
};
void CBase::f3() {
}
void foo(CBase *Base) {
CBase::f3();
}
struct CDerived : public CBase {
void f1() {}
};
void foo(CDerived *Derived);
int main() {
CDerived D;
foo(&D);
return 0;
}
void foo(CDerived *Derived) {
Derived->f1();
}
// CHECK-DERIVED: define {{.*}} @_Z3fooP5CBase{{.*}} {
// CHECK-DERIVED: call void @_ZN5CBase2f3Ev{{.*}} !dbg {{![0-9]+}}
// CHECK-DERIVED: }
// CHECK-DERIVED: define {{.*}} @main{{.*}} {
// CHECK-DERIVED: call void @_ZN8CDerivedC1Ev{{.*}} !dbg {{![0-9]+}}
// CHECK-DERIVED: call void @_Z3fooP8CDerived{{.*}} !dbg {{![0-9]+}}
// CHECK-DERIVED: }
// CHECK-DERIVED: define {{.*}} @_ZN8CDerivedC1Ev{{.*}} {
// CHECK-DERIVED: call void @_ZN8CDerivedC2Ev{{.*}} !dbg {{![0-9]+}}
// CHECK-DERIVED: }
// CHECK-DERIVED: define {{.*}} @_Z3fooP8CDerived{{.*}} {
// CHECK-DERIVED: call void %1{{.*}} !dbg {{![0-9]+}}, !call_target [[DERIVED_F1_DCL:![0-9]+]]
// CHECK-DERIVED: }
// CHECK-DERIVED: [[BASE_F1_DCL:![0-9]+]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN5CBase2f1Ev", {{.*}}containingType
// CHECK-DERIVED: [[DERIVED_F1_DCL]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN8CDerived2f1Ev", {{.*}}containingType
// CHECK-DERIVED: [[DERIVED_F1_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN8CDerived2f1Ev", {{.*}}DISPFlagDefinition
// CHECK-DERIVED: [[BASE_F1_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN5CBase2f1Ev", {{.*}}DISPFlagDefinition

View File

@ -1,93 +0,0 @@
// RUN: %clang_cc1 -triple=x86_64-linux -disable-llvm-passes -emit-llvm \
// RUN: -debug-info-kind=constructor -dwarf-version=5 -O1 %s \
// RUN: -o - | FileCheck %s -check-prefix CHECK-EDGES
// The following are identified edge cases involving the method being called:
// 1) Method is declared but not defined in current CU.
// 2) Pure virtual method but not defined in current CU.
// 3) Virtual method defined in a deeply nested structure hierarchy.
//---------------------------------------------------------------------
// 1) Method is declared but not defined in current CU - Pass.
// Generate 'call_target' metadata for 'f1' and 'f2'.
//---------------------------------------------------------------------
struct CEmpty {
virtual void f1();
virtual void f2();
};
void CEmpty::f2() {
}
void edge_a(CEmpty *Empty) {
Empty->f1();
Empty->f2();
}
//---------------------------------------------------------------------
// 2) Pure virtual method but not defined in current CU - Pass.
// Generate 'call_target' metadata for 'f1' and 'f2'.
//---------------------------------------------------------------------
struct CBase {
virtual void f1() = 0;
virtual void f2();
};
void CBase::f2() {
}
void edge_b(CBase *Base) {
Base->f1();
Base->f2();
}
//---------------------------------------------------------------------
// 3) Virtual method defined in a deeply nested structure hierarchy - Pass.
// Generate 'call_target' metadata for 'd0', 'd1', 'd2' and 'd3'.
//---------------------------------------------------------------------
struct CD0 {
struct CD1 {
virtual void d1();
};
CD1 D1;
virtual void d0();
};
void CD0::d0() {}
void CD0::CD1::d1() {}
void edge_c(CD0 *D0) {
D0->d0();
CD0::CD1 *D1 = &D0->D1;
D1->d1();
}
// CHECK-EDGES: define {{.*}} @_Z6edge_aP6CEmpty{{.*}} {
// CHECK-EDGES: call void %1{{.*}} !dbg {{![0-9]+}}, !call_target [[CEMPTY_F1_DCL:![0-9]+]]
// CHECK-EDGES: call void %3{{.*}} !dbg {{![0-9]+}}, !call_target [[CEMPTY_F2_DCL:![0-9]+]]
// CHECK-EDGES: }
// CHECK-EDGES: define {{.*}} @_Z6edge_bP5CBase{{.*}} {
// CHECK-EDGES: call void %1{{.*}} !dbg {{![0-9]+}}, !call_target [[CBASE_F1_DCL:![0-9]+]]
// CHECK-EDGES: call void %3{{.*}} !dbg {{![0-9]+}}, !call_target [[CBASE_F2_DCL:![0-9]+]]
// CHECK-EDGES: }
// CHECK-EDGES: define {{.*}} @_Z6edge_cP3CD0{{.*}} {
// CHECK-EDGES: call void %1{{.*}} !dbg {{![0-9]+}}, !call_target [[CD0_D0_DCL:![0-9]+]]
// CHECK-EDGES: call void %4{{.*}} !dbg {{![0-9]+}}, !call_target [[CD0_D1_DCL:![0-9]+]]
// CHECK-EDGES: }
// CHECK-EDGES: [[CD0_D1_DCL]] = {{.*}}!DISubprogram(name: "d1", linkageName: "_ZN3CD03CD12d1Ev", {{.*}}containingType
// CHECK-EDGES: [[CD0_D0_DCL]] = {{.*}}!DISubprogram(name: "d0", linkageName: "_ZN3CD02d0Ev", {{.*}}containingType
// CHECK-EDGES: [[CBASE_F1_DCL]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN5CBase2f1Ev", {{.*}}containingType
// CHECK-EDGES: [[CBASE_F2_DCL]] = {{.*}}!DISubprogram(name: "f2", linkageName: "_ZN5CBase2f2Ev", {{.*}}containingType
// CHECK-EDGES: [[CEMPTY_F2_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "f2", linkageName: "_ZN6CEmpty2f2Ev", {{.*}}DISPFlagDefinition
// CHECK-EDGES: [[CEMPTY_F2_DCL]] = {{.*}}!DISubprogram(name: "f2", linkageName: "_ZN6CEmpty2f2Ev", {{.*}}containingType
// CHECK-EDGES: [[CEMPTY_F1_DCL]] = {{.*}}!DISubprogram(name: "f1", linkageName: "_ZN6CEmpty2f1Ev", {{.*}}containingType
// CHECK-EDGES: [[CBASE_F2_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "f2", linkageName: "_ZN5CBase2f2Ev", {{.*}}DISPFlagDefinition
// CHECK-EDGES: [[CD0_D0_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "d0", linkageName: "_ZN3CD02d0Ev", {{.*}}DISPFlagDefinition
// CHECK-EDGES: [[CD0_D1_DEF:![0-9]+]] = {{.*}}!DISubprogram(name: "d1", linkageName: "_ZN3CD03CD12d1Ev", {{.*}}DISPFlagDefinition

View File

@ -1,72 +0,0 @@
// REQUIRES: x86-registered-target
// RUN: %clang --target=x86_64-linux -c -g -O1 %s -o - | \
// RUN: llvm-dwarfdump --debug-info - | FileCheck %s --check-prefix=CHECK
// Simple base and derived class with virtual:
// We check for a generated 'DW_AT_LLVM_virtual_call_origin' for 'foo', that
// corresponds to the 'call_target' metadata added to the indirect call
// instruction.
// Note: We should add a test case inside LLDB that make use of the
// virtuality call-site target information in DWARF.
struct CBaseOne {
virtual void foo(int &);
};
struct CDerivedOne : CBaseOne {
void foo(int &);
};
void CDerivedOne::foo(int &) {}
struct CBaseTwo {
CDerivedOne *DerivedOne;
};
struct CDerivedTwo : CBaseTwo {
void bar(int &);
};
void CDerivedTwo::bar(int &j) { DerivedOne->foo(j); }
// The IR generated looks like:
//
// define dso_local void @_ZN11CDerivedTwo3barERi(...) !dbg !40 {
// entry:
// ..
// %vtable = load ptr, ptr %0, align 8
// %vfn = getelementptr inbounds ptr, ptr %vtable, i64 0
// %2 = load ptr, ptr %vfn, align 8
// call void %2(...), !dbg !65, !call_target !25
// ret void
// }
//
// !25 = !DISubprogram(name: "foo", linkageName: "_ZN11CDerivedOne3fooERi", ...)
// !40 = !DISubprogram(name: "bar", linkageName: "_ZN11CDerivedTwo3barERi", ...)
// !65 = !DILocation(line: 25, column: 15, scope: !40)
// CHECK: DW_TAG_compile_unit
// CHECK: DW_TAG_structure_type
// CHECK: DW_AT_name ("CDerivedOne")
// CHECK: [[FOO_DCL:0x[a-f0-9]+]]: DW_TAG_subprogram
// CHECK: DW_AT_name ("foo")
// CHECK: DW_TAG_structure_type
// CHECK: DW_AT_name ("CBaseOne")
// CHECK: [[FOO_DEF:0x[a-f0-9]+]]: DW_TAG_subprogram
// CHECK: DW_AT_call_all_calls (true)
// CHECK: DW_AT_specification ([[FOO_DCL]] "{{.*}}foo{{.*}}")
// CHECK: DW_TAG_structure_type
// CHECK: DW_AT_name ("CDerivedTwo")
// CHECK: DW_TAG_subprogram
// CHECK: DW_AT_name ("bar")
// CHECK: DW_TAG_structure_type
// CHECK: DW_AT_name ("CBaseTwo")
// CHECK: DW_TAG_subprogram
// CHECK: DW_AT_call_all_calls (true)
// CHECK: DW_AT_specification (0x{{.*}} "{{.*}}bar{{.*}}")
// CHECK: DW_TAG_call_site
// CHECK: DW_AT_call_target_clobbered (DW_OP_reg0 RAX)
// CHECK: DW_AT_call_tail_call (true)
// CHECK: DW_AT_call_pc (0x{{.*}})
// CHECK: DW_AT_LLVM_virtual_call_origin ([[FOO_DCL]] "{{.*}}foo{{.*}}")

View File

@ -647,7 +647,6 @@ HANDLE_DW_AT(0x3e10, LLVM_address_space, 0, LLVM)
HANDLE_DW_AT(0x3e11, LLVM_lanes, 0, LLVM)
HANDLE_DW_AT(0x3e12, LLVM_lane_pc, 0, LLVM)
HANDLE_DW_AT(0x3e13, LLVM_vector_size, 0, LLVM)
HANDLE_DW_AT(0x3e14, LLVM_virtual_call_origin, 0, LLVM)
// https://llvm.org/docs/AMDGPUUsage.html#address-space-identifier
HANDLE_DW_ASPACE(0x0, none)

View File

@ -526,17 +526,11 @@ public:
/// Callee type ids.
SmallVector<ConstantInt *, 4> CalleeTypeIds;
/// 'call_target' metadata for the DISubprogram. It is the declaration
/// or definition of the target function and might be indirect.
MDNode *CallTarget = nullptr;
CallSiteInfo() = default;
/// Extracts the numeric type id from the CallBase's callee_type Metadata,
/// and sets CalleeTypeIds. This is used as type id for the indirect call in
/// the call graph section.
/// Extracts the MDNode from the CallBase's call_target Metadata to be used
/// during the construction of the debug info call site entries.
LLVM_ABI CallSiteInfo(const CallBase &CB);
};

View File

@ -5936,10 +5936,6 @@ public:
LoadSDNode *OriginalLoad,
SelectionDAG &DAG) const;
protected:
void setTypeIdForCallsiteInfo(const CallBase *CB, MachineFunction &MF,
MachineFunction::CallSiteInfo &CSInfo) const;
private:
SDValue foldSetCCWithAnd(EVT VT, SDValue N0, SDValue N1, ISD::CondCode Cond,
const SDLoc &DL, DAGCombinerInfo &DCI) const;

View File

@ -59,4 +59,3 @@ LLVM_FIXED_MD_KIND(MD_captures, "captures", 44)
LLVM_FIXED_MD_KIND(MD_alloc_token, "alloc_token", 45)
LLVM_FIXED_MD_KIND(MD_implicit_ref, "implicit.ref", 46)
LLVM_FIXED_MD_KIND(MD_nofpclass, "nofpclass", 47)
LLVM_FIXED_MD_KIND(MD_call_target, "call_target", 48)

View File

@ -1349,7 +1349,11 @@ DIE &DwarfCompileUnit::constructCallSiteEntryDIE(
} else if (CalleeSP) {
DIE *CalleeDIE = getOrCreateSubprogramDIE(CalleeSP, CalleeF);
assert(CalleeDIE && "Could not create DIE for call site entry origin");
addLinkageNamesToDeclarations(*DD, *CalleeSP, *CalleeDIE);
if (AddLinkageNamesToDeclCallOriginsForTuning(DD) &&
!CalleeSP->isDefinition() &&
!CalleeDIE->findAttribute(dwarf::DW_AT_linkage_name)) {
addLinkageName(*CalleeDIE, CalleeSP->getLinkageName());
}
addDIEEntry(CallSiteDIE, getDwarf5OrGNUAttr(dwarf::DW_AT_call_origin),
*CalleeDIE);
@ -1887,12 +1891,3 @@ DIE *DwarfCompileUnit::getOrCreateSubprogramDIE(const DISubprogram *SP,
return DwarfUnit::getOrCreateSubprogramDIE(SP, F, Minimal);
}
void DwarfCompileUnit::addLinkageNamesToDeclarations(
const DwarfDebug &DD, const DISubprogram &CalleeSP, DIE &CalleeDIE) {
if (AddLinkageNamesToDeclCallOriginsForTuning(&DD) &&
!CalleeSP.isDefinition() &&
!CalleeDIE.findAttribute(dwarf::DW_AT_linkage_name)) {
addLinkageName(CalleeDIE, CalleeSP.getLinkageName());
}
}

View File

@ -436,10 +436,6 @@ public:
void addBaseTypeRef(DIEValueList &Die, int64_t Idx);
MDNodeSetVector &getDeferredLocalDecls() { return DeferredLocalDecls; }
void addLinkageNamesToDeclarations(const DwarfDebug &DD,
const DISubprogram &CalleeSP,
DIE &CalleeDIE);
};
} // end namespace llvm

View File

@ -955,30 +955,6 @@ void DwarfDebug::constructCallSiteEntryDIEs(const DISubprogram &SP,
return true;
};
// Create call_target connections for indirect calls.
auto addCallSiteTargetForIndirectCalls = [&](const MachineInstr *MI,
DIE &CallSiteDIE) {
const MachineFunction *MF = MI->getMF();
const auto &CalleesMap = MF->getCallSitesInfo();
auto CSInfo = CalleesMap.find(MI);
// Get the information for the call instruction.
if (CSInfo == CalleesMap.end() || !CSInfo->second.CallTarget)
return;
MDNode *CallTarget = CSInfo->second.CallTarget;
// Add DW_AT_LLVM_virtual_call_origin with the 'call_target' metadata.
assert(!CallSiteDIE.findAttribute(dwarf::DW_AT_LLVM_virtual_call_origin) &&
"DW_AT_LLVM_virtual_call_origin already exists");
const DISubprogram *CalleeSP = dyn_cast<DISubprogram>(CallTarget);
DIE *CalleeDIE = CU.getOrCreateSubprogramDIE(CalleeSP, nullptr);
assert(CalleeDIE && "Could not create DIE for call site entry origin");
CU.addDIEEntry(CallSiteDIE,
CU.getDwarf5OrGNUAttr(dwarf::DW_AT_LLVM_virtual_call_origin),
*CalleeDIE);
// Add DW_AT_linkage_name to the method declaration if needed.
CU.addLinkageNamesToDeclarations(*this, *CalleeSP, *CalleeDIE);
};
// Emit call site entries for each call or tail call in the function.
for (const MachineBasicBlock &MBB : MF) {
for (const MachineInstr &MI : MBB.instrs()) {
@ -1076,9 +1052,6 @@ void DwarfDebug::constructCallSiteEntryDIEs(const DISubprogram &SP,
ScopeDIE, CalleeSP, CalleeDecl, IsTail, PCAddr, CallAddr, CallTarget,
Offset, AllocSiteTy);
if (CallTarget.getReg())
addCallSiteTargetForIndirectCalls(TopLevelCallMI, CallSiteDIE);
// Optionally emit call-site-param debug info.
if (emitDebugEntryValues()) {
ParamSet Params;
@ -1487,7 +1460,7 @@ void DwarfDebug::finalizeModuleInfo() {
TLOF.getDwarfMacinfoSection()->getBeginSymbol());
}
}
}
}
// Emit all frontend-produced Skeleton CUs, i.e., Clang modules.
for (auto *CUNode : MMI->getModule()->debug_compile_units())

View File

@ -541,7 +541,7 @@ static void convertCallSiteObjects(yaml::MachineFunction &YMF,
std::distance(CallI->getParent()->instr_begin(), CallI);
YmlCS.CallLocation = CallLocation;
auto [ArgRegPairs, CalleeTypeIds, _] = CallSiteInfo;
auto [ArgRegPairs, CalleeTypeIds] = CallSiteInfo;
// Construct call arguments and theirs forwarding register info.
for (auto ArgReg : ArgRegPairs) {
yaml::CallSiteInfo::ArgRegPair YmlArgReg;

View File

@ -700,9 +700,6 @@ bool MachineFunction::needsFrameMoves() const {
}
MachineFunction::CallSiteInfo::CallSiteInfo(const CallBase &CB) {
if (MDNode *Node = CB.getMetadata(llvm::LLVMContext::MD_call_target))
CallTarget = Node;
// Numeric callee_type ids are only for indirect calls.
if (!CB.isIndirectCall())
return;

View File

@ -12804,17 +12804,3 @@ SDValue TargetLowering::scalarizeExtractedVectorLoad(EVT ResultVT,
return Load;
}
// Set type id for call site info and metadata 'call_target'.
// We are filtering for:
// a) The call-graph-section use case that wants to know about indirect
// calls, or
// b) We want to annotate indirect calls.
void TargetLowering::setTypeIdForCallsiteInfo(
const CallBase *CB, MachineFunction &MF,
MachineFunction::CallSiteInfo &CSInfo) const {
if (CB && CB->isIndirectCall() &&
(MF.getTarget().Options.EmitCallGraphSection ||
MF.getTarget().Options.EmitCallSiteInfo))
CSInfo = MachineFunction::CallSiteInfo(*CB);
}

View File

@ -246,8 +246,7 @@ static void dumpAttribute(raw_ostream &OS, const DWARFDie &Die,
// having both the raw value and the pretty-printed value is
// interesting. These attributes are handled below.
if (Attr == DW_AT_specification || Attr == DW_AT_abstract_origin ||
Attr == DW_AT_call_origin || Attr == DW_AT_import ||
Attr == DW_AT_LLVM_virtual_call_origin) {
Attr == DW_AT_call_origin || Attr == DW_AT_import) {
if (const char *Name =
Die.getAttributeValueAsReferencedDie(FormValue).getName(
DINameKind::LinkageName))

View File

@ -9936,7 +9936,8 @@ AArch64TargetLowering::LowerCall(CallLoweringInfo &CLI,
RetCCInfo.AnalyzeCallResult(Ins, RetCC);
// Set type id for call site info.
setTypeIdForCallsiteInfo(CB, MF, CSInfo);
if (MF.getTarget().Options.EmitCallGraphSection && CB && CB->isIndirectCall())
CSInfo = MachineFunction::CallSiteInfo(*CB);
// Check callee args/returns for SVE registers and set calling convention
// accordingly.

View File

@ -2057,7 +2057,8 @@ ARMTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
GuardWithBTI = AFI->branchTargetEnforcement();
// Set type id for call site info.
setTypeIdForCallsiteInfo(CB, MF, CSInfo);
if (MF.getTarget().Options.EmitCallGraphSection && CB && CB->isIndirectCall())
CSInfo = MachineFunction::CallSiteInfo(*CB);
// Determine whether this is a non-secure function call.
if (CLI.CB && CLI.CB->getAttributes().hasFnAttr("cmse_nonsecure_call"))

View File

@ -3343,7 +3343,8 @@ MipsTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
// Call site info for function parameters tracking and call base type info.
MachineFunction::CallSiteInfo CSInfo;
// Set type id for call site info.
setTypeIdForCallsiteInfo(CB, MF, CSInfo);
if (MF.getTarget().Options.EmitCallGraphSection && CB && CB->isIndirectCall())
CSInfo = MachineFunction::CallSiteInfo(*CB);
// Check if it's really possible to do a tail call.
// For non-musttail calls, restrict to functions that won't require $gp

View File

@ -24528,7 +24528,8 @@ SDValue RISCVTargetLowering::LowerCall(CallLoweringInfo &CLI,
MachineFunction::CallSiteInfo CSInfo;
// Set type id for call site info.
setTypeIdForCallsiteInfo(CB, MF, CSInfo);
if (MF.getTarget().Options.EmitCallGraphSection && CB && CB->isIndirectCall())
CSInfo = MachineFunction::CallSiteInfo(*CB);
// Analyze the operands of the call, assigning locations to each operand.
SmallVector<CCValAssign, 16> ArgLocs;

View File

@ -2078,7 +2078,8 @@ X86TargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
report_fatal_error("X86 interrupts may not be called directly");
// Set type id for call site info.
setTypeIdForCallsiteInfo(CB, MF, CSInfo);
if (MF.getTarget().Options.EmitCallGraphSection && CB && CB->isIndirectCall())
CSInfo = MachineFunction::CallSiteInfo(*CB);
if (IsIndirectCall && !IsWin64 &&
M->getModuleFlag("import-call-optimization"))

View File

@ -32,13 +32,14 @@
;; Test printer and parser with -emit-call-site-info only.
;; Test printer.
;; Verify that fwdArgRegs and calleeTypeIds are set.
;; Verify that fwdArgRegs is set, calleeTypeIds is not set.
; RUN: llc -mtriple=x86_64 -emit-call-site-info %s -stop-after=finalize-isel -o %t2.mir
; RUN: cat %t2.mir | FileCheck %s --check-prefix=PRINTER_CSI
; PRINTER_CSI: name: main
; PRINTER_CSI: callSites:
; PRINTER_CSI-NEXT: - { bb: {{.*}}, offset: {{.*}}, fwdArgRegs:
; PRINTER_CSI-NEXT: { arg: 0, reg: {{.*}} }, calleeTypeIds:
; PRINTER_CSI-NEXT: { arg: 0, reg: {{.*}} }
; PRINTER_CSI-NOT: calleeTypeIds:
;; Test parser.
@ -48,7 +49,8 @@
; PARSER_CSI: name: main
; PARSER_CSI: callSites:
; PARSER_CSI-NEXT: - { bb: {{.*}}, offset: {{.*}}, fwdArgRegs:
; PARSER_CSI-NEXT: { arg: 0, reg: {{.*}} }, calleeTypeIds:
; PARSER_CSI-NEXT: { arg: 0, reg: {{.*}} }
; PARSER_CSI-NOT: calleeTypeIds:
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Test printer and parser with both -emit-call-site-info and --call-graph-section.