14#ifndef LLVM_PROFILEDATA_SAMPLEPROF_H
15#define LLVM_PROFILEDATA_SAMPLEPROF_H
35#include <system_error>
36#include <unordered_map>
83struct is_error_code_enum<
llvm::sampleprof_error> : std::true_type {};
115 std::string &GUIDBuf) {
116 if (
Name.empty() || !UseMD5)
143 return "InvalidSection";
145 return "ProfileSummarySection";
147 return "NameTableSection";
149 return "ProfileSymbolListSection";
151 return "FuncOffsetTableSection";
153 return "FunctionMetadata";
155 return "CSNameTableSection";
157 return "LBRProfileSection";
159 return "UnknownSection";
229template <
class SecFlagType>
232 if (std::is_same<SecCommonFlags, SecFlagType>())
236 bool IsFlagLegal =
false;
239 IsFlagLegal = std::is_same<SecNameTableFlags, SecFlagType>();
242 IsFlagLegal = std::is_same<SecProfSummaryFlags, SecFlagType>();
245 IsFlagLegal = std::is_same<SecFuncMetadataFlags, SecFlagType>();
249 IsFlagLegal = std::is_same<SecFuncOffsetFlags, SecFlagType>();
256template <
class SecFlagType>
259 auto FVal =
static_cast<uint64_t>(Flag);
260 bool IsCommon = std::is_same<SecCommonFlags, SecFlagType>();
261 Entry.Flags |= IsCommon ? FVal : (FVal << 32);
264template <
class SecFlagType>
267 auto FVal =
static_cast<uint64_t>(Flag);
268 bool IsCommon = std::is_same<SecCommonFlags, SecFlagType>();
269 Entry.Flags &= ~(IsCommon ? FVal : (FVal << 32));
272template <
class SecFlagType>
275 auto FVal =
static_cast<uint64_t>(Flag);
276 bool IsCommon = std::is_same<SecCommonFlags, SecFlagType>();
277 return Entry.Flags & (IsCommon ? FVal : (FVal << 32));
324 if (
F.getAsInteger(10, Hash))
344 if (
LHS.second !=
RHS.second)
345 return LHS.second >
RHS.second;
347 return LHS.first <
RHS.first;
383 uint64_t &TargetSamples = CallTargets[
F];
395 auto I = CallTargets.
find(
F);
396 if (
I != CallTargets.
end()) {
414 for (
const auto &
I : CallTargets)
422 for (
const auto &[
Target, Frequency] : Targets) {
423 SortedTargets.emplace(
Target, Frequency);
425 return SortedTargets;
430 float DistributionFactor) {
432 for (
const auto &[
Target, Frequency] : Targets) {
433 AdjustedTargets[
Target] = Frequency * DistributionFactor;
435 return AdjustedTargets;
445 return NumSamples ==
Other.NumSamples && CallTargets ==
Other.CallTargets;
449 return !(*
this ==
Other);
492 return !(*
this == That);
495 std::string
toString(
bool OutputLineLocation)
const {
496 std::ostringstream OContextStr;
498 if (OutputLineLocation) {
503 return OContextStr.str();
537 assert(!Name.empty() &&
"Name is empty");
551 std::list<SampleContextFrameVector> &CSNameTable,
562 CSNameTable.emplace_back();
574 ContextStr = ContextStr.
substr(1, ContextStr.
size() - 2);
578 while (!ContextRemain.
empty()) {
579 auto ContextSplit = ContextRemain.
split(
" @ ");
580 ChildContext = ContextSplit.first;
581 ContextRemain = ContextSplit.second;
584 Context.emplace_back(CalleeName, CallSiteLoc);
593 auto EntrySplit = ContextStr.
split(
':');
594 FName = EntrySplit.first;
597 if (!EntrySplit.second.empty()) {
601 auto LocSplit = EntrySplit.second.split(
'.');
602 LocSplit.first.getAsInteger(10, LineOffset);
606 if (!LocSplit.second.empty())
625 bool IncludeLeafLineLocation =
false) {
626 std::ostringstream OContextStr;
628 if (OContextStr.str().size()) {
629 OContextStr <<
" @ ";
632 IncludeLeafLineLocation);
634 return OContextStr.str();
663 Name =
Context.back().FuncName;
668 return State == That.State && Name == That.Name &&
669 FullContext == That.FullContext;
675 if (State != That.State)
676 return State < That.State;
679 return Name < That.Name;
683 while (
I < std::min(FullContext.
size(), That.FullContext.
size())) {
684 auto &Context1 = FullContext[
I];
685 auto &Context2 = That.FullContext[
I];
686 auto V = Context1.FuncName.compare(Context2.FuncName);
689 if (Context1.Location != Context2.Location)
690 return Context1.Location < Context2.Location;
694 return FullContext.
size() < That.FullContext.
size();
704 auto ThisContext = FullContext;
705 auto ThatContext = That.FullContext;
706 if (ThatContext.size() < ThisContext.size())
708 ThatContext = ThatContext.
take_front(ThisContext.size());
710 if (ThisContext.back().FuncName != ThatContext.back().FuncName)
744 std::unordered_map<LineLocation, LineLocation, LineLocationHash>;
767 if (TotalSamples < Num)
787 return BodySamples[
LineLocation(LineOffset, Discriminator)].addSamples(
795 return BodySamples[
LineLocation(LineOffset, Discriminator)].addCalledTarget(
801 return BodySamples[Location].merge(
SampleRecord, Weight);
810 auto I = BodySamples.find(
LineLocation(LineOffset, Discriminator));
811 if (
I != BodySamples.end()) {
812 Count =
I->second.removeCalledTarget(FName);
813 Count =
I->second.removeSamples(Count);
814 if (!
I->second.getSamples())
815 BodySamples.erase(
I);
823 CallsiteSamples.clear();
828 for (
auto &
I : BodySamples) {
829 uint64_t TargetSamples =
I.second.getCallTargetSum();
834 if (TargetSamples >
I.second.getSamples())
835 I.second.addSamples(TargetSamples -
I.second.getSamples());
842 for (
const auto &
I : BodySamples)
845 for (
auto &
I : CallsiteSamples) {
846 for (
auto &CS :
I.second) {
847 CS.second.updateTotalSamples();
856 for (
auto &
I : CallsiteSamples) {
857 for (
auto &CS :
I.second) {
858 CS.second.SetContextSynthetic();
867 if (!IRToProfileLocationMap)
869 const auto &ProfileLoc = IRToProfileLocationMap->find(IRLoc);
870 if (ProfileLoc != IRToProfileLocationMap->end())
871 return ProfileLoc->second;
881 const auto &ret = BodySamples.find(
883 if (ret == BodySamples.end())
884 return std::error_code();
885 return ret->second.getSamples();
893 const auto &ret = BodySamples.find(
895 if (ret == BodySamples.end())
896 return std::error_code();
897 return ret->second.getCallTargets();
905 if (Ret == BodySamples.end())
906 return std::error_code();
907 return Ret->second.getCallTargets();
919 if (iter == CallsiteSamples.end())
921 return &iter->second;
934 bool empty()
const {
return TotalSamples == 0; }
961 if (!BodySamples.empty() &&
962 (CallsiteSamples.empty() ||
963 BodySamples.begin()->first < CallsiteSamples.begin()->first))
964 Count = BodySamples.begin()->second.getSamples();
965 else if (!CallsiteSamples.empty()) {
968 for (
const auto &N_FS : CallsiteSamples.begin()->second)
969 Count += N_FS.second.getHeadSamplesEstimate();
972 return Count ? Count : TotalSamples > 0;
980 return CallsiteSamples;
990 MaxCount = std::max(MaxCount, L.second.getSamples());
994 for (
const FunctionSamplesMap::value_type &
F :
C.second)
995 MaxCount = std::max(MaxCount,
F.second.getMaxCountInside());
1006 Context =
Other.getContext();
1007 if (FunctionHash == 0) {
1009 FunctionHash =
Other.getFunctionHash();
1010 }
else if (FunctionHash !=
Other.getFunctionHash()) {
1023 for (
const auto &
I :
Other.getBodySamples()) {
1028 for (
const auto &
I :
Other.getCallsiteSamples()) {
1031 for (
const auto &Rec :
I.second)
1032 MergeResult(Result, FSMap[Rec.first].merge(Rec.second, Weight));
1044 if (TotalSamples <= Threshold)
1046 auto isDeclaration = [](
const Function *
F) {
1047 return !
F ||
F->isDeclaration();
1055 for (
const auto &BS : BodySamples)
1056 for (
const auto &TS : BS.second.getCallTargets())
1057 if (TS.getValue() > Threshold) {
1059 if (isDeclaration(Callee))
1062 for (
const auto &CS : CallsiteSamples)
1063 for (
const auto &NameFS : CS.second)
1064 NameFS.second.findInlinedFunctions(S, SymbolMap, Threshold);
1081 assert(IRToProfileLocationMap ==
nullptr &&
"this should be set only once");
1082 IRToProfileLocationMap = LTLM;
1088 auto AttrName =
"sample-profile-suffix-elision-policy";
1089 auto Attr =
F.getFnAttribute(AttrName).getValueAsString();
1105 if (Attr ==
"" || Attr ==
"all") {
1106 return FnName.
split(
'.').first;
1107 }
else if (Attr ==
"selected") {
1109 for (
const auto &Suf : knownSuffixes) {
1115 auto It = Cand.
rfind(Suffix);
1118 auto Dit = Cand.
rfind(
'.');
1119 if (Dit == It + Suffix.
size() - 1)
1120 Cand = Cand.
substr(0, It);
1123 }
else if (Attr ==
"none") {
1126 assert(
false &&
"internal error: unknown suffix elision policy");
1215 FunctionHash ==
Other.FunctionHash && Context ==
Other.Context &&
1216 TotalSamples ==
Other.TotalSamples &&
1217 TotalHeadSamples ==
Other.TotalHeadSamples &&
1218 BodySamples ==
Other.BodySamples &&
1219 CallsiteSamples ==
Other.CallsiteSamples;
1223 return !(*
this ==
Other);
1226 template <
typename T>
1289 const LocToLocMap *IRToProfileLocationMap =
nullptr;
1314template <
template <
typename,
typename,
typename...>
typename MapT,
1315 typename KeyT,
typename ValueT,
typename... MapTArgs>
1327 template <
typename... Ts>
1332 return base_type::try_emplace(Hash, std::forward<Ts>(Args)...);
1335 template <
typename... Ts>
1339 return try_emplace(Hash, Key, std::forward<Ts>(Args)...);
1342 template <
typename... Ts> std::pair<iterator, bool>
emplace(Ts &&...Args) {
1352 auto It = base_type::find(Hash);
1353 if (It != base_type::end())
1355 return base_type::end();
1360 auto It = base_type::find(Hash);
1361 if (It != base_type::end())
1363 return base_type::end();
1367 auto It =
find(Ctx);
1368 if (It != base_type::end()) {
1369 base_type::erase(It);
1382 :
public HashKeyMap<std::unordered_map, SampleContext, FunctionSamples> {
1389 Ret.first->second.setContext(Ctx);
1390 return Ret.first->second;
1419 std::vector<NameFunctionSamples> &SortedProfiles);
1431 for (
const auto &
I : Samples)
1434 return A->first <
B->first;
1458 bool TrimColdContext,
1459 bool MergeColdContext,
1461 bool TrimBaseProfileOnly);
1497 bool ProfileIsCS =
false) {
1500 ProfileMap = std::move(TmpProfiles);
1505 bool ProfileIsCS =
false) {
1507 for (
const auto &
I : InputProfiles) {
1514 for (
const auto &
I : InputProfiles)
1515 flattenNestedProfile(OutputProfiles,
I.second);
1525 auto Ret = OutputProfiles.
try_emplace(Context, FS);
1530 Profile.removeAllCallsiteSamples();
1540 "There should be no inlinees' profiles after flattening.");
1546 uint64_t TotalSamples =
FS.getTotalSamples();
1548 for (
const auto &
I :
FS.getCallsiteSamples()) {
1549 for (
const auto &Callee :
I.second) {
1550 const auto &CalleeProfile =
Callee.second;
1552 Profile.addBodySamples(
I.first.LineOffset,
I.first.Discriminator,
1553 CalleeProfile.getHeadSamplesEstimate());
1555 Profile.addCalledTargetSamples(
1556 I.first.LineOffset,
I.first.Discriminator, CalleeProfile.getName(),
1557 CalleeProfile.getHeadSamplesEstimate());
1559 TotalSamples = TotalSamples >= CalleeProfile.getTotalSamples()
1560 ? TotalSamples - CalleeProfile.getTotalSamples()
1562 TotalSamples += CalleeProfile.getHeadSamplesEstimate();
1564 flattenNestedProfile(OutputProfiles, CalleeProfile);
1567 Profile.addTotalSamples(TotalSamples);
1574 FrameNode *getOrCreateContextPath(
const SampleContext &Context);
1576 SampleProfileMap &ProfileMap;
1577 FrameNode RootFrame;
1593 Syms.insert(
Name.copy(Allocator));
1603 unsigned size() {
return Syms.size(); }
1616 bool ToCompress =
false;
1623using namespace sampleprof;
1654 return toString(IntHash, 10,
false)
This file defines the StringMap class.
This file defines the BumpPtrAllocator interface.
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
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")
This file defines the DenseSet and SmallDenseSet classes.
Provides ErrorOr<T> smart pointer.
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)
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
This file defines the SmallVector class.
Class for arbitrary precision integers.
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.
Allocate memory in an ever growing pool, as if by bump-pointer.
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.
GUID getGUID() const
Return a 64-bit global unique ID constructed from global value name (i.e.
void update(ArrayRef< uint8_t > Data)
Updates the hash for the byte stream provided.
static void stringifyResult(MD5Result &Result, SmallVectorImpl< char > &Str)
Translates the bytes in Res to a hex string that is deposited into Str.
void final(MD5Result &Result)
Finishes off the hash and puts the result in result.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
iterator find(StringRef Key)
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.
std::string str() const
str - Get the contents as an std::string.
constexpr StringRef substr(size_t Start, size_t N=npos) const
Return a reference to the substring from [Start, Start + N).
constexpr bool empty() const
empty - Check if the string is empty.
constexpr size_t size() const
size - Get the string size.
bool startswith(StringRef Prefix) const
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.
Representation of the samples collected for a function.
void setTotalSamples(uint64_t Num)
static bool ProfileIsPreInlined
void setName(StringRef FunctionName)
Set the name of the function.
bool operator!=(const FunctionSamples &Other) const
void updateTotalSamples()
void setHeadSamples(uint64_t Num)
sampleprof_error addTotalSamples(uint64_t Num, uint64_t Weight=1)
static uint64_t getGUID(StringRef Name)
static constexpr const char * UniqSuffix
void updateCallsiteSamples()
static StringRef getCanonicalFnName(StringRef FnName, StringRef Attr="selected")
ErrorOr< SampleRecord::CallTargetMap > findCallTargetMapAt(uint32_t LineOffset, uint32_t Discriminator) const
Returns the call target map collected at a given location.
bool operator==(const FunctionSamples &Other) const
static constexpr const char * PartSuffix
const FunctionSamplesMap * findFunctionSamplesMapAt(const LineLocation &Loc) const
Returns the FunctionSamplesMap at the given Loc.
void findInlinedFunctions(DenseSet< GlobalValue::GUID > &S, const StringMap< Function * > &SymbolMap, uint64_t Threshold) const
Recursively traverses all children, if the total sample count of the corresponding function is no les...
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...
ErrorOr< uint64_t > findSamplesAt(uint32_t LineOffset, uint32_t Discriminator) const
Return the number of samples collected at the given location.
ErrorOr< 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
uint64_t getFunctionHash() const
static constexpr const char * LLVMSuffix
Name suffixes which canonicalization should handle to avoid profile mismatch.
void findAllNames(DenseSet< StringRef > &NameSet) const
StringRef getFuncName(StringRef Name) const
Translate Name into its original name.
sampleprof_error addHeadSamples(uint64_t Num, uint64_t Weight=1)
sampleprof_error addSampleRecord(LineLocation Location, const SampleRecord &SampleRecord, uint64_t Weight=1)
const FunctionSamples * findFunctionSamplesAt(const LineLocation &Loc, StringRef CalleeName, SampleProfileReaderItaniumRemapper *Remapper) const
Returns a pointer to FunctionSamples at the given callsite location Loc with callee CalleeName.
DenseMap< uint64_t, StringRef > * GUIDToFuncNameMap
GUIDToFuncNameMap saves the mapping from GUID to the symbol name, for all the function symbols define...
FunctionSamplesMap & functionSamplesAt(const LineLocation &Loc)
Return the function samples at the given callsite location.
static 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.
static uint64_t getCallSiteHash(StringRef CalleeName, const LineLocation &Callsite)
Returns a unique hash code for a combination of a callsite location and the callee function name.
sampleprof_error addBodySamples(uint32_t LineOffset, uint32_t Discriminator, uint64_t Num, uint64_t Weight=1)
static unsigned getOffset(const DILocation *DIL)
Returns the line offset to the start line of the subprogram.
void setFunctionHash(uint64_t Hash)
uint64_t removeCalledTargetAndBodySample(uint32_t LineOffset, uint32_t Discriminator, StringRef FName)
static bool ProfileIsFS
If this profile uses flow sensitive discriminators.
sampleprof_error addCalledTargetSamples(uint32_t LineOffset, uint32_t Discriminator, StringRef FName, uint64_t Num, uint64_t Weight=1)
SampleContext & getContext() const
static 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.
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.
void setContext(const SampleContext &FContext)
void SetContextSynthetic()
static 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.
const FunctionSamples * findFunctionSamples(const DILocation *DIL, SampleProfileReaderItaniumRemapper *Remapper=nullptr) const
Get the FunctionSamples of the inline instance where DIL originates from.
StringRef getName() const
Return the function name.
const BodySampleMap & getBodySamples() const
Return all the samples collected in the body of the function.
static 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...
std::pair< iterator, bool > emplace(Ts &&...Args)
std::pair< iterator, bool > try_emplace(const key_type &Hash, const original_key_type &Key, Ts &&...Args)
typename base_type::iterator iterator
const_iterator find(const original_key_type &Key) const
typename base_type::value_type value_type
std::pair< iterator, bool > try_emplace(const original_key_type &Key, Ts &&...Args)
MapT< hash_code, ValueT, MapTArgs... > base_type
size_t erase(const original_key_type &Ctx)
mapped_type & operator[](const original_key_type &Key)
iterator find(const original_key_type &Key)
typename base_type::const_iterator const_iterator
Helper class for profile conversion.
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)
std::error_code write(raw_ostream &OS)
void dump(raw_ostream &OS=dbgs()) const
void merge(const ProfileSymbolList &List)
bool contains(StringRef Name)
void add(StringRef Name, bool copy=false)
copy indicates whether we need to copy the underlying memory for the input Name.
std::error_code read(const uint8_t *Data, uint64_t ListSize)
SampleContextTrimmer impelements helper functions to trim, merge cold context profiles.
SampleContextTrimmer(SampleProfileMap &Profiles)
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
SampleContext(SampleContextFrames Context, ContextStateMask CState=RawContext)
bool operator<(const SampleContext &That) const
StringRef getName() const
SampleContext(StringRef ContextStr, std::list< SampleContextFrameVector > &CSNameTable, ContextStateMask CState=RawContext)
bool hasState(ContextStateMask S)
void clearState(ContextStateMask S)
void setName(StringRef FunctionName)
Set the name of the function and clear the current context.
SampleContextFrames getContextFrames() const
bool isBaseContext() const
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)
static void decodeContextString(StringRef ContextStr, StringRef &FName, LineLocation &LineLoc)
uint32_t getAllAttributes()
void setAttribute(ContextAttributeMask A)
bool IsPrefixOf(const SampleContext &That) const
bool hasAttribute(ContextAttributeMask A)
std::string toString() const
SampleContext(StringRef Name)
This class provides operator overloads to the map container using MD5 as the key type,...
iterator find(const SampleContext &Ctx)
size_t erase(const key_type &Key)
const_iterator find(const SampleContext &Ctx) const
mapped_type & Create(const SampleContext &Ctx)
iterator find(StringRef Fname)
size_t erase(const SampleContext &Ctx)
SampleProfileReaderItaniumRemapper remaps the profile data from a sample profile data reader,...
Representation of a single sample record.
bool hasCalls() const
Return true if this sample record contains function calls.
sampleprof_error merge(const SampleRecord &Other, uint64_t Weight=1)
Merge the samples in Other into this record.
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.
sampleprof_error addCalledTarget(StringRef F, uint64_t S, uint64_t Weight=1)
Add called function F with samples S.
std::pair< StringRef, uint64_t > CallTarget
StringMap< uint64_t > CallTargetMap
static const SortedCallTargetSet SortCallTargets(const CallTargetMap &Targets)
Sort call targets in descending order of call frequency.
const SortedCallTargetSet getSortedCallTargets() const
static const CallTargetMap adjustCallTargets(const CallTargetMap &Targets, float DistributionFactor)
Prorate call targets by a distribution factor.
bool operator!=(const SampleRecord &Other) const
bool operator==(const SampleRecord &Other) const
uint64_t removeCalledTarget(StringRef F)
Remove called function from the call target map.
void print(raw_ostream &OS, unsigned Indent) const
Print the sample record to the stream OS indented by Indent.
Sort a LocationT->SampleT map by LocationT.
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.
std::optional< const char * > toString(const std::optional< DWARFFormValue > &V)
Take an optional DWARFFormValue and try to extract a string value from it.
static void verifySecFlag(SecType Type, SecFlagType Flag)
ArrayRef< SampleContextFrame > SampleContextFrames
static uint64_t hashFuncName(StringRef F)
void sortFuncProfiles(const SampleProfileMap &ProfileMap, std::vector< NameFunctionSamples > &SortedProfiles)
static uint64_t SPMagic(SampleProfileFormat Format=SPF_Binary)
std::unordered_map< LineLocation, LineLocation, LineLocationHash > LocToLocMap
std::pair< hash_code, const FunctionSamples * > NameFunctionSamples
static void addSecFlag(SecHdrTableEntry &Entry, SecFlagType Flag)
raw_ostream & operator<<(raw_ostream &OS, const LineLocation &Loc)
static bool hasSecFlag(const SecHdrTableEntry &Entry, SecFlagType Flag)
std::map< LineLocation, FunctionSamplesMap > CallsiteSampleMap
@ ContextDuplicatedIntoBase
static StringRef getRepInFormat(StringRef Name, bool UseMD5, std::string &GUIDBuf)
Get the proper representation of a string according to whether the current Format uses MD5 to represe...
std::map< LineLocation, SampleRecord > BodySampleMap
@ SecFlagIsPreInlined
SecFlagIsPreInlined means this profile contains ShouldBeInlined contexts thus this is CS preinliner c...
@ 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)
static hash_code hash_value(const SampleContextFrame &arg)
static std::string getSecName(SecType Type)
std::map< std::string, FunctionSamples, std::less<> > FunctionSamplesMap
static uint64_t SPVersion()
This is an optimization pass for GlobalISel generic memory operations.
void stable_sort(R &&Range)
std::error_code make_error_code(BitcodeError E)
@ unsupported_writing_format
@ ostream_seek_unsupported
raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
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.
const std::error_category & sampleprof_category()
std::string getUniqueInternalLinkagePostfix(const StringRef &FName)
sampleprof_error MergeResult(sampleprof_error &Accumulator, sampleprof_error Result)
OutputIt copy(R &&Range, OutputIt Out)
uint64_t MD5Hash(StringRef Str)
Helper to compute and return lower 64 bits of the given string's MD5 hash.
hash_code hash_combine(const Ts &...args)
Combine values into a single hash_code.
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.
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
bool operator==(const LineLocation &O) const
FrameNode * getOrCreateChildFrame(const LineLocation &CallSite, StringRef CalleeName)
FrameNode(StringRef FName=StringRef(), FunctionSamples *FSamples=nullptr, LineLocation CallLoc={0, 0})
FunctionSamples * FuncSamples
std::map< uint64_t, FrameNode > AllChildFrames
uint64_t operator()(const SampleContextFrameVector &S) const
bool operator==(const SampleContextFrame &That) const
bool operator!=(const SampleContextFrame &That) const
std::string toString(bool OutputLineLocation) const
SampleContextFrame(StringRef FuncName, LineLocation Location)
uint64_t operator()(const SampleContext &Context) const
bool operator()(const CallTarget &LHS, const CallTarget &RHS) const