15#ifndef LLVM_PROFILEDATA_INSTRPROF_H
16#define LLVM_PROFILEDATA_INSTRPROF_H
46#include <system_error>
54struct InstrProfRecord;
61#define INSTR_PROF_SECT_ENTRY(Kind, SectNameCommon, SectNameCoff, Prefix) Kind,
67 return std::numeric_limits<uint64_t>::max() - 2;
77 bool AddSegmentInfo =
true);
82 return INSTR_PROF_VALUE_PROF_FUNC_STR;
88 return INSTR_PROF_VALUE_PROF_MEMOP_FUNC_STR;
122 return "__llvm_coverage_mapping";
130 return "__llvm_coverage_names";
139 return "__llvm_profile_register_functions";
145 return "__llvm_profile_register_function";
151 return "__llvm_profile_register_names_function";
164 return INSTR_PROF_QUOTE(INSTR_PROF_PROFILE_RUNTIME_VAR);
170 return "__llvm_profile_runtime_user";
174 return INSTR_PROF_QUOTE(INSTR_PROF_PROFILE_COUNTER_BIAS_VAR);
178 return INSTR_PROF_QUOTE(INSTR_PROF_PROFILE_BITMAP_BIAS_VAR);
233 StringRef PGOFuncName);
241 StringRef FileName =
"<unknown>");
253 bool doCompression, std::string &Result);
261 std::string &Result,
bool doCompression =
true);
264 std::string &Result,
bool doCompression);
276#define VALUE_PROF_KIND(Enumerator, Value, Descr) Enumerator = Value,
284 const InstrProfRecord &InstrProfR,
292 ArrayRef<InstrProfValueData> VDs,
uint64_t Sum,
299SmallVector<InstrProfValueData, 4>
302 bool GetNoICPValue =
false);
311std::string
getPGOName(
const GlobalVariable &V,
bool InLTO =
false);
394 std::vector<BPFunctionNode> &Nodes,
395 bool RemoveOutlierUNs =
true);
405 : Err(Err), Msg(ErrStr.str()) {
409 std::string
message()
const override;
423 static std::pair<instrprof_error, std::string>
take(
Error E) {
425 std::string Msg =
"";
447namespace IndexedInstrProf {
476 std::vector<std::pair<uint64_t, StringRef>> MD5NameMap;
479 std::vector<std::pair<uint64_t, Function *>> MD5FuncMap;
495 static StringRef getExternalSymbol() {
return "** External Symbol **"; }
520 inline void finalizeSymtab();
567 template <
typename NameIterRange>
573 template <
typename FuncNameIterRange,
typename VTableNameIterRange>
574 Error create(
const FuncNameIterRange &FuncIterRange,
575 const VTableNameIterRange &VTableIterRange);
579 if (SymbolName.empty())
581 "symbol name is empty");
585 auto Ins = NameTab.
insert(SymbolName);
587 MD5NameMap.push_back(std::make_pair(
606 VTableNames.
insert(VTableName);
615 AddrToMD5Map.push_back(std::make_pair(
Addr, MD5Val));
622 VTableAddrMap.
insert(StartAddr, EndAddr, MD5Val);
647 return Symbol == InstrProfSymtab::getExternalSymbol();
670template <
typename NameIterRange>
672 for (
auto Name : IterRange)
680template <
typename FuncNameIterRange,
typename VTableNameIterRange>
682 const VTableNameIterRange &VTableIterRange) {
690 for (
StringRef VTableName : VTableIterRange)
698void InstrProfSymtab::finalizeSymtab() {
704 AddrToMD5Map.erase(
llvm::unique(AddrToMD5Map), AddrToMD5Map.end());
711 return InstrProfSymtab::getExternalSymbol();
718 [](
const std::pair<uint64_t, StringRef> &
LHS,
720 if (Result != MD5NameMap.end() && Result->first ==
MD5Hash)
721 return Result->second;
728 [](
const std::pair<uint64_t, Function *> &
LHS,
730 if (Result != MD5FuncMap.end() && Result->first == FuncMD5Hash)
731 return Result->second;
736 return MD5VTableMap.lookup(
MD5Hash);
787 if (Sum1 < 1.0f || Sum2 < 1.0f)
789 return std::min(Val1 / Sum1, Val2 / Sum2);
811 [](
const InstrProfValueData &L,
const InstrProfValueData &R) {
812 return L.Value < R.Value;
843 ValueData(
RHS.ValueData
844 ?
std::make_unique<ValueProfData>(*
RHS.ValueData)
850 if (!
RHS.ValueData) {
855 ValueData = std::make_unique<ValueProfData>(*
RHS.ValueData);
857 *ValueData = *
RHS.ValueData;
894 for (
uint32_t Kind = IPVK_First; Kind <= IPVK_Last; ++Kind)
895 for (
auto &SR : getValueSitesForKind(Kind))
945 using ValueProfData = std::array<std::vector<InstrProfValueSiteRecord>,
946 IPVK_Last - IPVK_First + 1>;
947 std::unique_ptr<ValueProfData> ValueData;
950 getValueSitesForKind(
uint32_t ValueKind) {
954 auto AR =
const_cast<const InstrProfRecord *
>(
this)->getValueSitesForKind(
959 ArrayRef<InstrProfValueSiteRecord>
960 getValueSitesForKind(
uint32_t ValueKind)
const {
963 assert(IPVK_First <= ValueKind && ValueKind <= IPVK_Last &&
964 "Unknown value kind!");
965 return (*ValueData)[ValueKind - IPVK_First];
968 std::vector<InstrProfValueSiteRecord> &
969 getOrCreateValueSitesForKind(
uint32_t ValueKind) {
971 ValueData = std::make_unique<ValueProfData>();
972 assert(IPVK_First <= ValueKind && ValueKind <= IPVK_Last &&
973 "Unknown value kind!");
974 return (*ValueData)[
ValueKind - IPVK_First];
979 InstrProfSymtab *SymTab);
1001 std::vector<uint64_t>
Counts)
1004 std::vector<uint64_t>
Counts,
1019 for (
uint32_t Kind = IPVK_First; Kind <= IPVK_Last; ++Kind)
1020 NumValueKinds += !(getValueSitesForKind(Kind).empty());
1021 return NumValueKinds;
1026 for (
const auto &SR : getValueSitesForKind(ValueKind))
1027 N += SR.ValueData.size();
1032 return getValueSitesForKind(ValueKind).size();
1037 return getValueSitesForKind(ValueKind)[Site].ValueData;
1043 getOrCreateValueSitesForKind(ValueKind).reserve(NumValueSites);
1047#define INSTR_PROF_VALUE_PROF_DATA
1052 ValueData, [](
const InstrProfValueData &L,
const InstrProfValueData &R) {
1053 return L.Count > R.Count;
1056 size_t max_s = INSTR_PROF_MAX_NUM_VAL_PER_SITE;
1061namespace IndexedInstrProf {
1150 size_t size()
const;
1196 void operator delete(
void *ptr) { ::operator
delete(ptr); }
1204 return reinterpret_cast<const uint64_t *
>(
this + 1);
1208 return reinterpret_cast<uint64_t *
>(
this + 1);
1212 return reinterpret_cast<const Entry *
>(
1239 return std::unique_ptr<Summary>(
new (::operator
new(TotalSize))
1245namespace RawInstrProf {
1265 return INSTR_PROF_RAW_MAGIC_64;
1269 return INSTR_PROF_RAW_MAGIC_32;
1278#define INSTR_PROF_DATA(Type, LLVMType, Name, Init) Type Name;
1283#define INSTR_PROF_VTABLE_DATA(Type, LLVMType, Name, Init) Type Name;
1292#define INSTR_PROF_RAW_HEADER(Type, Name, Init) const Type Name;
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
This file defines the DenseMap class.
This file implements a coalescing interval map for small objects.
Machine Check Debug Module
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
StringSet - A set-like wrapper for the StringMap.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Base class for user error types.
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
Tagged union holding either a T or a Error.
LinkageTypes
An enumeration for the kinds of linkage for global values.
void log(raw_ostream &OS) const override
Print an error message to an output stream.
static std::pair< instrprof_error, std::string > take(Error E)
Consume an Error and return the raw enum value contained within it, and the optional error message.
const std::string & getMessage() const
instrprof_error get() const
std::error_code convertToErrorCode() const override
Convert this error to a std::error_code.
std::string message() const override
Return the error message as a string.
InstrProfError(instrprof_error Err, const Twine &ErrStr=Twine())
A symbol table used for function [IR]PGO name look-up with keys (such as pointers,...
static bool isExternalSymbol(const StringRef &Symbol)
True if Symbol is the value used to represent external symbols.
uint64_t getFunctionHashFromAddress(uint64_t Address)
Return a function's hash, or 0, if the function isn't in this SymTab.
Error addSymbolName(StringRef SymbolName)
std::vector< std::pair< uint64_t, uint64_t > > AddrHashMap
GlobalVariable * getGlobalVariable(uint64_t MD5Hash)
Return the global variable corresponding to md5 hash.
uint64_t getVTableHashFromAddress(uint64_t Address)
Return a vtable's hash, or 0 if the vtable doesn't exist in this SymTab.
StringRef getFuncOrVarName(uint64_t ValMD5Hash)
Return name of functions or global variables from the name's md5 hash value.
InstrProfSymtab & operator=(InstrProfSymtab &&)=delete
void mapAddress(uint64_t Addr, uint64_t MD5Val)
Map a function address to its name's MD5 hash.
Error addVTableName(StringRef VTableName)
Adds VTableName as a known symbol, and inserts it to a map that tracks all vtable names.
void dumpNames(raw_ostream &OS) const
Dump the symbols in this table.
Function * getFunction(uint64_t FuncMD5Hash)
Return function from the name's md5 hash. Return nullptr if not found.
StringRef getNameData() const
Return the name section data.
Error create(object::SectionRef &Section)
Create InstrProfSymtab from an object file section which contains function PGO names.
Error addFuncName(StringRef FuncName)
The method name is kept since there are many callers.
void mapVTableAddress(uint64_t StartAddr, uint64_t EndAddr, uint64_t MD5Val)
Map the address range (i.e., [start_address, end_address)) of a variable to its names' MD5 hash.
Error initVTableNamesFromCompressedStrings(StringRef CompressedVTableNames)
Initialize 'this' with the set of vtable names encoded in CompressedVTableNames.
const StringSet & getVTableNames() const
StringRef getFuncName(uint64_t FuncNameAddress, size_t NameSize)
Return function's PGO name from the function name's symbol address in the object file.
InstrProfSymtab & operator=(const InstrProfSymtab &)=delete
InstrProfSymtab(InstrProfSymtab &&)=delete
InstrProfSymtab(const InstrProfSymtab &)=delete
StringRef getFuncOrVarNameIfDefined(uint64_t ValMD5Hash)
Just like getFuncOrVarName, except that it will return literal string 'External Symbol' if the functi...
void insert(KeyT a, KeyT b, ValT y)
insert - Add a mapping of [a;b] to y, coalesce with adjacent intervals.
typename Sizer::Allocator Allocator
A Module instance is used to store all the information related to an LLVM module.
MutableArrayRef - Represent a mutable reference to an array (0 or more elements consecutively in memo...
StringRef - Represent a constant reference to a string, i.e.
constexpr bool empty() const
empty - Check if the string is empty.
StringSet - A wrapper for StringMap that provides set-like functionality.
std::pair< typename Base::iterator, bool > insert(StringRef key)
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.
An efficient, type-erasing, non-owning reference to a callable.
This is a value type class that represents a single section in the list of sections in the object fil...
A raw_ostream that writes to a file descriptor.
This class implements an extremely fast bulk output stream that can only output to a stream.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
std::unique_ptr< Summary > allocSummary(uint32_t TotalSize)
uint64_t ComputeHash(StringRef K)
uint64_t getMagic< uint32_t >()
uint64_t getMagic< uint64_t >()
constexpr size_t NameSize
uint64_t MD5Hash(const FunctionId &Obj)
This is an optimization pass for GlobalISel generic memory operations.
void stable_sort(R &&Range)
StringRef getInstrProfNameVarPrefix()
Return the name prefix of variables containing instrumented function names.
std::string getPGOFuncName(const Function &F, bool InLTO=false, uint64_t Version=INSTR_PROF_INDEX_VERSION)
Please use getIRPGOFuncName for LLVM IR instrumentation.
StringRef getInstrProfRuntimeHookVarName()
Return the name of the hook variable defined in profile runtime library.
void createPGOFuncNameMetadata(Function &F, StringRef PGOFuncName)
Create the PGOFuncName meta data if PGOFuncName is different from function's raw name.
std::string getIRPGOFuncName(const Function &F, bool InLTO=false)
std::error_code make_error_code(BitcodeError E)
StringRef getPGOFuncNameMetadataName()
StringRef getCoverageMappingVarName()
Return the name of a covarage mapping variable (internal linkage) for each instrumented source module...
void handleAllErrors(Error E, HandlerTs &&... Handlers)
Behaves the same as handleErrors, except that by contract all errors must be handled by the given han...
StringRef getInstrProfBitmapVarPrefix()
Return the name prefix of profile bitmap variables.
cl::opt< bool > DoInstrProfNameCompression
StringRef getFuncNameWithoutPrefix(StringRef PGOFuncName, StringRef FileName="<unknown>")
Given a PGO function name, remove the filename prefix and return the original (static) function name.
void createPGONameMetadata(GlobalObject &GO, StringRef PGOName)
Create the PGOName metadata if a global object's PGO name is different from its mangled name.
StringRef getInstrProfVTableNamesVarName()
std::pair< StringRef, StringRef > getParsedIRPGOName(StringRef IRPGOName)
auto unique(Range &&R, Predicate P)
MDNode * getPGOFuncNameMetadata(const Function &F)
Return the PGOFuncName meta data associated with a function.
StringRef getInstrProfDataVarPrefix()
Return the name prefix of variables containing per-function control data.
StringRef getCoverageUnusedNamesVarName()
Return the name of the internal variable recording the array of PGO name vars referenced by the cover...
std::string getInstrProfSectionName(InstrProfSectKind IPSK, Triple::ObjectFormatType OF, bool AddSegmentInfo=true)
Return the name of the profile section corresponding to IPSK.
uint64_t getInstrMaxCountValue()
Return the max count value. We reserver a few large values for special use.
bool needsComdatForCounter(const GlobalObject &GV, const Module &M)
Check if we can use Comdat for profile variables.
std::string getPGOName(const GlobalVariable &V, bool InLTO=false)
StringRef getInstrProfInitFuncName()
Return the name of the runtime initialization method that is generated by the compiler.
StringRef getInstrProfValuesVarPrefix()
Return the name prefix of value profile variables.
StringRef getInstrProfCounterBiasVarName()
GlobalVariable * createPGOFuncNameVar(Function &F, StringRef PGOFuncName)
Create and return the global variable for function name used in PGO instrumentation.
void annotateValueSite(Module &M, Instruction &Inst, const InstrProfRecord &InstrProfR, InstrProfValueKind ValueKind, uint32_t SiteIndx, uint32_t MaxMDCount=3)
Get the value profile data for value site SiteIdx from InstrProfR and annotate the instruction Inst w...
StringRef getInstrProfRuntimeHookVarUseFuncName()
Return the name of the compiler generated function that references the runtime hook variable.
StringRef getInstrProfRegFuncsName()
Return the name of function that registers all the per-function control data at program startup time ...
Error collectPGOFuncNameStrings(ArrayRef< GlobalVariable * > NameVars, std::string &Result, bool doCompression=true)
Produce Result string with the same format described above.
void sort(IteratorTy Start, IteratorTy End)
StringRef getInstrProfCountersVarPrefix()
Return the name prefix of profile counter variables.
StringRef getPGOFuncNameVarInitializer(GlobalVariable *NameVar)
Return the initializer in string of the PGO name var NameVar.
StringRef getInstrProfBitmapBiasVarName()
StringRef getInstrProfNameSeparator()
Return the marker used to separate PGO names during serialization.
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...
StringRef getInstrProfValueProfMemOpFuncName()
Return the name profile runtime entry point to do memop size value profiling.
@ LLVM_MARK_AS_BITMASK_ENUM
@ unable_to_correlate_profile
@ raw_profile_version_mismatch
@ counter_value_too_large
@ missing_correlation_info
@ value_site_count_mismatch
@ unexpected_correlation_info
StringRef getInstrProfNamesRegFuncName()
Return the name of the runtime interface that registers the PGO name strings.
auto lower_bound(R &&Range, T &&Value)
Provide wrappers to std::lower_bound which take ranges instead of having to pass begin/end explicitly...
const std::error_category & instrprof_category()
Error collectVTableStrings(ArrayRef< GlobalVariable * > VTables, std::string &Result, bool doCompression)
bool canRenameComdatFunc(const Function &F, bool CheckAddressTaken=false)
Check if we can safely rename this Comdat function.
void createProfileFileNameVar(Module &M, StringRef InstrProfileOutput)
Error collectGlobalObjectNameStrings(ArrayRef< std::string > NameStrs, bool doCompression, std::string &Result)
Given a vector of strings (names of global objects like functions or, virtual tables) NameStrs,...
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
StringRef getInstrProfValueProfFuncName()
Return the name profile runtime entry point to do value profiling for a given site.
StringRef getInstrProfRegFuncName()
Return the name of the runtime interface that registers per-function control data for one instrumente...
std::string getPGOFuncNameVarName(StringRef FuncName, GlobalValue::LinkageTypes Linkage)
Return the name of the global variable used to store a function name in PGO instrumentation.
StringRef getInstrProfNamesVarName()
Return the name of the variable holding the strings (possibly compressed) of all function's PGO names...
bool isGPUProfTarget(const Module &M)
Determines whether module targets a GPU eligable for PGO instrumentation.
bool isIRPGOFlagSet(const Module *M)
Check if INSTR_PROF_RAW_VERSION_VAR is defined.
StringRef getPGONameMetadataName()
StringRef getInstrProfVNodesVarName()
Return the name of value profile node array variables:
StringRef getInstrProfVTableVarPrefix()
Return the name prefix of variables containing virtual table profile data.
InstrProfKind
An enum describing the attributes of an instrumented profile.
@ FunctionEntryInstrumentation
@ FrontendInstrumentation
Implement std::hash so that hash_code can be used in STL containers.
CountSumOrPercent()=default
std::array< double, IPVK_Last - IPVK_First+1 > ValueCounts
uint64_t Cutoff
The required percentile of total execution count.
uint64_t NumBlocks
Number of blocks >= the minumum execution count.
uint64_t MinBlockCount
The minimum execution count for this percentile.
const Entry * getCutoffEntryBase() const
uint64_t get(SummaryFieldKind K) const
void set(SummaryFieldKind K, uint64_t V)
Entry * getCutoffEntryBase()
void setEntry(uint32_t I, const ProfileSummaryEntry &E)
uint64_t * getSummaryDataBase()
@ TotalNumFunctions
The total number of functions instrumented.
@ TotalNumBlocks
Total number of instrumented blocks/edges.
@ MaxFunctionCount
The maximal execution count among all functions.
@ TotalBlockCount
The sum of all instrumented block counts.
@ MaxBlockCount
Max block count of the program.
@ MaxInternalBlockCount
Max internal block count of the program (excluding entry blocks).
const uint64_t * getSummaryDataBase() const
static uint32_t getSize(uint32_t NumSumFields, uint32_t NumCutoffEntries)
uint64_t NumSummaryFields
const Entry & getEntry(uint32_t I) const
uint64_t NumCutoffEntries
Profiling information for a single function.
void overlapValueProfData(uint32_t ValueKind, InstrProfRecord &Src, OverlapStats &Overlap, OverlapStats &FuncLevelOverlap)
Compute the overlap of value profile counts.
InstrProfRecord()=default
std::vector< uint64_t > Counts
ArrayRef< InstrProfValueData > getValueArrayForSite(uint32_t ValueKind, uint32_t Site) const
Return the array of profiled values at Site.
CountPseudoKind getCountPseudoKind() const
InstrProfRecord(std::vector< uint64_t > Counts)
void accumulateCounts(CountSumOrPercent &Sum) const
Compute the sums of all counts and store in Sum.
uint32_t getNumValueSites(uint32_t ValueKind) const
Return the number of instrumented sites for ValueKind.
uint32_t getNumValueKinds() const
Return the number of value profile kinds with non-zero number of profile sites.
void setPseudoCount(CountPseudoKind Kind)
InstrProfRecord(InstrProfRecord &&)=default
uint32_t getNumValueData(uint32_t ValueKind) const
Return the total number of ValueData for ValueKind.
void merge(InstrProfRecord &Other, uint64_t Weight, function_ref< void(instrprof_error)> Warn)
Merge the counts in Other into this one.
void addValueData(uint32_t ValueKind, uint32_t Site, ArrayRef< InstrProfValueData > VData, InstrProfSymtab *SymTab)
Add ValueData for ValueKind at value Site.
InstrProfRecord & operator=(const InstrProfRecord &RHS)
void clearValueData()
Clear value data entries.
InstrProfRecord(const InstrProfRecord &RHS)
InstrProfRecord(std::vector< uint64_t > Counts, std::vector< uint8_t > BitmapBytes)
void reserveSites(uint32_t ValueKind, uint32_t NumValueSites)
Reserve space for NumValueSites sites.
void overlap(InstrProfRecord &Other, OverlapStats &Overlap, OverlapStats &FuncLevelOverlap, uint64_t ValueCutoff)
Compute the overlap b/w this IntrprofRecord and Other.
void sortValueData()
Sort value profile data (per site) by count.
std::vector< uint8_t > BitmapBytes
InstrProfRecord & operator=(InstrProfRecord &&)=default
void Clear()
Clear value data entries and edge counters.
void scale(uint64_t N, uint64_t D, function_ref< void(instrprof_error)> Warn)
Scale up profile counts (including value profile data) by a factor of (N / D).
void sortByCount()
Sort ValueData Descending by Count.
InstrProfValueSiteRecord(std::vector< InstrProfValueData > &&VD)
InstrProfValueSiteRecord()=default
void sortByTargetValues()
Sort ValueData ascending by Value.
std::vector< InstrProfValueData > ValueData
Value profiling data pairs at a given value site.
void merge(InstrProfValueSiteRecord &Input, uint64_t Weight, function_ref< void(instrprof_error)> Warn)
Merge data from another InstrProfValueSiteRecord Optionally scale merged counts by Weight.
void overlap(InstrProfValueSiteRecord &Input, uint32_t ValueKind, OverlapStats &Overlap, OverlapStats &FuncLevelOverlap)
Compute the overlap b/w this record and Input record.
void scale(uint64_t N, uint64_t D, function_ref< void(instrprof_error)> Warn)
Scale up value profile data counts by N (Numerator) / D (Denominator).
static bool hasCSFlagInHash(uint64_t FuncHash)
NamedInstrProfRecord(StringRef Name, uint64_t Hash, std::vector< uint64_t > Counts)
NamedInstrProfRecord(StringRef Name, uint64_t Hash, std::vector< uint64_t > Counts, std::vector< uint8_t > BitmapBytes)
static void setCSFlagInHash(uint64_t &FuncHash)
static const int CS_FLAG_IN_FUNC_HASH
NamedInstrProfRecord()=default
const std::string NameFilter
void addOneMismatch(const CountSumOrPercent &MismatchFunc)
static double score(uint64_t Val1, uint64_t Val2, double Sum1, double Sum2)
Error accumulateCounts(const std::string &BaseFilename, const std::string &TestFilename, bool IsCS)
void dump(raw_fd_ostream &OS) const
CountSumOrPercent Overlap
void addOneUnique(const CountSumOrPercent &UniqueFunc)
const std::string * BaseFilename
const std::string * TestFilename
void setFuncInfo(StringRef Name, uint64_t Hash)
CountSumOrPercent Mismatch
OverlapStats(OverlapStatsLevel L=ProgramLevel)
An ordered list of functions identified by their NameRef found in INSTR_PROF_DATA.
static void createBPFunctionNodes(ArrayRef< TemporalProfTraceTy > Traces, std::vector< BPFunctionNode > &Nodes, bool RemoveOutlierUNs=true)
Use a set of temporal profile traces to create a list of balanced partitioning function nodes used by...
std::vector< uint64_t > FunctionNameRefs
TemporalProfTraceTy(std::initializer_list< uint64_t > Trace={}, uint64_t Weight=1)
Function object to check whether the first component of a container supported by std::get (like std::...