64#define DEBUG_TYPE "module-summary-analysis"
74 cl::desc(
"Force all edges in the function summary to cold"),
77 "all-non-critical",
"All non-critical edges."),
82 cl::desc(
"File to emit dot graph of new summary into"));
87 "Enable MemProf support for summarizing and cloning indirect calls"));
99 cl::desc(
"Max number of summary edges added from "
100 "indirect call profile metadata"));
125 bool &RefLocalLinkageIFunc) {
126 bool HasBlockAddress =
false;
128 if (Visited.
insert(CurUser).second)
131 while (!Worklist.
empty()) {
135 for (
const auto &OI : U->operands()) {
140 HasBlockAddress =
true;
147 if (!(CB && CB->isCallee(&OI))) {
153 GI && GI->hasLocalLinkage()) {
154 RefLocalLinkageIFunc =
true;
157 RefEdges.insert(Index.getOrInsertValueInfo(GV));
161 if (Visited.
insert(Operand).second)
174 for (
const auto &V : ValueDataArray)
175 RefEdges.insert(Index.getOrInsertValueInfo(
178 return HasBlockAddress;
189 if (!
F.hasMetadata(LLVMContext::MD_implicit_ref))
192 F.getMetadata(LLVMContext::MD_implicit_ref, MDs);
197 RefEdges.insert(Index.getOrInsertValueInfo(GV));
224 std::vector<FunctionSummary::ConstVCall>> &ConstVCalls) {
225 std::vector<uint64_t> Args;
229 if (!CI || CI->getBitWidth() > 64) {
233 Args.push_back(CI->getZExtValue());
235 ConstVCalls.insert({{
Guid,
Call.Offset}, std::move(Args)});
244 &TypeTestAssumeVCalls,
246 &TypeCheckedLoadVCalls,
248 std::vector<FunctionSummary::ConstVCall>>
249 &TypeTestAssumeConstVCalls,
251 std::vector<FunctionSummary::ConstVCall>>
252 &TypeCheckedLoadConstVCalls,
255 case Intrinsic::type_test:
256 case Intrinsic::public_type_test: {
269 return !isa<AssumeInst>(CIU.getUser());
271 if (HasNonAssumeUses)
272 TypeTests.insert(
Guid);
277 for (
auto &
Call : DevirtCalls)
279 TypeTestAssumeConstVCalls);
284 case Intrinsic::type_checked_load_relative:
285 case Intrinsic::type_checked_load: {
296 bool HasNonCallUses =
false;
298 HasNonCallUses, CI, DT);
302 TypeTests.insert(
Guid);
303 for (
auto &
Call : DevirtCalls)
305 TypeCheckedLoadConstVCalls);
316 return !LI->isVolatile();
323 return !
SI->isVolatile();
350 unsigned NumInsts = 0;
360 TypeTestAssumeVCalls, TypeCheckedLoadVCalls;
362 std::vector<FunctionSummary::ConstVCall>>
363 TypeTestAssumeConstVCalls, TypeCheckedLoadConstVCalls;
369 bool HasLocalIFuncCallOrRef =
false;
370 findRefEdges(Index, &
F, RefEdges, Visited, HasLocalIFuncCallOrRef);
373 std::vector<const Instruction *> NonVolatileLoads;
374 std::vector<const Instruction *> NonVolatileStores;
376 std::vector<CallsiteInfo> Callsites;
377 std::vector<AllocInfo> Allocs;
383 bool HasInlineAsmMaybeReferencingInternal =
false;
384 bool HasIndirBranchToBlockAddress =
false;
385 bool HasUnknownCall =
false;
386 bool MayThrow =
false;
392 if (BB.hasAddressTaken()) {
395 HasIndirBranchToBlockAddress =
true;
401 if (
I.isDebugOrPseudoInst())
413 NonVolatileLoads.push_back(&
I);
417 NonVolatileStores.push_back(&
I);
424 Value *Stored =
I.getOperand(0);
428 RefEdges.
insert(Index.getOrInsertValueInfo(GV));
430 findRefEdges(Index, U, RefEdges, Visited, HasLocalIFuncCallOrRef);
434 findRefEdges(Index, &
I, RefEdges, Visited, HasLocalIFuncCallOrRef);
448 if (HasLocalsInUsedOrAsm && CI && CI->isInlineAsm())
449 HasInlineAsmMaybeReferencingInternal =
true;
456 auto *CalledValue = CB->getCalledOperand();
457 auto *CalledFunction = CB->getCalledFunction();
458 if (CalledValue && !CalledFunction) {
459 CalledValue = CalledValue->stripPointerCasts();
466 assert(!CalledFunction &&
"Expected null called function in callsite for alias");
471 if (CalledFunction) {
472 if (CI && CalledFunction->isIntrinsic()) {
474 CI, TypeTests, TypeTestAssumeVCalls, TypeCheckedLoadVCalls,
475 TypeTestAssumeConstVCalls, TypeCheckedLoadConstVCalls, DT);
479 assert(CalledFunction->hasName());
481 auto Hotness = ScaledCount ?
getHotness(*ScaledCount, PSI)
490 auto &
ValueInfo = CallGraphEdges[Index.getOrInsertValueInfo(
493 if (CB->isTailCall())
496 HasUnknownCall =
true;
505 if (GI->hasLocalLinkage())
506 HasLocalIFuncCallOrRef =
true;
508 if (CI && CI->isInlineAsm())
518 if (
auto *MD =
I.getMetadata(LLVMContext::MD_callees)) {
519 for (
const auto &
Op : MD->operands()) {
522 CallGraphEdges[Index.getOrInsertValueInfo(Callee)];
526 CandidateProfileData =
529 for (
const auto &Candidate : CandidateProfileData)
530 CallGraphEdges[Index.getOrInsertValueInfo(Candidate.Value)]
531 .updateHotness(
getHotness(Candidate.Count, PSI));
547 CallsThatMayHaveMemprofSummary.
insert(CB);
553 I.getMetadata(LLVMContext::MD_callsite));
554 auto *MemProfMD =
I.getMetadata(LLVMContext::MD_memprof);
556 std::vector<MIBInfo> MIBs;
557 std::vector<std::vector<ContextTotalSize>> ContextSizeInfos;
558 bool HasNonZeroContextSizeInfos =
false;
559 for (
auto &MDOp : MemProfMD->operands()) {
566 for (
auto ContextIter =
568 ContextIter != StackContext.
end(); ++ContextIter) {
569 unsigned StackIdIdx = Index.addOrGetStackIdIndex(*ContextIter);
573 if (StackIdIndices.
empty() || StackIdIndices.
back() != StackIdIdx)
578 assert(MIBMD->getNumOperands() > 2 ||
580 if (MIBMD->getNumOperands() > 2) {
581 std::vector<ContextTotalSize> ContextSizes;
582 for (
unsigned I = 2;
I < MIBMD->getNumOperands();
I++) {
591 ContextSizes.push_back({FullStackId, TS});
595 HasNonZeroContextSizeInfos =
true;
596 ContextSizeInfos.push_back(std::move(ContextSizes));
605 ContextSizeInfos.push_back({{0, 0}});
610 Allocs.push_back(
AllocInfo(std::move(MIBs)));
611 assert(HasNonZeroContextSizeInfos ||
617 if (HasNonZeroContextSizeInfos) {
618 assert(Allocs.back().MIBs.size() == ContextSizeInfos.size());
619 Allocs.back().ContextSizeInfos = std::move(ContextSizeInfos);
621 }
else if (!InstCallsite.
empty()) {
623 for (
auto StackId : InstCallsite)
624 StackIdIndices.
push_back(Index.addOrGetStackIdIndex(StackId));
625 if (CalledFunction) {
630 auto CalleeValueInfo =
632 Callsites.push_back({CalleeValueInfo, StackIdIndices});
639 for (
const auto &Candidate : CandidateProfileData) {
640 auto CalleeValueInfo = Index.getOrInsertValueInfo(Candidate.Value);
641 Callsites.push_back({CalleeValueInfo, StackIdIndices});
649 Index.addBlockCount(
F.size());
654 [&](
const std::vector<const Instruction *> &Instrs,
657 for (
const auto *
I : Instrs) {
659 findRefEdges(Index,
I, Edges, Cache, HasLocalIFuncCallOrRef);
666 AddRefEdges(NonVolatileLoads, LoadRefEdges, Visited);
678 AddRefEdges(NonVolatileStores, StoreRefEdges, StoreCache);
683 for (
const auto &VI : StoreRefEdges)
684 if (LoadRefEdges.
remove(VI))
687 unsigned RefCnt = RefEdges.
size();
693 unsigned FirstWORef = RefEdges.
size();
697 for (; RefCnt < FirstWORef; ++RefCnt)
698 Refs[RefCnt].setReadOnly();
700 for (; RefCnt < Refs.
size(); ++RefCnt)
701 Refs[RefCnt].setWriteOnly();
707 for (
auto &
I :
F.getImportGUIDs())
708 CallGraphEdges[Index.getOrInsertValueInfo(
I)].updateHotness(
724 if (CallsThatMayHaveMemprofSummary.
count(CB))
733 bool NotEligibleForImport =
734 NonRenamableLocal || HasInlineAsmMaybeReferencingInternal ||
735 HasIndirBranchToBlockAddress || HasLocalIFuncCallOrRef;
737 F.getLinkage(),
F.getVisibility(), NotEligibleForImport,
738 false,
F.isDSOLocal(),
F.canBeOmittedFromSymbolTable(),
742 F.doesNotAccessMemory(),
F.onlyReadsMemory() && !
F.doesNotAccessMemory(),
743 F.hasFnAttribute(Attribute::NoRecurse),
F.returnDoesNotAlias(),
746 F.getAttributes().hasFnAttr(Attribute::NoInline),
747 F.hasFnAttribute(Attribute::AlwaysInline),
748 F.hasFnAttribute(Attribute::NoUnwind), MayThrow, HasUnknownCall,
750 std::vector<FunctionSummary::ParamAccess> ParamAccesses;
751 if (
auto *SSI = GetSSICallback(
F))
752 ParamAccesses = SSI->getParamAccesses(Index);
753 auto FuncSummary = std::make_unique<FunctionSummary>(
754 Flags, NumInsts, FunFlags, std::move(Refs), CallGraphEdges.
takeVector(),
757 TypeTestAssumeConstVCalls.takeVector(),
758 TypeCheckedLoadConstVCalls.takeVector(), std::move(ParamAccesses),
759 std::move(Callsites), std::move(Allocs));
760 if (NonRenamableLocal)
761 CantBePromoted.
insert(
F.getGUID());
762 Index.addGlobalValueSummary(
F, std::move(FuncSummary));
775 if (
I->getType()->isPointerTy()) {
776 auto C =
I->stripPointerCasts();
783 if (GV && GV->getName() !=
"__cxa_pure_virtual")
784 VTableFuncs.push_back({Index.getOrInsertValueInfo(GV), StartingOffset});
801 StartingOffset +
Offset, M, Index, VTableFuncs, OrigGV);
805 Type *EltTy = ATy->getElementType();
806 uint64_t EltSize =
DL.getTypeAllocSize(EltTy);
807 for (
unsigned i = 0, e = ATy->getNumElements(); i != e; ++i) {
809 StartingOffset + i * EltSize, M, Index, VTableFuncs,
814 if (CE->getOpcode() != Instruction::Trunc ||
821 if (CE->getOpcode() == Instruction::Sub) {
823 APSInt LHSOffset, RHSOffset;
854 for (
auto &
P : VTableFuncs) {
858 assert(
P.VTableOffset >= PrevOffset);
859 PrevOffset =
P.VTableOffset;
878 Index.getOrInsertTypeIdCompatibleVtableSummary(TypeId->getString())
879 .push_back({
Offset, Index.getOrInsertValueInfo(&V)});
890 bool RefLocalIFunc =
false;
891 bool HasBlockAddress =
892 findRefEdges(Index, &V, RefEdges, Visited, RefLocalIFunc);
893 const bool NotEligibleForImport = (HasBlockAddress || RefLocalIFunc);
896 V.getLinkage(), V.getVisibility(), NonRenamableLocal,
897 false, V.isDSOLocal(), V.canBeOmittedFromSymbolTable(),
903 if (!Index.enableSplitLTOUnit()) {
905 V.getMetadata(LLVMContext::MD_type, Types);
906 if (!Types.empty()) {
916 bool CanBeInternalized =
917 !V.hasComdat() && !V.hasAppendingLinkage() && !V.isInterposable() &&
918 !V.hasAvailableExternallyLinkage() && !V.hasDLLExportStorageClass();
921 Constant ?
false : CanBeInternalized,
923 auto GVarSummary = std::make_unique<GlobalVarSummary>(Flags, VarFlags,
925 if (NonRenamableLocal)
926 CantBePromoted.
insert(V.getGUID());
927 if (NotEligibleForImport)
928 GVarSummary->setNotEligibleToImport();
929 if (!VTableFuncs.empty())
930 GVarSummary->setVTableFuncs(VTableFuncs);
931 Index.addGlobalValueSummary(V, std::move(GVarSummary));
943 A.getLinkage(),
A.getVisibility(), NonRenamableLocal,
944 false,
A.isDSOLocal(),
A.canBeOmittedFromSymbolTable(),
946 auto AS = std::make_unique<AliasSummary>(Flags);
947 auto AliaseeVI = Index.getValueInfo(Aliasee->
getGUID());
948 assert(AliaseeVI &&
"Alias expects aliasee summary to be available");
949 assert(AliaseeVI.getSummaryList().size() == 1 &&
950 "Expected a single entry per aliasee in per-module index");
951 AS->setAliasee(AliaseeVI, AliaseeVI.getSummaryList()[0].get());
952 if (NonRenamableLocal)
953 CantBePromoted.
insert(
A.getGUID());
954 Index.addGlobalValueSummary(
A, std::move(AS));
961 for (
const auto &Summary : VI.getSummaryList())
962 Summary->setLive(
true);
971 bool EnableSplitLTOUnit =
false;
972 bool UnifiedLTO =
false;
974 M.getModuleFlag(
"EnableSplitLTOUnit")))
975 EnableSplitLTOUnit = MD->getZExtValue();
978 UnifiedLTO = MD->getZExtValue();
993 for (
auto *V : Used) {
994 if (V->hasLocalLinkage()) {
996 CantBePromoted.
insert(V->getGUID());
1000 bool HasLocalInlineAsmSymbol =
false;
1001 if (!M.getModuleInlineAsm().empty()) {
1017 HasLocalInlineAsmSymbol =
true;
1032 std::unique_ptr<FunctionSummary> Summary =
1033 std::make_unique<FunctionSummary>(
1036 F->hasFnAttribute(Attribute::ReadNone),
1037 F->hasFnAttribute(Attribute::ReadOnly),
1038 F->hasFnAttribute(Attribute::NoRecurse),
1039 F->returnDoesNotAlias(),
1041 F->hasFnAttribute(Attribute::AlwaysInline),
1042 F->hasFnAttribute(Attribute::NoUnwind),
1055 Index.addGlobalValueSummary(*GV, std::move(Summary));
1057 std::unique_ptr<GlobalVarSummary> Summary =
1058 std::make_unique<GlobalVarSummary>(
1064 Index.addGlobalValueSummary(*GV, std::move(Summary));
1069 bool IsThinLTO =
true;
1072 IsThinLTO = MD->getZExtValue();
1076 for (
const auto &
F : M) {
1077 if (
F.isDeclaration())
1082 std::unique_ptr<BlockFrequencyInfo> BFIPtr;
1084 BFI = GetBFICallback(
F);
1085 else if (
F.hasProfileData()) {
1088 BFIPtr = std::make_unique<BlockFrequencyInfo>(
F, BPI, LI);
1093 !LocalsUsed.
empty() || HasLocalInlineAsmSymbol,
1094 CantBePromoted, IsThinLTO, GetSSICallback);
1101 if (
G.isDeclaration())
1113 I.applyAlongResolverPath([&Index](
const GlobalValue &GV) {
1114 Index.getGlobalValueSummary(GV)->setLive(
true);
1118 for (
auto *V : LocalsUsed) {
1119 auto *Summary = Index.getGlobalValueSummary(*V);
1120 assert(Summary &&
"Missing summary for global value");
1121 Summary->setNotEligibleToImport();
1133 for (
auto &GlobalList : Index) {
1135 if (GlobalList.second.getSummaryList().empty())
1138 assert(GlobalList.second.getSummaryList().size() == 1 &&
1139 "Expected module's index to have one summary per GUID");
1140 auto &Summary = GlobalList.second.getSummaryList()[0];
1142 Summary->setNotEligibleToImport();
1146 bool AllRefsCanBeExternallyReferenced =
1148 return !CantBePromoted.count(VI.getGUID());
1150 if (!AllRefsCanBeExternallyReferenced) {
1151 Summary->setNotEligibleToImport();
1158 return !CantBePromoted.count(Edge.first.getGUID());
1160 if (!AllCallsCanBeExternallyReferenced)
1161 Summary->setNotEligibleToImport();
1171 Index.exportToDot(OSDot, {});
1201 "Module Summary Analysis",
false,
true)
1264 "Module summary info",
false,
true)
1269 if (CB->isDebugOrPseudoInst())
1272 auto *CalledValue = CB->getCalledOperand();
1273 auto *CalledFunction = CB->getCalledFunction();
1274 if (CalledValue && !CalledFunction) {
1275 CalledValue = CalledValue->stripPointerCasts();
1282 assert(!CalledFunction &&
1283 "Expected null called function in callsite for alias");
1288 if (CalledFunction) {
1289 if (CI && CalledFunction->isIntrinsic())
1296 if (CI && CI->isInlineAsm())
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static bool isConstant(const MachineInstr &MI)
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
This file contains the simple types necessary to represent the attributes associated with functions a...
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
#define clEnumValN(ENUMVAL, FLAGNAME, DESC)
This file contains the declarations for the subclasses of Constant, which represent the different fla...
This file defines the DenseSet and SmallDenseSet classes.
Module.h This file contains the declarations for the Module class.
This defines the Use class.
This file implements a map that provides insertion order iteration.
static void addVCallToSet(DevirtCallSite Call, GlobalValue::GUID Guid, SetVector< FunctionSummary::VFuncId, std::vector< FunctionSummary::VFuncId > > &VCalls, SetVector< FunctionSummary::ConstVCall, std::vector< FunctionSummary::ConstVCall > > &ConstVCalls)
Determine whether this call has all constant integer arguments (excluding "this") and summarize it to...
static void computeVTableFuncs(ModuleSummaryIndex &Index, const GlobalVariable &V, const Module &M, VTableFuncList &VTableFuncs)
static void computeAliasSummary(ModuleSummaryIndex &Index, const GlobalAlias &A, DenseSet< GlobalValue::GUID > &CantBePromoted)
static void findFuncPointers(const Constant *I, uint64_t StartingOffset, const Module &M, ModuleSummaryIndex &Index, VTableFuncList &VTableFuncs, const GlobalVariable &OrigGV)
Find function pointers referenced within the given vtable initializer (or subset of an initializer) I...
static void computeVariableSummary(ModuleSummaryIndex &Index, const GlobalVariable &V, DenseSet< GlobalValue::GUID > &CantBePromoted, const Module &M, SmallVectorImpl< MDNode * > &Types)
static void setLiveRoot(ModuleSummaryIndex &Index, StringRef Name)
static CalleeInfo::HotnessType getHotness(uint64_t ProfileCount, ProfileSummaryInfo *PSI)
static bool isNonVolatileLoad(const Instruction *I)
static void findImplicitRefEdges(ModuleSummaryIndex &Index, const Function &F, SetVector< ValueInfo, SmallVector< ValueInfo, 0 > > &RefEdges)
Collect globals referenced via !implicit.ref metadata on a function and add them as reference edges i...
static bool isNonRenamableLocal(const GlobalValue &GV)
static void computeFunctionSummary(ModuleSummaryIndex &Index, const Module &M, const Function &F, BlockFrequencyInfo *BFI, ProfileSummaryInfo *PSI, DominatorTree &DT, bool HasLocalsInUsedOrAsm, DenseSet< GlobalValue::GUID > &CantBePromoted, bool IsThinLTO, std::function< const StackSafetyInfo *(const Function &F)> GetSSICallback)
static bool mustBeUnreachableFunction(const Function &F)
static bool isNonVolatileStore(const Instruction *I)
static bool findRefEdges(ModuleSummaryIndex &Index, const User *CurUser, SetVector< ValueInfo, SmallVector< ValueInfo, 0 > > &RefEdges, SmallPtrSet< const User *, 8 > &Visited, bool &RefLocalLinkageIFunc)
static void addIntrinsicToSummary(const CallInst *CI, SetVector< GlobalValue::GUID, std::vector< GlobalValue::GUID > > &TypeTests, SetVector< FunctionSummary::VFuncId, std::vector< FunctionSummary::VFuncId > > &TypeTestAssumeVCalls, SetVector< FunctionSummary::VFuncId, std::vector< FunctionSummary::VFuncId > > &TypeCheckedLoadVCalls, SetVector< FunctionSummary::ConstVCall, std::vector< FunctionSummary::ConstVCall > > &TypeTestAssumeConstVCalls, SetVector< FunctionSummary::ConstVCall, std::vector< FunctionSummary::ConstVCall > > &TypeCheckedLoadConstVCalls, DominatorTree &DT)
If this intrinsic call requires that we add information to the function summary, do so via the non-co...
static void recordTypeIdCompatibleVtableReferences(ModuleSummaryIndex &Index, const GlobalVariable &V, SmallVectorImpl< MDNode * > &Types)
Record vtable definition V for each type metadata it references.
This is the interface to build a ModuleSummaryIndex for a module.
ModuleSummaryIndex.h This file contains the declarations the classes that hold the module index and s...
FunctionAnalysisManager FAM
#define INITIALIZE_PASS_DEPENDENCY(depName)
#define INITIALIZE_PASS_END(passName, arg, name, cfg, analysis)
#define INITIALIZE_PASS_BEGIN(passName, arg, name, cfg, analysis)
#define INITIALIZE_PASS(passName, arg, name, cfg, analysis)
This file implements a set that has insertion order iteration characteristics.
This file defines the SmallPtrSet class.
This file defines the SmallVector class.
An arbitrary precision integer that knows its signedness.
PassT::Result & getResult(IRUnitT &IR, ExtraArgTs... ExtraArgs)
Get the result of an analysis pass for a given IR unit.
Represent the analysis usage information of a pass.
AnalysisUsage & addRequired()
void setPreservesAll()
Set by analyses that do not transform their input at all.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
LLVM Basic Block Representation.
static LLVM_ABI BlockAddress * get(Function *F, BasicBlock *BB)
Return a BlockAddress for the specified function and basic block.
Analysis pass which computes BlockFrequencyInfo.
Legacy analysis pass which computes BlockFrequencyInfo.
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
Analysis providing branch probability information.
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
Function * getCalledFunction() const
Returns the function called, or null if this is an indirect function invocation or the function signa...
Value * getArgOperand(unsigned i) const
This class represents a function call, abstracting a target machine's calling convention.
This is an important base class in LLVM.
A parsed version of the target data layout string in and methods for querying it.
Implements a dense probed hash-table based set.
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
std::pair< ValueInfo, CalleeInfo > EdgeTy
<CalleeValueInfo, CalleeInfo> call edge pair.
ForceSummaryHotnessType
Types for -force-summary-edges-cold debugging option.
Intrinsic::ID getIntrinsicID() const LLVM_READONLY
getIntrinsicID - This method returns the ID number of the specified function, or Intrinsic::not_intri...
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
LLVM_ABI bool isDeclaration() const
Return true if the primary definition of this global value is outside of the current translation unit...
uint64_t GUID
Declare a type to represent a global unique identifier for a global value.
bool hasLocalLinkage() const
GUID getGUID() const
Return a 64-bit global unique ID constructed from global value name (i.e.
@ DefaultVisibility
The GV is visible.
LLVM_ABI bool canBeOmittedFromSymbolTable() const
True if GV can be left out of the object symbol table.
@ InternalLinkage
Rename collisions when linking (static functions).
const Constant * getInitializer() const
getInitializer - Return the initializer for this global variable.
Legacy wrapper pass to provide the ModuleSummaryIndex object.
ImmutableModuleSummaryIndexWrapperPass(const ModuleSummaryIndex *Index=nullptr)
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
ImmutablePass class - This class is used to provide information that does not need to be run.
const MDOperand & getOperand(unsigned I) const
unsigned getNumOperands() const
Return number of MDNode operands.
Tracking metadata reference owned by Metadata.
This class implements a map that also provides access to all stored values in a deterministic order.
VectorType takeVector()
Clear the MapVector and return the underlying vector.
ModulePass class - This class is used to implement unstructured interprocedural optimizations and ana...
LLVM_ABI Result run(Module &M, ModuleAnalysisManager &AM)
Legacy wrapper pass to provide the ModuleSummaryIndex object.
void getAnalysisUsage(AnalysisUsage &AU) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
bool doFinalization(Module &M) override
doFinalization - Virtual method overriden by subclasses to do any necessary clean up after all passes...
ModuleSummaryIndexWrapperPass()
bool runOnModule(Module &M) override
runOnModule - Virtual method overriden by subclasses to process the module being operated on.
Class to hold module path string table and global value map, and encapsulate methods for operating on...
static LLVM_ABI void CollectAsmSymbols(const Module &M, function_ref< void(StringRef, object::BasicSymbolRef::Flags)> AsmSymbol)
Parse inline ASM and collect the symbols that are defined or referenced in the current module.
A Module instance is used to store all the information related to an LLVM module.
Represent a mutable reference to an array (0 or more elements consecutively in memory),...
AnalysisType & getAnalysis() const
getAnalysis<AnalysisType>() - This function is used by subclasses to get to the analysis information ...
An analysis pass based on the new PM to deliver ProfileSummaryInfo.
An analysis pass based on legacy pass manager to deliver ProfileSummaryInfo.
Analysis providing profile information.
LLVM_ABI std::optional< uint64_t > getProfileCount(const CallBase &CallInst, BlockFrequencyInfo *BFI, bool AllowSynthetic=false) const
Returns the profile count for CallInst.
LLVM_ABI bool isColdCount(uint64_t C) const
Returns true if count C is considered cold.
LLVM_ABI bool hasPartialSampleProfile() const
Returns true if module M has partial-profile sample profile.
LLVM_ABI bool isHotCount(uint64_t C) const
Returns true if count C is considered hot.
A vector that has set insertion semantics.
bool remove(const value_type &X)
Remove an item from the set vector.
size_type size() const
Determine the number of elements in the SetVector.
void insert_range(Range &&R)
Vector takeVector()
Clear the SetVector and return the underlying vector.
bool insert(const value_type &X)
Insert a new element into the SetVector.
std::pair< iterator, bool > insert(PtrType Ptr)
Inserts Ptr if and only if there is no element in the container equal to Ptr.
SmallPtrSet - This class implements a set which is optimized for holding SmallSize or less elements.
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StackSafetyInfo wrapper for the new pass manager.
StackSafetyInfo wrapper for the legacy pass manager.
Interface to access stack safety analysis results for single function.
Represent a constant reference to a string, i.e.
Used to lazily calculate structure layout information for a target machine, based on the DataLayout s...
LLVM_ABI unsigned getElementContainingOffset(uint64_t FixedOffset) const
Given a valid byte offset into the structure, returns the structure index that contains it.
TypeSize getElementOffset(unsigned Idx) const
Class to represent struct types.
ArrayRef< Type * > elements() const
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
The instances of the Type class are immutable: once they are created, they are never changed.
A Use represents the edge between a Value definition and its users.
LLVM Value Representation.
Type * getType() const
All values are typed, get the type of this value.
iterator_range< use_iterator > uses()
std::pair< iterator, bool > insert(const ValueT &V)
size_type count(const_arg_type_t< ValueT > V) const
Return 1 if the specified key is in the set, 0 otherwise.
Helper class to iterate through stack ids in both metadata (memprof MIB and callsite) and the corresp...
CallStackIterator beginAfterSharedPrefix(const CallStack &Other)
CallStackIterator end() const
A raw_ostream that writes to a file descriptor.
@ C
The default llvm calling convention, compatible with C.
ValuesClass values(OptsTy... Options)
Helper to build a ValuesClass by forwarding a variable number of arguments as an initializer list to ...
initializer< Ty > init(const Ty &Val)
LocationClass< Ty > location(Ty &L)
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > extract_or_null(Y &&MD)
Extract a Value from Metadata, allowing null.
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > dyn_extract(Y &&MD)
Extract a Value from Metadata, if any.
LLVM_ABI bool metadataIncludesAllContextSizeInfo()
Whether the alloc memeprof metadata will include context size info for all MIBs.
LLVM_ABI AllocationType getMIBAllocType(const MDNode *MIB)
Returns the allocation type from an MIB metadata node.
LLVM_ABI MDNode * getMIBStackNode(const MDNode *MIB)
Returns the stack node from an MIB metadata node.
@ OF_Text
The file should be opened in text mode on platforms like z/OS that make this distinction.
This is an optimization pass for GlobalISel generic memory operations.
auto drop_begin(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the first N elements excluded.
cl::opt< bool > MemProfReportHintedSizes("memprof-report-hinted-sizes", cl::init(false), cl::Hidden, cl::desc("Report total allocation sizes of hinted allocations"))
std::vector< VirtFuncOffset > VTableFuncList
List of functions referenced by a particular vtable definition.
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
auto enumerate(FirstRange &&First, RestRanges &&...Rest)
Given two or more input ranges, returns a new range whose values are tuples (A, B,...
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI bool mayHaveMemprofSummary(const CallBase *CB)
Returns true if the instruction could have memprof metadata, used to ensure consistency between summa...
LLVM_ABI bool IsConstantOffsetFromGlobal(Constant *C, GlobalValue *&GV, APInt &Offset, const DataLayout &DL, DSOLocalEquivalent **DSOEquiv=nullptr)
If this constant is a constant offset from a global, return the global and the constant.
auto dyn_cast_if_present(const Y &Val)
dyn_cast_if_present<X> - Functionally identical to dyn_cast, except that a null (or none in the case ...
FunctionSummary::ForceSummaryHotnessType ForceSummaryEdgesCold
LLVM_ABI bool needsParamAccessSummary(const Module &M)
static cl::opt< std::string > ModuleSummaryDotFile("module-summary-dot-file", cl::Hidden, cl::value_desc("filename"), cl::desc("File to emit dot graph of new summary into"))
InnerAnalysisManagerProxy< FunctionAnalysisManager, Module > FunctionAnalysisManagerModuleProxy
Provide the FunctionAnalysisManager to Module proxy.
LLVM_ABI ModuleSummaryIndex buildModuleSummaryIndex(const Module &M, std::function< BlockFrequencyInfo *(const Function &F)> GetBFICallback, ProfileSummaryInfo *PSI, std::function< const StackSafetyInfo *(const Function &F)> GetSSICallback=[](const Function &F) -> const StackSafetyInfo *{ return nullptr;})
Direct function to compute a ModuleSummaryIndex from a given module.
cl::opt< unsigned > MaxNumVTableAnnotations("icp-max-num-vtables", cl::init(6), cl::Hidden, cl::desc("Max number of vtables annotated for a vtable load instruction."))
LLVM_ABI cl::opt< bool > ScalePartialSampleProfileWorkingSetSize
auto dyn_cast_or_null(const Y &Val)
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
cl::opt< unsigned > MaxSummaryIndirectEdges("module-summary-max-indirect-edges", cl::init(0), cl::Hidden, cl::desc("Max number of summary edges added from " "indirect call profile metadata"))
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
LLVM_ABI void findDevirtualizableCallsForTypeCheckedLoad(SmallVectorImpl< DevirtCallSite > &DevirtCalls, SmallVectorImpl< Instruction * > &LoadedPtrs, SmallVectorImpl< Instruction * > &Preds, bool &HasNonCallUses, const CallInst *CI, DominatorTree &DT)
Given a call to the intrinsic @llvm.type.checked.load, find all devirtualizable call sites based on t...
Function::ProfileCount ProfileCount
LLVM_ABI SmallVector< InstrProfValueData, 4 > getValueProfDataFromInst(const Instruction &Inst, InstrProfValueKind ValueKind, uint32_t MaxNumValueData, uint64_t &TotalC, bool GetNoICPValue=false)
Extract the value profile data from Inst and returns them if Inst is annotated with value profile dat...
LLVM_ABI ModulePass * createModuleSummaryIndexWrapperPass()
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
DWARFExpression::Operation Op
LLVM_ABI ImmutablePass * createImmutableModuleSummaryIndexWrapperPass(const ModuleSummaryIndex *Index)
static cl::opt< FunctionSummary::ForceSummaryHotnessType, true > FSEC("force-summary-edges-cold", cl::Hidden, cl::location(ForceSummaryEdgesCold), cl::desc("Force all edges in the function summary to cold"), cl::values(clEnumValN(FunctionSummary::FSHT_None, "none", "None."), clEnumValN(FunctionSummary::FSHT_AllNonCritical, "all-non-critical", "All non-critical edges."), clEnumValN(FunctionSummary::FSHT_All, "all", "All edges.")))
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
static cl::opt< bool > EnableMemProfIndirectCallSupport("enable-memprof-indirect-call-support", cl::init(true), cl::Hidden, cl::desc("Enable MemProf support for summarizing and cloning indirect calls"))
LLVM_ABI void findDevirtualizableCallsForTypeTest(SmallVectorImpl< DevirtCallSite > &DevirtCalls, SmallVectorImpl< CallInst * > &Assumes, const CallInst *CI, DominatorTree &DT)
Given a call to the intrinsic @llvm.type.test, find all devirtualizable call sites based on the call ...
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
LLVM_ABI GlobalVariable * collectUsedGlobalVariables(const Module &M, SmallVectorImpl< GlobalValue * > &Vec, bool CompilerUsed)
Given "llvm.used" or "llvm.compiler.used" as a global name, collect the initializer elements of that ...
Summary of memprof metadata on allocations.
A special type used by analysis passes to provide an address that identifies that particular analysis...
A call site that could be devirtualized.
A specification for a virtual function call with all constant integer arguments.
Flags specific to function summaries.
An "identifier" for a virtual function.
Group flags (Linkage, NotEligibleToImport, etc.) as a bitfield.
Summary of a single MIB in a memprof metadata on allocations.
Struct that holds a reference to a particular GUID in a global value summary.