14#ifndef LLVM_PROFILEDATA_SAMPLEPROF_H
15#define LLVM_PROFILEDATA_SAMPLEPROF_H
38#include <system_error>
39#include <unordered_map>
87struct is_error_code_enum<
llvm::sampleprof_error> : std::true_type {};
137 switch (
static_cast<int>(
Type)) {
139 return "InvalidSection";
141 return "ProfileSummarySection";
143 return "NameTableSection";
145 return "ProfileSymbolListSection";
147 return "FuncOffsetTableSection";
149 return "FunctionMetadata";
151 return "CSNameTableSection";
153 return "LBRProfileSection";
155 return "UnknownSection";
228template <
class SecFlagType>
231 if (std::is_same<SecCommonFlags, SecFlagType>())
235 bool IsFlagLegal =
false;
238 IsFlagLegal = std::is_same<SecNameTableFlags, SecFlagType>();
241 IsFlagLegal = std::is_same<SecProfSummaryFlags, SecFlagType>();
244 IsFlagLegal = std::is_same<SecFuncMetadataFlags, SecFlagType>();
248 IsFlagLegal = std::is_same<SecFuncOffsetFlags, SecFlagType>();
255template <
class SecFlagType>
258 auto FVal =
static_cast<uint64_t>(Flag);
259 bool IsCommon = std::is_same<SecCommonFlags, SecFlagType>();
260 Entry.Flags |= IsCommon ? FVal : (FVal << 32);
263template <
class SecFlagType>
266 auto FVal =
static_cast<uint64_t>(Flag);
267 bool IsCommon = std::is_same<SecCommonFlags, SecFlagType>();
268 Entry.Flags &= ~(IsCommon ? FVal : (FVal << 32));
271template <
class SecFlagType>
274 auto FVal =
static_cast<uint64_t>(Flag);
275 bool IsCommon = std::is_same<SecCommonFlags, SecFlagType>();
276 return Entry.Flags & (IsCommon ? FVal : (FVal << 32));
299 std::tie(O.LineOffset, O.Discriminator);
320 return Loc.getHashCode();
355 if (
LHS.second !=
RHS.second)
356 return LHS.second >
RHS.second;
358 return LHS.first <
RHS.first;
394 uint64_t &TargetSamples = CallTargets[
F];
406 auto I = CallTargets.find(
F);
407 if (
I != CallTargets.end()) {
409 CallTargets.erase(
I);
415 bool hasCalls()
const {
return !CallTargets.empty(); }
425 for (
const auto &
I : CallTargets)
434 for (
const auto &[
Target, Frequency] : Targets) {
435 SortedTargets.emplace(
Target, Frequency);
437 return SortedTargets;
442 float DistributionFactor) {
444 for (
const auto &[
Target, Frequency] : Targets) {
445 AdjustedTargets[
Target] = Frequency * DistributionFactor;
447 return AdjustedTargets;
463 return NumSamples ==
Other.NumSamples && CallTargets ==
Other.CallTargets;
467 return !(*
this ==
Other);
510 return !(*
this == That);
513 std::string
toString(
bool OutputLineLocation)
const {
514 std::ostringstream OContextStr;
515 OContextStr <<
Func.str();
516 if (OutputLineLocation) {
517 OContextStr <<
":" <<
Location.LineOffset;
519 OContextStr <<
"." <<
Location.Discriminator;
521 return OContextStr.str();
527 return NameHash + (LocId << 5) + LocId;
560 assert(!Name.empty() &&
"Name is empty");
569 assert(!Context.empty() &&
"Context is empty");
577 std::list<SampleContextFrameVector> &CSNameTable,
588 CSNameTable.emplace_back();
600 ContextStr = ContextStr.
substr(1, ContextStr.
size() - 2);
604 while (!ContextRemain.
empty()) {
605 auto ContextSplit = ContextRemain.
split(
" @ ");
606 ChildContext = ContextSplit.first;
607 ContextRemain = ContextSplit.second;
610 Context.emplace_back(Callee, CallSiteLoc);
620 auto EntrySplit = ContextStr.
split(
':');
624 if (!EntrySplit.second.empty()) {
628 auto LocSplit = EntrySplit.second.split(
'.');
629 LocSplit.first.getAsInteger(10, LineOffset);
633 if (!LocSplit.second.empty())
652 bool IncludeLeafLineLocation =
false) {
653 std::ostringstream OContextStr;
655 if (OContextStr.str().size()) {
656 OContextStr <<
" @ ";
658 OContextStr << Context[
I].toString(
I != Context.size() - 1 ||
659 IncludeLeafLineLocation);
661 return OContextStr.str();
678 Func = NewFunctionID;
686 FullContext = Context;
687 Func = Context.back().Func;
692 return State == That.State && Func == That.Func &&
693 FullContext == That.FullContext;
699 if (State != That.State)
700 return State < That.State;
703 return Func < That.Func;
707 while (
I < std::min(FullContext.size(), That.FullContext.
size())) {
708 auto &Context1 = FullContext[
I];
709 auto &Context2 = That.FullContext[
I];
710 auto V = Context1.Func.compare(Context2.Func);
713 if (Context1.Location != Context2.Location)
714 return Context1.Location < Context2.Location;
718 return FullContext.size() < That.FullContext.
size();
723 return Context.getHashCode();
728 auto ThisContext = FullContext;
729 auto ThatContext = That.FullContext;
730 if (ThatContext.size() < ThisContext.size())
732 ThatContext = ThatContext.
take_front(ThisContext.size());
734 if (ThisContext.back().Func != ThatContext.back().Func)
753 return Context.getHashCode();
757 return OS << Context.toString();
770 std::unordered_map<LineLocation, LineLocation, LineLocationHash>;
793 if (TotalSamples < Num)
813 return BodySamples[
LineLocation(LineOffset, Discriminator)].addSamples(
822 return BodySamples[
LineLocation(LineOffset, Discriminator)].addCalledTarget(
829 return BodySamples[Location].merge(
SampleRecord, Weight);
838 auto I = BodySamples.find(
LineLocation(LineOffset, Discriminator));
839 if (
I != BodySamples.end()) {
840 Count =
I->second.removeCalledTarget(Func);
842 if (!
I->second.getSamples())
843 BodySamples.erase(
I);
851 CallsiteSamples.clear();
856 for (
auto &
I : BodySamples) {
857 uint64_t TargetSamples =
I.second.getCallTargetSum();
862 if (TargetSamples >
I.second.getSamples())
863 I.second.addSamples(TargetSamples -
I.second.getSamples());
870 for (
const auto &
I : BodySamples)
873 for (
auto &
I : CallsiteSamples) {
874 for (
auto &CS :
I.second) {
875 CS.second.updateTotalSamples();
884 for (
auto &
I : CallsiteSamples) {
885 for (
auto &CS :
I.second) {
886 CS.second.setContextSynthetic();
894 Context.setAttribute(Attr);
895 for (
auto &
I : CallsiteSamples) {
896 for (
auto &CS :
I.second) {
897 CS.second.setContextAttribute(Attr);
906 if (!IRToProfileLocationMap)
908 const auto &ProfileLoc = IRToProfileLocationMap->find(IRLoc);
909 if (ProfileLoc != IRToProfileLocationMap->end())
910 return ProfileLoc->second;
919 const auto &Ret = BodySamples.find(
921 if (Ret == BodySamples.end())
922 return std::error_code();
923 return Ret->second.getSamples();
931 const auto &Ret = BodySamples.find(
933 if (Ret == BodySamples.end())
934 return std::error_code();
935 return Ret->second.getCallTargets();
943 if (Ret == BodySamples.end())
944 return std::error_code();
945 return Ret->second.getCallTargets();
957 if (Iter == CallsiteSamples.end())
959 return &Iter->second;
965 if (Iter == VirtualCallsiteTypeCounts.end())
967 return &Iter->second;
980 *FuncNameToProfNameMap =
nullptr)
const;
982 bool empty()
const {
return TotalSamples == 0; }
1009 if (!BodySamples.empty() &&
1010 (CallsiteSamples.empty() ||
1011 BodySamples.begin()->first < CallsiteSamples.begin()->first))
1012 Count = BodySamples.begin()->second.getSamples();
1013 else if (!CallsiteSamples.empty()) {
1016 for (
const auto &FuncSamples : CallsiteSamples.begin()->second)
1017 Count += FuncSamples.second.getHeadSamplesEstimate();
1028 return CallsiteSamples;
1034 return VirtualCallsiteTypeCounts;
1048 template <
typename T>
1052 static_assert((std::is_same_v<typename T::key_type, StringRef> ||
1053 std::is_same_v<typename T::key_type, FunctionId>) &&
1054 std::is_same_v<typename T::mapped_type, uint64_t>,
1055 "T must be a map with StringRef or FunctionId as key and "
1056 "uint64_t as value");
1058 bool Overflowed =
false;
1062 bool RowOverflow =
false;
1064 Count, Weight, TypeCounts[TypeId], &RowOverflow);
1065 Overflowed |= RowOverflow;
1078 MaxCount = std::max(MaxCount, L.second.getSamples());
1082 for (
const FunctionSamplesMap::value_type &
F :
C.second)
1083 MaxCount = std::max(MaxCount,
F.second.getMaxCountInside());
1093 if (Context.getFunction().empty())
1094 Context =
Other.getContext();
1095 if (FunctionHash == 0) {
1097 FunctionHash =
Other.getFunctionHash();
1098 }
else if (FunctionHash !=
Other.getFunctionHash()) {
1113 for (
const auto &
I :
Other.getBodySamples()) {
1118 for (
const auto &
I :
Other.getCallsiteSamples()) {
1121 for (
const auto &Rec :
I.second)
1123 FSMap[Rec.first].merge(Rec.second, Weight));
1125 for (
const auto &[
Loc, OtherTypeMap] :
Other.getCallsiteTypeCounts())
1140 if (TotalSamples <= Threshold)
1142 auto IsDeclaration = [](
const Function *
F) {
1143 return !
F ||
F->isDeclaration();
1151 for (
const auto &BS : BodySamples)
1152 for (
const auto &TS : BS.second.getCallTargets())
1153 if (TS.second > Threshold) {
1155 if (IsDeclaration(Callee))
1156 S.
insert(TS.first.getHashCode());
1158 for (
const auto &CS : CallsiteSamples)
1159 for (
const auto &NameFS : CS.second)
1160 NameFS.second.findInlinedFunctions(S, SymbolMap, Threshold);
1165 Context.setFunction(NewFunctionID);
1179 assert(IRToProfileLocationMap ==
nullptr &&
"this should be set only once");
1180 IRToProfileLocationMap = LTLM;
1186 const char *AttrName =
"sample-profile-suffix-elision-policy";
1187 auto Attr =
F.getFnAttribute(AttrName).getValueAsString();
1203 if (Attr ==
"" || Attr ==
"all")
1204 return FnName.
split(
'.').first;
1205 if (Attr ==
"selected") {
1207 for (
const auto &Suf : KnownSuffixes) {
1213 auto It = Cand.
rfind(Suffix);
1216 auto Dit = Cand.
rfind(
'.');
1217 if (Dit == It + Suffix.
size() - 1)
1218 Cand = Cand.
substr(0, It);
1224 assert(
false &&
"internal error: unknown suffix elision policy");
1237 return Func.stringRef();
1279 *FuncNameToProfNameMap =
nullptr)
const;
1318 FunctionHash ==
Other.FunctionHash && Context ==
Other.Context &&
1319 TotalSamples ==
Other.TotalSamples &&
1320 TotalHeadSamples ==
Other.TotalHeadSamples &&
1321 BodySamples ==
Other.BodySamples &&
1322 CallsiteSamples ==
Other.CallsiteSamples;
1326 return !(*
this ==
Other);
1406 const LocToLocMap *IRToProfileLocationMap =
nullptr;
1425 :
public HashKeyMap<std::unordered_map, SampleContext, FunctionSamples> {
1432 Ret.first->second.setContext(Ctx);
1433 return Ret.first->second;
1460 std::vector<NameFunctionSamples> &SortedProfiles);
1472 for (
const auto &
I : Samples)
1475 return A->first <
B->first;
1499 bool TrimColdContext,
1500 bool MergeColdContext,
1502 bool TrimBaseProfileOnly);
1538 bool ProfileIsCS =
false) {
1541 ProfileMap = std::move(TmpProfiles);
1546 bool ProfileIsCS =
false) {
1548 for (
const auto &
I : InputProfiles) {
1555 for (
const auto &
I : InputProfiles)
1556 flattenNestedProfile(OutputProfiles,
I.second);
1566 auto Ret = OutputProfiles.
try_emplace(Context, FS);
1571 Profile.removeAllCallsiteSamples();
1581 "There should be no inlinees' profiles after flattening.");
1587 uint64_t TotalSamples =
FS.getTotalSamples();
1589 for (
const auto &
I :
FS.getCallsiteSamples()) {
1590 for (
const auto &Callee :
I.second) {
1591 const auto &CalleeProfile =
Callee.second;
1593 Profile.addBodySamples(
I.first.LineOffset,
I.first.Discriminator,
1594 CalleeProfile.getHeadSamplesEstimate());
1596 Profile.addCalledTargetSamples(
1597 I.first.LineOffset,
I.first.Discriminator,
1598 CalleeProfile.getFunction(),
1599 CalleeProfile.getHeadSamplesEstimate());
1601 TotalSamples = TotalSamples >= CalleeProfile.getTotalSamples()
1602 ? TotalSamples - CalleeProfile.getTotalSamples()
1604 TotalSamples += CalleeProfile.getHeadSamplesEstimate();
1606 flattenNestedProfile(OutputProfiles, CalleeProfile);
1609 Profile.addTotalSamples(TotalSamples);
1618 SampleProfileMap &ProfileMap;
1635 Syms.insert(Name.copy(Allocator));
1641 for (
auto Sym :
List.Syms)
1645 unsigned size() {
return Syms.size(); }
1658 bool ToCompress =
false;
1665using namespace sampleprof;
1698 return toString(IntHash, 10,
false)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file defines the BumpPtrAllocator interface.
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
This file defines the DenseSet and SmallDenseSet classes.
Provides ErrorOr<T> smart pointer.
Defines HashKeyMap template.
static cl::opt< unsigned > ColdCountThreshold("mfs-count-threshold", cl::desc("Minimum number of times a block must be executed to be retained."), cl::init(1), cl::Hidden)
This file implements a map that provides insertion order iteration.
Defines FunctionId class.
This file defines the SmallVector class.
Class for arbitrary precision integers.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
ArrayRef< T > take_front(size_t N=1) const
Return a copy of *this with only the first N elements.
size_t size() const
size - Get the array size.
ArrayRef< T > drop_back(size_t N=1) const
Drop the last N elements of the array.
ValueT lookup(const_arg_type_t< KeyT > Val) const
lookup - Return the entry for the specified key, or a default constructed value if no such entry exis...
Implements a dense probed hash-table based set.
Represents either an error or a value T.
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
LLVM_ABI void update(ArrayRef< uint8_t > Data)
Updates the hash for the byte stream provided.
static LLVM_ABI void stringifyResult(MD5Result &Result, SmallVectorImpl< char > &Str)
Translates the bytes in Res to a hex string that is deposited into Str.
LLVM_ABI void final(MD5Result &Result)
Finishes off the hash and puts the result in result.
This class implements a map that also provides access to all stored values in a deterministic order.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
std::pair< StringRef, StringRef > split(char Separator) const
Split into two substrings around the first occurrence of a separator character.
constexpr StringRef substr(size_t Start, size_t N=npos) const
Return a reference to the substring from [Start, Start + N).
bool starts_with(StringRef Prefix) const
Check if this string starts with the given Prefix.
constexpr bool empty() const
empty - Check if the string is empty.
constexpr size_t size() const
size - Get the string size.
size_t rfind(char C, size_t From=npos) const
Search for the last character C in the string.
static constexpr size_t npos
Target - Wrapper for Target specific information.
The instances of the Type class are immutable: once they are created, they are never changed.
std::pair< iterator, bool > insert(const ValueT &V)
An opaque object representing a hash code.
This class implements an extremely fast bulk output stream that can only output to a stream.
This class represents a function that is read from a sample profile.
uint64_t getHashCode() const
Get hash code of this object.
Representation of the samples collected for a function.
void setTotalSamples(uint64_t Num)
static LLVM_ABI bool ProfileIsPreInlined
void setContextAttribute(ContextAttributeMask Attr)
void findInlinedFunctions(DenseSet< GlobalValue::GUID > &S, const HashKeyMap< std::unordered_map, FunctionId, Function * > &SymbolMap, uint64_t Threshold) const
Recursively traverses all children, if the total sample count of the corresponding function is no les...
bool operator!=(const FunctionSamples &Other) const
void updateTotalSamples()
void setHeadSamples(uint64_t Num)
LLVM_ABI const FunctionSamples * findFunctionSamplesAt(const LineLocation &Loc, StringRef CalleeName, SampleProfileReaderItaniumRemapper *Remapper, const HashKeyMap< std::unordered_map, FunctionId, FunctionId > *FuncNameToProfNameMap=nullptr) const
Returns a pointer to FunctionSamples at the given callsite location Loc with callee CalleeName.
sampleprof_error addTotalSamples(uint64_t Num, uint64_t Weight=1)
static constexpr const char * UniqSuffix
void updateCallsiteSamples()
static StringRef getCanonicalFnName(StringRef FnName, StringRef Attr="selected")
bool operator==(const FunctionSamples &Other) const
static constexpr const char * PartSuffix
static uint64_t getCallSiteHash(FunctionId Callee, const LineLocation &Callsite)
Returns a unique hash code for a combination of a callsite location and the callee function name.
const FunctionSamplesMap * findFunctionSamplesMapAt(const LineLocation &Loc) const
Returns the FunctionSamplesMap at the given Loc.
void removeAllCallsiteSamples()
uint64_t getMaxCountInside(bool SkipCallSite=false) const
Return the maximum of sample counts in a function body.
void removeTotalSamples(uint64_t Num)
uint64_t getHeadSamples() const
For top-level functions, return the total number of branch samples that have the function as the bran...
void setFunction(FunctionId NewFunctionID)
Set the name of the function.
ErrorOr< uint64_t > findSamplesAt(uint32_t LineOffset, uint32_t Discriminator) const
Return the number of samples collected at the given location.
static LLVM_ABI bool ProfileIsCS
ErrorOr< const SampleRecord::CallTargetMap & > findCallTargetMapAt(const LineLocation &CallSite) const
Returns the call target map collected at a given location specified by CallSite.
const LineLocation & mapIRLocToProfileLoc(const LineLocation &IRLoc) const
FunctionId getFunction() const
Return the function name.
uint64_t getFunctionHash() const
const CallsiteTypeMap & getCallsiteTypeCounts() const
Returns vtable access samples for the C++ types collected in this function.
sampleprof_error addCallsiteVTableTypeProfAt(const LineLocation &Loc, const T &Other, uint64_t Weight=1)
Scale Other sample counts by Weight and add the scaled result to the type samples for Loc.
static constexpr const char * LLVMSuffix
Name suffixes which canonicalization should handle to avoid profile mismatch.
StringRef getFuncName(FunctionId Func) const
Translate Func into its original name.
const TypeCountMap * findCallsiteTypeSamplesAt(const LineLocation &Loc) const
Returns the TypeCountMap for inlined callsites at the given Loc.
sampleprof_error addHeadSamples(uint64_t Num, uint64_t Weight=1)
sampleprof_error addSampleRecord(LineLocation Location, const SampleRecord &SampleRecord, uint64_t Weight=1)
uint64_t removeCalledTargetAndBodySample(uint32_t LineOffset, uint32_t Discriminator, FunctionId Func)
DenseMap< uint64_t, StringRef > * GUIDToFuncNameMap
GUIDToFuncNameMap saves the mapping from GUID to the symbol name, for all the function symbols define...
sampleprof_error addCalledTargetSamples(uint32_t LineOffset, uint32_t Discriminator, FunctionId Func, uint64_t Num, uint64_t Weight=1)
FunctionSamplesMap & functionSamplesAt(const LineLocation &Loc)
Return the function samples at the given callsite location.
LLVM_ABI const FunctionSamples * findFunctionSamples(const DILocation *DIL, SampleProfileReaderItaniumRemapper *Remapper=nullptr, const HashKeyMap< std::unordered_map, FunctionId, FunctionId > *FuncNameToProfNameMap=nullptr) const
Get the FunctionSamples of the inline instance where DIL originates from.
static LLVM_ABI bool ProfileIsProbeBased
void setIRToProfileLocationMap(const LocToLocMap *LTLM)
static StringRef getCanonicalFnName(const Function &F)
Return the canonical name for a function, taking into account suffix elision policy attributes.
StringRef getFuncName() const
Return the original function name.
LLVM_ABI void findAllNames(DenseSet< FunctionId > &NameSet) const
sampleprof_error addBodySamples(uint32_t LineOffset, uint32_t Discriminator, uint64_t Num, uint64_t Weight=1)
static LLVM_ABI unsigned getOffset(const DILocation *DIL)
Returns the line offset to the start line of the subprogram.
void setContextSynthetic()
void setFunctionHash(uint64_t Hash)
static LLVM_ABI bool ProfileIsFS
If this profile uses flow sensitive discriminators.
ErrorOr< const SampleRecord::CallTargetMap & > findCallTargetMapAt(uint32_t LineOffset, uint32_t Discriminator) const
Returns the call target map collected at a given location.
SampleContext & getContext() const
static LLVM_ABI bool HasUniqSuffix
Whether the profile contains any ".__uniq." suffix in a name.
uint64_t getTotalSamples() const
Return the total number of samples collected inside the function.
LLVM_ABI void print(raw_ostream &OS=dbgs(), unsigned Indent=0) const
Print the samples collected for a function on stream OS.
sampleprof_error merge(const FunctionSamples &Other, uint64_t Weight=1)
Merge the samples in Other into this one.
FunctionSamples()=default
const CallsiteSampleMap & getCallsiteSamples() const
Return all the callsite samples collected in the body of the function.
LLVM_ABI void dump() const
void setContext(const SampleContext &FContext)
static LLVM_ABI LineLocation getCallSiteIdentifier(const DILocation *DIL, bool ProfileIsFS=false)
Returns a unique call site identifier for a given debug location of a call instruction.
uint64_t getHeadSamplesEstimate() const
Return an estimate of the sample count of the function entry basic block.
uint64_t getGUID() const
Return the GUID of the context's name.
TypeCountMap & getTypeSamplesAt(const LineLocation &Loc)
Returns the vtable access samples for the C++ types for Loc.
const BodySampleMap & getBodySamples() const
Return all the samples collected in the body of the function.
static LLVM_ABI bool UseMD5
Whether the profile uses MD5 to represent string.
This class is a wrapper to associative container MapT<KeyT, ValueT> using the hash value of the origi...
FunctionSamples mapped_type
std::pair< iterator, bool > try_emplace(const key_type &Hash, const original_key_type &Key, Ts &&...Args)
typename base_type::iterator iterator
decltype(hash_value(SampleContext())) key_type
size_t erase(const original_key_type &Ctx)
iterator find(const original_key_type &Key)
typename base_type::const_iterator const_iterator
LLVM_ABI ProfileConverter(SampleProfileMap &Profiles)
LLVM_ABI void convertCSProfiles()
static void flattenProfile(SampleProfileMap &ProfileMap, bool ProfileIsCS=false)
static void flattenProfile(const SampleProfileMap &InputProfiles, SampleProfileMap &OutputProfiles, bool ProfileIsCS=false)
ProfileSymbolList records the list of function symbols shown up in the binary used to generate the pr...
void setToCompress(bool TC)
void add(StringRef Name, bool Copy=false)
copy indicates whether we need to copy the underlying memory for the input Name.
LLVM_ABI std::error_code write(raw_ostream &OS)
LLVM_ABI void dump(raw_ostream &OS=dbgs()) const
void merge(const ProfileSymbolList &List)
bool contains(StringRef Name)
LLVM_ABI std::error_code read(const uint8_t *Data, uint64_t ListSize)
SampleContextTrimmer(SampleProfileMap &Profiles)
LLVM_ABI void trimAndMergeColdContextProfiles(uint64_t ColdCountThreshold, bool TrimColdContext, bool MergeColdContext, uint32_t ColdContextFrameLength, bool TrimBaseProfileOnly)
static void createCtxVectorFromStr(StringRef ContextStr, SampleContextFrameVector &Context)
Create a context vector from a given context string and save it in Context.
bool operator==(const SampleContext &That) const
void setFunction(FunctionId NewFunctionID)
Set the name of the function and clear the current context.
SampleContext(SampleContextFrames Context, ContextStateMask CState=RawContext)
bool operator<(const SampleContext &That) const
SampleContext(StringRef ContextStr, std::list< SampleContextFrameVector > &CSNameTable, ContextStateMask CState=RawContext)
bool hasState(ContextStateMask S)
void clearState(ContextStateMask S)
SampleContextFrames getContextFrames() const
SampleContext(FunctionId Func)
bool isBaseContext() const
static void decodeContextString(StringRef ContextStr, FunctionId &Func, LineLocation &LineLoc)
static std::string getContextString(SampleContextFrames Context, bool IncludeLeafLineLocation=false)
bool operator!=(const SampleContext &That) const
void setState(ContextStateMask S)
void setAllAttributes(uint32_t A)
uint64_t getHashCode() const
void setContext(SampleContextFrames Context, ContextStateMask CState=RawContext)
FunctionId getFunction() const
uint32_t getAllAttributes()
void setAttribute(ContextAttributeMask A)
bool hasAttribute(ContextAttributeMask A)
std::string toString() const
SampleContext(StringRef Name)
bool isPrefixOf(const SampleContext &That) const
This class provides operator overloads to the map container using MD5 as the key type,...
iterator find(const SampleContext &Ctx)
mapped_type & create(const SampleContext &Ctx)
iterator erase(iterator It)
size_t erase(const key_type &Key)
const_iterator find(const SampleContext &Ctx) const
size_t erase(const SampleContext &Ctx)
SampleProfileReaderItaniumRemapper remaps the profile data from a sample profile data reader,...
Representation of a single sample record.
std::unordered_map< FunctionId, uint64_t > CallTargetMap
LLVM_ABI std::error_code serialize(raw_ostream &OS, const MapVector< FunctionId, uint32_t > &NameTable) const
Serialize the sample record to the output stream using ULEB128 encoding.
LLVM_ABI void dump() const
bool hasCalls() const
Return true if this sample record contains function calls.
LLVM_ABI sampleprof_error merge(const SampleRecord &Other, uint64_t Weight=1)
Merge the samples in Other into this record.
static const SortedCallTargetSet sortCallTargets(const CallTargetMap &Targets)
Sort call targets in descending order of call frequency.
const CallTargetMap & getCallTargets() const
std::set< CallTarget, CallTargetComparator > SortedCallTargetSet
uint64_t getSamples() const
uint64_t getCallTargetSum() const
uint64_t removeSamples(uint64_t S)
Decrease the number of samples for this record by S.
sampleprof_error addSamples(uint64_t S, uint64_t Weight=1)
Increment the number of samples for this record by S.
uint64_t removeCalledTarget(FunctionId F)
Remove called function from the call target map.
const SortedCallTargetSet getSortedCallTargets() const
static const CallTargetMap adjustCallTargets(const CallTargetMap &Targets, float DistributionFactor)
Prorate call targets by a distribution factor.
std::pair< FunctionId, uint64_t > CallTarget
bool operator!=(const SampleRecord &Other) const
bool operator==(const SampleRecord &Other) const
LLVM_ABI void print(raw_ostream &OS, unsigned Indent) const
Print the sample record to the stream OS indented by Indent.
sampleprof_error addCalledTarget(FunctionId F, uint64_t S, uint64_t Weight=1)
Add called function F with samples S.
std::pair< const LocationT, SampleT > SamplesWithLoc
SampleSorter(const std::map< LocationT, SampleT > &Samples)
const SamplesWithLocList & get() const
SmallVector< const SamplesWithLoc *, 20 > SamplesWithLocList
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ C
The default llvm calling convention, compatible with C.
static FunctionId getRepInFormat(StringRef Name)
Get the proper representation of a string according to whether the current Format uses MD5 to represe...
static void verifySecFlag(SecType Type, SecFlagType Flag)
LLVM_ABI void sortFuncProfiles(const SampleProfileMap &ProfileMap, std::vector< NameFunctionSamples > &SortedProfiles)
static uint64_t SPMagic(SampleProfileFormat Format=SPF_Binary)
static void addSecFlag(SecHdrTableEntry &Entry, SecFlagType Flag)
std::map< LineLocation, FunctionSamplesMap > CallsiteSampleMap
static bool hasSecFlag(const SecHdrTableEntry &Entry, SecFlagType Flag)
ArrayRef< SampleContextFrame > SampleContextFrames
std::pair< hash_code, const FunctionSamples * > NameFunctionSamples
@ ContextDuplicatedIntoBase
@ SecFlagIsPreInlined
SecFlagIsPreInlined means this profile contains ShouldBeInlined contexts thus this is CS preinliner c...
@ SecFlagHasVTableTypeProf
SecFlagHasVTableTypeProf means this profile contains vtable type profiles.
@ SecFlagPartial
SecFlagPartial means the profile is for common/shared code.
@ SecFlagFSDiscriminator
SecFlagFSDiscriminator means this profile uses flow-sensitive discriminators.
@ SecFlagFullContext
SecFlagContext means this is context-sensitive flat profile for CSSPGO.
static void removeSecFlag(SecHdrTableEntry &Entry, SecFlagType Flag)
SmallVector< SampleContextFrame, 1 > SampleContextFrameVector
std::map< FunctionId, FunctionSamples > FunctionSamplesMap
std::unordered_map< LineLocation, LineLocation, LineLocationHash > LocToLocMap
raw_ostream & operator<<(raw_ostream &OS, const FunctionId &Obj)
std::map< FunctionId, uint64_t > TypeCountMap
Key represents type of a C++ polymorphic class type by its vtable and value represents its counter.
static std::string getSecName(SecType Type)
constexpr char kVTableProfPrefix[]
uint64_t hash_value(const FunctionId &Obj)
std::error_code serializeTypeMap(const TypeCountMap &Map, const MapVector< FunctionId, uint32_t > &NameTable, raw_ostream &OS)
Write Map to the output stream.
static uint64_t SPVersion()
std::map< LineLocation, TypeCountMap > CallsiteTypeMap
std::map< LineLocation, SampleRecord > BodySampleMap
This is an optimization pass for GlobalISel generic memory operations.
void stable_sort(R &&Range)
std::error_code make_error_code(BitcodeError E)
sampleprof_error mergeSampleProfErrors(sampleprof_error &Accumulator, sampleprof_error Result)
@ unsupported_writing_format
@ ostream_seek_unsupported
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
FunctionAddr VTableAddr Count
std::enable_if_t< std::is_unsigned_v< T >, T > SaturatingMultiplyAdd(T X, T Y, T A, bool *ResultOverflowed=nullptr)
Multiply two unsigned integers, X and Y, and add the unsigned integer, A to the product.
BumpPtrAllocatorImpl BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
LLVM_ATTRIBUTE_VISIBILITY_DEFAULT AnalysisKey InnerAnalysisManagerProxy< AnalysisManagerT, IRUnitT, ExtraArgTs... >::Key
LLVM_ABI const std::error_category & sampleprof_category()
FunctionAddr VTableAddr uintptr_t uintptr_t Data
std::string getUniqueInternalLinkagePostfix(const StringRef &FName)
std::string toString(const APInt &I, unsigned Radix, bool Signed, bool formatAsCLiteral=false, bool UpperCase=true, bool InsertSeparators=false)
LogicalResult success(bool IsSuccess=true)
Utility function to generate a LogicalResult.
hash_code hash_combine_range(InputIteratorT first, InputIteratorT last)
Compute a hash_code for a sequence of values.
Implement std::hash so that hash_code can be used in STL containers.
static unsigned getHashValue(const SampleContext &Val)
static SampleContext getTombstoneKey()
static SampleContext getEmptyKey()
static bool isEqual(const SampleContext &LHS, const SampleContext &RHS)
An information struct used to provide DenseMap with the various necessary components for a given valu...
uint64_t operator()(const LineLocation &Loc) const
Represents the relative location of an instruction.
LLVM_ABI void serialize(raw_ostream &OS) const
LLVM_ABI void print(raw_ostream &OS) const
LineLocation(uint32_t L, uint32_t D)
bool operator!=(const LineLocation &O) const
bool operator<(const LineLocation &O) const
uint64_t getHashCode() const
bool operator==(const LineLocation &O) const
LLVM_ABI void dump() const
FunctionSamples * FuncSamples
FrameNode(FunctionId FName=FunctionId(), FunctionSamples *FSamples=nullptr, LineLocation CallLoc={0, 0})
LLVM_ABI FrameNode * getOrCreateChildFrame(const LineLocation &CallSite, FunctionId CalleeName)
std::map< uint64_t, FrameNode > AllChildFrames
uint64_t operator()(const SampleContextFrameVector &S) const
bool operator==(const SampleContextFrame &That) const
SampleContextFrame(FunctionId Func, LineLocation Location)
bool operator!=(const SampleContextFrame &That) const
std::string toString(bool OutputLineLocation) const
uint64_t getHashCode() const
uint64_t operator()(const SampleContext &Context) const
bool operator()(const CallTarget &LHS, const CallTarget &RHS) const