45#include <system_error> 
   51#define DEBUG_TYPE "samplepgo-reader" 
   58    cl::desc(
"Profile uses flow sensitive discriminators"));
 
   66  OS << 
"Function: " << FS.getContext().toString() << 
": " << FS;
 
 
   71  std::vector<NameFunctionSamples> V;
 
   73  for (
const auto &
I : V)
 
 
   80    for (
const auto &
I : BodySamples) {
 
   85        if (
Loc.Discriminator)
 
   90        if (!CallTargets.empty()) {
 
   92            for (
const auto &J : CallTargets) {
 
  105    for (
const auto &
I : CallsiteSamples)
 
  106      for (
const auto &FS : 
I.second) {
 
  111          if (
Loc.Discriminator)
 
  126    if (!BodySamples.empty())
 
  130    if (!CallsiteSamples.empty())
 
  132                         [&] { DumpCallsiteSamples(CallsiteSamples); });
 
 
  138  std::vector<NameFunctionSamples> V;
 
  142  for (
const auto &
F : V)
 
 
  161  size_t n2 = 
Input.rfind(
':');
 
  162  size_t n1 = 
Input.rfind(
':', n2 - 1);
 
  163  FName = 
Input.substr(0, n1);
 
  164  if (
Input.substr(n1 + 1, n2 - n1 - 1).getAsInteger(10, NumSamples))
 
  166  if (
Input.substr(n2 + 1).getAsInteger(10, NumHeadSamples))
 
 
  183  if (
Input.starts_with(
"!CFGChecksum:")) {
 
  188  if (
Input.starts_with(
"!Attributes:")) {
 
 
  208    size_t ColonIndex = 
Input.find(
':', Index);
 
  213    size_t CountStartIndex = ColonIndex + 1;
 
  215    size_t NextIndex = 
Input.find_first_of(
' ', CountStartIndex);
 
  217    if (
Input.substr(CountStartIndex, NextIndex - CountStartIndex)
 
  218            .getAsInteger(10, 
Count))
 
  226                : 
Input.find_first_not_of(
' ', NextIndex);
 
 
  267  size_t n1 = 
Input.find(
':');
 
  269  size_t n2 = 
Loc.find(
'.');
 
  275    if (
Loc.substr(0, n2).getAsInteger(10, LineOffset))
 
  277    if (
Loc.substr(n2 + 1).getAsInteger(10, Discriminator))
 
  284    size_t n3 = Rest.
find(
' ');
 
  334      if (n4 == Rest.
size())
 
  346    CalleeName = Rest.
substr(0, n3);
 
 
  364  uint32_t TopLevelProbeProfileCount = 0;
 
  370  std::vector<SampleContext *> FlatSamples;
 
  376    if (pos == LineIt->
npos || (*LineIt)[pos] == 
'#')
 
  390    if ((*LineIt)[0] != 
' ') {
 
  391      uint64_t NumSamples, NumHeadSamples;
 
  393      if (!
ParseHead(*LineIt, FName, NumSamples, NumHeadSamples)) {
 
  395                    "Expected 'mangled_name:NUM:NUM', found " + *LineIt);
 
  421                     FunctionHash, Attributes, IsFlat)) {
 
  425                      "Cannot parse metadata: " + *LineIt);
 
  429                      "Expected 'vtables [mangled_vtable:NUM]+', found " +
 
  434                      "Expected 'NUM[.NUM]: NUM[ mangled_name:NUM]*', found " +
 
  442                    "Found non-metadata after metadata: " + *LineIt);
 
  465            Result, InlineStack.
back()->addCallsiteVTableTypeProfAt(
 
  472        for (
const auto &name_count : TargetCountMap) {
 
  474                                            LineOffset, Discriminator,
 
  488            ++TopLevelProbeProfileCount;
 
  493        DepthMetadata = 
Depth;
 
  496            FlatSamples.push_back(&FProfile.
getContext());
 
  500                "!Flat may only be used at top level function.", 
DS_Warning));
 
  515         "Cannot have both context-sensitive and regular profile");
 
  517  assert((TopLevelProbeProfileCount == 0 ||
 
  518          TopLevelProbeProfileCount == 
Profiles.size()) &&
 
  519         "Cannot have both probe-based profiles and regular profiles");
 
 
  537    if ((*LineIt)[0] != 
' ') {
 
  538      uint64_t NumSamples, NumHeadSamples;
 
  540      result = 
ParseHead(*LineIt, FName, NumSamples, NumHeadSamples);
 
 
  548  unsigned NumBytesRead = 0;
 
  551  if (Val > std::numeric_limits<T>::max()) {
 
  555  } 
else if (
Data + NumBytesRead > 
End) {
 
  561  Data += NumBytesRead;
 
  562  return static_cast<T>(Val);
 
 
  567  if (
Data + Str.size() + 1 > 
End) {
 
  573  Data += Str.size() + 1;
 
 
  593  if (std::error_code EC = Idx.getError())
 
  595  if (*Idx >= Table.size())
 
 
  603  if (std::error_code EC = Idx.getError())
 
 
  613  if (std::error_code EC = ContextIdx.getError())
 
  618    *RetIdx = *ContextIdx;
 
 
  628    if (std::error_code EC = FContext.getError())
 
  633    if (std::error_code EC = FName.getError())
 
  645    Hash = Context.getHashCode();
 
  648  return std::make_pair(Context, Hash);
 
 
  654  if (std::error_code EC = NumVTableTypes.getError())
 
  659    if (std::error_code EC = VTableType.getError())
 
  663    if (std::error_code EC = VTableSamples.getError())
 
  668    if (!
M.insert(std::make_pair(*VTableType, *VTableSamples)).second) {
 
  670          Buffer->getBufferIdentifier(), 0,
 
  671          "Duplicate vtable type " + VTableType->str() +
 
  672              " at the same location. Additional counters will be ignored.",
 
 
  683         "Cannot read vtable profiles if ReadVTableProf is false");
 
  687  if (std::error_code EC = NumCallsites.getError())
 
  692    if (std::error_code EC = LineOffset.getError())
 
  699    if (std::error_code EC = Discriminator.getError())
 
 
  715  if (std::error_code EC = NumSamples.getError())
 
  721  if (std::error_code EC = NumRecords.getError())
 
  726    if (std::error_code EC = LineOffset.getError())
 
  734    if (std::error_code EC = Discriminator.getError())
 
  738    if (std::error_code EC = NumSamples.getError())
 
  742    if (std::error_code EC = NumCalls.getError())
 
  748    for (
uint32_t J = 0; J < *NumCalls; ++J) {
 
  750      if (std::error_code EC = CalledFunction.getError())
 
  754      if (std::error_code EC = CalledFunctionSamples.getError())
 
  758                                      *CalledFunction, *CalledFunctionSamples);
 
  761    FProfile.
addBodySamples(*LineOffset, DiscriminatorVal, *NumSamples);
 
  766  if (std::error_code EC = NumCallsites.getError())
 
  769  for (
uint32_t J = 0; J < *NumCallsites; ++J) {
 
  771    if (std::error_code EC = LineOffset.getError())
 
  775    if (std::error_code EC = Discriminator.getError())
 
  779    if (std::error_code EC = FName.getError())
 
  788    if (std::error_code EC = 
readProfile(CalleeProfile))
 
 
  803  if (std::error_code EC = NumHeadSamples.getError())
 
  807  if (std::error_code EC = FContextHash.getError())
 
  810  auto &[FContext, Hash] = *FContextHash;
 
  817  if (FContext.hasContext())
 
 
  845  switch (Entry.Type) {
 
  850      Summary->setPartialProfile(
true);
 
  861    bool FixedLengthMD5 =
 
  891             "func offset table should always be sorted in CS profile");
 
 
  961      ProfilesToReadMetadata.
insert(&
I->second);
 
  964  if (std::error_code EC =
 
  986  if (std::error_code EC = 
Size.getError())
 
  990  if (UseFuncOffsetList)
 
  997    if (std::error_code EC = FContextHash.getError())
 
 1000    auto &[FContext, Hash] = *FContextHash;
 
 1002    if (std::error_code EC = 
Offset.getError())
 
 1005    if (UseFuncOffsetList)
 
 
 1043      const auto &FContext = NameOffset.first;
 
 1055        if (!CommonContext || !CommonContext->
isPrefixOf(FContext))
 
 1056          CommonContext = &FContext;
 
 1059      if (CommonContext == &FContext ||
 
 1060          (CommonContext && CommonContext->
isPrefixOf(FContext))) {
 
 1063        const uint8_t *FuncProfileAddr = Start + NameOffset.second;
 
 1075      const uint8_t *FuncProfileAddr = Start + iter->second;
 
 1084      StringRef FuncNameStr = FuncName.stringRef();
 
 1087      const uint8_t *FuncProfileAddr = Start + NameOffset.second;
 
 1098      const uint8_t *FuncProfileAddr = Start + iter->second;
 
 
 1118  if (!LoadFuncsToBeUsed) {
 
 1131         "Cannot have both context-sensitive and regular profile");
 
 1133         "Section flag should be consistent with actual profile");
 
 
 1139    ProfSymList = std::make_unique<ProfileSymbolList>();
 
 
 1148std::error_code SampleProfileReaderExtBinaryBase::decompressSection(
 
 1152  End = SecStart + SecSize;
 
 1154  if (std::error_code EC = DecompressSize.getError())
 
 1156  DecompressBufSize = *DecompressSize;
 
 1159  if (std::error_code EC = CompressSize.getError())
 
 1166  size_t UCSize = DecompressBufSize;
 
 1177      reinterpret_cast<const uint8_t *
>(
Buffer->getBufferStart());
 
 1188    const uint8_t *SecStart = BufStart + Entry.Offset;
 
 1199      if (std::error_code EC = decompressSection(
 
 1200              SecStart, SecSize, DecompressBuf, DecompressBufSize))
 
 1202      SecStart = DecompressBuf;
 
 1203      SecSize = DecompressBufSize;
 
 1206    if (std::error_code EC = 
readOneSection(SecStart, SecSize, Entry))
 
 1208    if (
Data != SecStart + SecSize)
 
 1213      Data = BufStart + Entry.Offset;
 
 1214      End = BufStart + 
Buffer->getBufferSize();
 
 
 1221std::error_code SampleProfileReaderRawBinary::verifySPMagic(
uint64_t Magic) {
 
 1227std::error_code SampleProfileReaderExtBinary::verifySPMagic(
uint64_t Magic) {
 
 1235  if (std::error_code EC = 
Size.getError())
 
 1256  for (
size_t I = 0; 
I < *
Size; ++
I) {
 
 1258    if (std::error_code EC = Name.getError())
 
 
 1275                                                   bool FixedLengthMD5) {
 
 1276  if (FixedLengthMD5) {
 
 1278      errs() << 
"If FixedLengthMD5 is true, UseMD5 has to be true";
 
 1280    if (std::error_code EC = 
Size.getError())
 
 1284           "Fixed length MD5 name table does not contain specified number of " 
 1291    for (
size_t I = 0; 
I < *
Size; ++
I) {
 
 1304    assert(!FixedLengthMD5 && 
"FixedLengthMD5 should be unreachable here");
 
 1306    if (std::error_code EC = 
Size.getError())
 
 1313    for (
size_t I = 0; 
I < *
Size; ++
I) {
 
 1315      if (std::error_code EC = FID.getError())
 
 
 1335  if (std::error_code EC = 
Size.getError())
 
 1348  for (
size_t I = 0; 
I < *
Size; ++
I) {
 
 1351    if (std::error_code EC = ContextSize.getError())
 
 1353    for (
uint32_t J = 0; J < *ContextSize; ++J) {
 
 1355      if (std::error_code EC = FName.getError())
 
 1358      if (std::error_code EC = LineOffset.getError())
 
 1365      if (std::error_code EC = Discriminator.getError())
 
 1369          FName.get(), 
LineLocation(LineOffset.get(), Discriminator.get()));
 
 
 1382      if (std::error_code EC = Checksum.getError())
 
 1390      if (std::error_code EC = Attributes.getError())
 
 1399      if (std::error_code EC = NumCallsites.getError())
 
 1402      for (
uint32_t J = 0; J < *NumCallsites; ++J) {
 
 1404        if (std::error_code EC = LineOffset.getError())
 
 1408        if (std::error_code EC = Discriminator.getError())
 
 1412        if (std::error_code EC = FContextHash.getError())
 
 1415        auto &[FContext, Hash] = *FContextHash;
 
 1421                  *Discriminator))[FContext.getFunction()]);
 
 1423        if (std::error_code EC =
 
 
 1443    Data = R->second.first;
 
 1444    End = R->second.second;
 
 
 1456    if (std::error_code EC = FContextHash.getError())
 
 1458    auto &[FContext, Hash] = *FContextHash;
 
 1462      FProfile = &It->second;
 
 
 1479  if (std::error_code EC = 
Type.getError())
 
 1481  Entry.Type = 
static_cast<SecType>(*Type);
 
 1484  if (std::error_code EC = Flags.getError())
 
 1486  Entry.Flags = *Flags;
 
 1489  if (std::error_code EC = 
Offset.getError())
 
 1494  if (std::error_code EC = 
Size.getError())
 
 1498  Entry.LayoutIndex = Idx;
 
 
 1505  if (std::error_code EC = EntryNum.getError())
 
 1508  for (
uint64_t i = 0; i < (*EntryNum); i++)
 
 
 1517      reinterpret_cast<const uint8_t *
>(
Buffer->getBufferStart());
 
 1519  End = BufStart + 
Buffer->getBufferSize();
 
 
 1533    if (Entry.Type == 
Type)
 
 
 1547    FileSize = std::max(Entry.Offset + Entry.Size, FileSize);
 
 
 1555    Flags.append(
"{compressed,");
 
 1560    Flags.append(
"flat,");
 
 1562  switch (Entry.Type) {
 
 1565      Flags.append(
"fixlenmd5,");
 
 1567      Flags.append(
"md5,");
 
 1569      Flags.append(
"uniq,");
 
 1573      Flags.append(
"partial,");
 
 1575      Flags.append(
"context,");
 
 1577      Flags.append(
"preInlined,");
 
 1579      Flags.append(
"fs-discriminator,");
 
 1583      Flags.append(
"ordered,");
 
 1587      Flags.append(
"probe,");
 
 1589      Flags.append(
"attr,");
 
 1594  char &last = Flags.back();
 
 
 1605    OS << 
getSecName(Entry.Type) << 
" - Offset: " << Entry.Offset
 
 1606       << 
", Size: " << Entry.Size << 
", Flags: " << 
getSecFlagsStr(Entry)
 
 1609    TotalSecsSize += Entry.Size;
 
 1613         "Size of 'header + sections' doesn't match the total size of profile");
 
 1615  OS << 
"Header Size: " << HeaderSize << 
"\n";
 
 1616  OS << 
"Total Sections Size: " << TotalSecsSize << 
"\n";
 
 
 1624  if (std::error_code EC = Magic.getError())
 
 1626  else if (std::error_code EC = verifySPMagic(*Magic))
 
 1631  if (std::error_code EC = 
Version.getError())
 
 
 1654std::error_code SampleProfileReaderBinary::readSummaryEntry(
 
 1655    std::vector<ProfileSummaryEntry> &Entries) {
 
 1657  if (std::error_code EC = Cutoff.getError())
 
 1661  if (std::error_code EC = MinBlockCount.getError())
 
 1665  if (std::error_code EC = NumBlocks.getError())
 
 1668  Entries.emplace_back(*Cutoff, *MinBlockCount, *NumBlocks);
 
 1674  if (std::error_code EC = TotalCount.getError())
 
 1678  if (std::error_code EC = MaxBlockCount.getError())
 
 1682  if (std::error_code EC = MaxFunctionCount.getError())
 
 1686  if (std::error_code EC = NumBlocks.getError())
 
 1690  if (std::error_code EC = NumFunctions.getError())
 
 1694  if (std::error_code EC = NumSummaryEntries.getError())
 
 1697  std::vector<ProfileSummaryEntry> Entries;
 
 1698  for (
unsigned i = 0; i < *NumSummaryEntries; i++) {
 
 1699    std::error_code EC = readSummaryEntry(Entries);
 
 1703  Summary = std::make_unique<ProfileSummary>(
 
 1705      *MaxFunctionCount, *NumBlocks, *NumFunctions);
 
 
 1734    if (
GcovBuffer.readInt(Val) && Val <= std::numeric_limits<T>::max())
 
 1735      return static_cast<T>(Val);
 
 1736  } 
else if (
sizeof(
T) <= 
sizeof(
uint64_t)) {
 
 1738    if (
GcovBuffer.readInt64(Val) && Val <= std::numeric_limits<T>::max())
 
 1739      return static_cast<T>(Val);
 
 
 1801    Names.push_back(std::string(Str));
 
 
 1827  if (InlineStack.
size() == 0)
 
 1846  if (InlineStack.
size() == 0) {
 
 1894      for (
auto *CallerProfile : NewStack)
 
 1895        CallerProfile->addTotalSamples(
Count);
 
 1904    for (
uint32_t J = 0; J < NumTargets; J++) {
 
 
 1966  return Magic == 
"adcg*704";
 
 
 1972  if (Reader.useMD5()) {
 
 1974        Reader.getBuffer()->getBufferIdentifier(),
 
 1975        "Profile data remapping cannot be applied to profile data " 
 1976        "using MD5 names (original mangled names are not available).",
 
 1983  assert(Remappings && 
"should be initialized while creating remapper");
 
 1984  for (
auto &Sample : Reader.getProfiles()) {
 
 1986    Sample.second.findAllNames(NamesInSample);
 
 1987    for (
auto &Name : NamesInSample) {
 
 1989      if (
auto Key = Remappings->insert(NameStr))
 
 1990        NameMap.insert({
Key, NameStr});
 
 1994  RemappingApplied = 
true;
 
 
 1997std::optional<StringRef>
 
 1999  if (
auto Key = Remappings->lookup(Fname)) {
 
 2001    if (!Result.empty())
 
 2004  return std::nullopt;
 
 
 2013                                           : FS.getBufferForFile(Filename);
 
 2014  if (std::error_code EC = BufferOrErr.getError())
 
 2016  auto Buffer = std::move(BufferOrErr.get());
 
 2018  return std::move(Buffer);
 
 
 2032ErrorOr<std::unique_ptr<SampleProfileReader>>
 
 2037  if (std::error_code EC = BufferOrError.getError())
 
 2039  return create(BufferOrError.get(), 
C, FS, 
P, RemapFilename);
 
 
 2058  if (std::error_code EC = BufferOrError.getError())
 
 2060  return create(BufferOrError.get(), Reader, 
C);
 
 
 2077  auto Remappings = std::make_unique<SymbolRemappingReader>();
 
 2078  if (
Error E = Remappings->read(*
B)) {
 
 2082                                                 ParseError.getLineNum(),
 
 2083                                                 ParseError.getMessage()));
 
 2088  return std::make_unique<SampleProfileReaderItaniumRemapper>(
 
 2089      std::move(
B), std::move(Remappings), Reader);
 
 
 2107  std::unique_ptr<SampleProfileReader> Reader;
 
 2119  if (!RemapFilename.
empty()) {
 
 2121        RemapFilename, FS, *Reader, 
C);
 
 2122    if (std::error_code EC = ReaderOrErr.getError()) {
 
 2123      std::string Msg = 
"Could not create remapper: " + EC.message();
 
 2127    Reader->Remapper = std::move(ReaderOrErr.get());
 
 2130  if (std::error_code EC = Reader->readHeader()) {
 
 2134  Reader->setDiscriminatorMaskedBitFrom(
P);
 
 2136  return std::move(Reader);
 
 
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
This file defines the DenseMap class.
Provides ErrorOr<T> smart pointer.
Module.h This file contains the declarations for the Module class.
This file supports working with JSON data.
static bool ParseHead(const StringRef &Input, StringRef &FName, uint64_t &NumSamples, uint64_t &NumHeadSamples)
Parse Input as function head.
static void dumpFunctionProfileJson(const FunctionSamples &S, json::OStream &JOS, bool TopLevel=false)
static bool isOffsetLegal(unsigned L)
Returns true if line offset L is legal (only has 16 bits).
static bool ParseLine(const StringRef &Input, LineType &LineTy, uint32_t &Depth, uint64_t &NumSamples, uint32_t &LineOffset, uint32_t &Discriminator, StringRef &CalleeName, DenseMap< StringRef, uint64_t > &TargetCountMap, DenseMap< StringRef, uint64_t > &TypeCountMap, uint64_t &FunctionHash, uint32_t &Attributes, bool &IsFlat)
Parse Input as line sample.
static cl::opt< bool > ProfileIsFSDisciminator("profile-isfs", cl::Hidden, cl::init(false), cl::desc("Profile uses flow sensitive discriminators"))
static std::string getSecFlagsStr(const SecHdrTableEntry &Entry)
static bool parseTypeCountMap(StringRef Input, DenseMap< StringRef, uint64_t > &TypeCountMap)
static bool parseMetadata(const StringRef &Input, uint64_t &FunctionHash, uint32_t &Attributes)
Parse Input that contains metadata.
Defines the virtual file system interface vfs::FileSystem.
Implements a dense probed hash-table based set.
Diagnostic information for the sample profiler.
Represents either an error or a value T.
Lightweight error class with error context and mandatory checking.
Tagged union holding either a T or a Error.
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
This is an important class for using LLVM in a threaded context.
This interface provides simple read-only access to a block of memory, and provides simple methods for...
static ErrorOr< std::unique_ptr< MemoryBuffer > > getSTDIN()
Read all of stdin into a file buffer, and return it.
static LLVM_ABI const ArrayRef< uint32_t > DefaultCutoffs
A vector of useful cutoff values for detailed summary.
void push_back(const T &Elt)
StringRef - Represent a constant reference to a string, i.e.
bool getAsInteger(unsigned Radix, T &Result) const
Parse the current string as an integer of the specified radix.
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 find_last_of(char C, size_t From=npos) const
Find the last character in the string that is C, or npos if not found.
size_t find_first_of(char C, size_t From=0) const
Find the first character in the string that is C, or npos if not found.
size_t find(char C, size_t From=0) const
Search for the first character C in the string.
static constexpr size_t npos
LLVM_ABI size_t find_first_not_of(char C, size_t From=0) const
Find the first character in the string that is not C or npos if not found.
Target - Wrapper for Target specific information.
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.
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.
json::OStream allows writing well-formed JSON without materializing all structures as json::Value ahe...
void object(Block Contents)
Emit an object whose elements are emitted in the provided Block.
void attribute(llvm::StringRef Key, const Value &Contents)
Emit an attribute whose value is self-contained (number, vector<int> etc).
LLVM_ABI void arrayBegin()
void attributeArray(llvm::StringRef Key, Block Contents)
Emit an attribute whose value is an array with elements from the Block.
A forward iterator which reads text lines from a buffer.
int64_t line_number() const
Return the current line number. May return any number at EOF.
bool is_at_eof() const
Return true if we've reached EOF or are an "end" iterator.
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.
StringRef stringRef() const
Convert to StringRef.
uint64_t getHashCode() const
Get hash code of this object.
std::string str() const
Convert to a string, usually for output purpose.
Representation of the samples collected for a function.
static LLVM_ABI bool ProfileIsPreInlined
sampleprof_error addTotalSamples(uint64_t Num, uint64_t Weight=1)
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.
static LLVM_ABI bool ProfileIsCS
FunctionId getFunction() const
Return the function name.
sampleprof_error addHeadSamples(uint64_t Num, uint64_t Weight=1)
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.
static LLVM_ABI bool ProfileIsProbeBased
static StringRef getCanonicalFnName(const Function &F)
Return the canonical name for a function, taking into account suffix elision policy attributes.
sampleprof_error addBodySamples(uint32_t LineOffset, uint32_t Discriminator, uint64_t Num, uint64_t Weight=1)
void setFunctionHash(uint64_t Hash)
static LLVM_ABI bool ProfileIsFS
If this profile uses flow sensitive discriminators.
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.
const CallsiteSampleMap & getCallsiteSamples() const
Return all the callsite samples collected in the body of the function.
void setContext(const SampleContext &FContext)
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.
void setAllAttributes(uint32_t A)
FunctionId getFunction() const
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)
std::error_code readProfile(FunctionSamples &FProfile)
Read the contents of the given profile instance.
std::error_code readNameTable()
Read the whole name table.
const uint8_t * Data
Points to the current location in the buffer.
ErrorOr< StringRef > readString()
Read a string from the profile.
std::vector< FunctionId > NameTable
Function name table.
ErrorOr< T > readNumber()
Read a numeric value of type T from the profile.
ErrorOr< SampleContextFrames > readContextFromTable(size_t *RetIdx=nullptr)
Read a context indirectly via the CSNameTable.
ErrorOr< std::pair< SampleContext, uint64_t > > readSampleContextFromTable()
Read a context indirectly via the CSNameTable if the profile has context, otherwise same as readStrin...
std::error_code readHeader() override
Read and validate the file header.
const uint64_t * MD5SampleContextStart
The starting address of the table of MD5 values of sample contexts.
std::vector< SampleContextFrameVector > CSNameTable
CSNameTable is used to save full context vectors.
std::error_code readImpl() override
Read sample profiles from the associated file.
ErrorOr< FunctionId > readStringFromTable(size_t *RetIdx=nullptr)
Read a string indirectly via the name table. Optionally return the index.
std::vector< uint64_t > MD5SampleContextTable
Table to cache MD5 values of sample contexts corresponding to readSampleContextFromTable(),...
std::error_code readCallsiteVTableProf(FunctionSamples &FProfile)
Read all virtual functions' vtable access counts for FProfile.
ErrorOr< size_t > readStringIndex(T &Table)
Read the string index and check whether it overflows the table.
const uint8_t * End
Points to the end of the buffer.
ErrorOr< T > readUnencodedNumber()
Read a numeric value of type T from the profile.
std::error_code readFuncProfile(const uint8_t *Start)
Read the next function profile instance.
std::error_code readVTableTypeCountMap(TypeCountMap &M)
Read bytes from the input buffer pointed by Data and decode them into M.
std::error_code readSummary()
Read profile summary.
std::error_code readMagicIdent()
Read the contents of Magic number and Version number.
std::error_code readFuncOffsetTable()
std::vector< SecHdrTableEntry > SecHdrTable
bool collectFuncsFromModule() override
Collect functions with definitions in Module M.
uint64_t getSectionSize(SecType Type)
Get the total size of all Type sections.
std::error_code readCSNameTableSec()
virtual std::error_code readCustomSection(const SecHdrTableEntry &Entry)=0
std::vector< std::pair< SampleContext, uint64_t > > FuncOffsetList
The list version of FuncOffsetTable.
DenseSet< StringRef > FuncsToUse
The set containing the functions to use when compiling a module.
std::unique_ptr< ProfileSymbolList > ProfSymList
std::error_code readSecHdrTable()
std::error_code readFuncProfiles()
bool useFuncOffsetList() const
Determine which container readFuncOffsetTable() should populate, the list FuncOffsetList or the map F...
std::error_code readNameTableSec(bool IsMD5, bool FixedLengthMD5)
std::error_code readSecHdrTableEntry(uint64_t Idx)
std::error_code readImpl() override
Read sample profiles in extensible format from the associated file.
std::error_code readFuncMetadata(bool ProfileHasAttribute, DenseSet< FunctionSamples * > &Profiles)
virtual std::error_code readOneSection(const uint8_t *Start, uint64_t Size, const SecHdrTableEntry &Entry)
bool dumpSectionInfo(raw_ostream &OS=dbgs()) override
DenseMap< hash_code, uint64_t > FuncOffsetTable
The table mapping from a function context's MD5 to the offset of its FunctionSample towards file star...
std::error_code readHeader() override
Read and validate the file header.
uint64_t getFileSize()
Get the total size of header and all sections.
std::error_code readProfileSymbolList()
static bool hasFormat(const MemoryBuffer &Buffer)
Return true if Buffer is in the format supported by this class.
ErrorOr< T > readNumber()
GCOVBuffer GcovBuffer
GCOV buffer containing the profile.
std::vector< std::string > Names
Function names in this profile.
std::error_code readImpl() override
Read sample profiles from the associated file.
std::error_code readNameTable()
std::error_code readHeader() override
Read and validate the file header.
ErrorOr< StringRef > readString()
static const uint32_t GCOVTagAFDOFunction
std::error_code readOneFunctionProfile(const InlineCallStack &InlineStack, bool Update, uint32_t Offset)
std::error_code readFunctionProfiles()
static const uint32_t GCOVTagAFDOFileNames
GCOV tags used to separate sections in the profile file.
std::error_code skipNextWord()
static bool hasFormat(const MemoryBuffer &Buffer)
Return true if Buffer is in the format supported by this class.
std::error_code readSectionTag(uint32_t Expected)
Read the section tag and check that it's the same as Expected.
static LLVM_ABI ErrorOr< std::unique_ptr< SampleProfileReaderItaniumRemapper > > create(StringRef Filename, vfs::FileSystem &FS, SampleProfileReader &Reader, LLVMContext &C)
Create a remapper from the given remapping file.
LLVM_ABI void applyRemapping(LLVMContext &Ctx)
Apply remappings to the profile read by Reader.
LLVM_ABI std::optional< StringRef > lookUpNameInProfile(StringRef FunctionName)
Return the equivalent name in the profile for FunctionName if it exists.
static bool hasFormat(const MemoryBuffer &Buffer)
Return true if Buffer is in the format supported by this class.
std::error_code readImpl() override
Read sample profiles from the associated file.
static bool hasFormat(const MemoryBuffer &Buffer)
Return true if Buffer is in the format supported by this class.
Sample-based profile reader.
std::pair< const uint8_t *, const uint8_t * > ProfileSecRange
bool ReadVTableProf
If true, the profile has vtable profiles and reader should decode them to parse profiles correctly.
bool ProfileIsPreInlined
Whether function profile contains ShouldBeInlined contexts.
std::unordered_map< uint64_t, std::pair< const uint8_t *, const uint8_t * > > FuncMetadataIndex
uint32_t CSProfileCount
Number of context-sensitive profiles.
static LLVM_ABI ErrorOr< std::unique_ptr< SampleProfileReader > > create(StringRef Filename, LLVMContext &C, vfs::FileSystem &FS, FSDiscriminatorPass P=FSDiscriminatorPass::Base, StringRef RemapFilename="")
Create a sample profile reader appropriate to the file format.
LLVM_ABI void dump(raw_ostream &OS=dbgs())
Print all the profiles on stream OS.
bool useMD5() const
Return whether names in the profile are all MD5 numbers.
const Module * M
The current module being compiled if SampleProfileReader is used by compiler.
std::unique_ptr< MemoryBuffer > Buffer
Memory buffer holding the profile file.
std::unique_ptr< SampleProfileReaderItaniumRemapper > Remapper
bool ProfileHasAttribute
Whether the profile has attribute metadata.
bool SkipFlatProf
If SkipFlatProf is true, skip functions marked with !Flat in text mode or sections with SecFlagFlat f...
std::error_code read()
The interface to read sample profiles from the associated file.
bool ProfileIsCS
Whether function profiles are context-sensitive flat profiles.
bool ProfileIsMD5
Whether the profile uses MD5 for Sample Contexts and function names.
std::unique_ptr< ProfileSummary > Summary
Profile summary information.
LLVM_ABI void computeSummary()
Compute summary for this profile.
uint32_t getDiscriminatorMask() const
Get the bitmask the discriminators: For FS profiles, return the bit mask for this pass.
bool ProfileIsFS
Whether the function profiles use FS discriminators.
LLVM_ABI void dumpJson(raw_ostream &OS=dbgs())
Print all the profiles on stream OS in the JSON format.
SampleProfileMap Profiles
Map every function to its associated profile.
LLVM_ABI void dumpFunctionProfile(const FunctionSamples &FS, raw_ostream &OS=dbgs())
Print the profile for FunctionSamples on stream OS.
bool ProfileIsProbeBased
Whether samples are collected based on pseudo probes.
void reportError(int64_t LineNumber, const Twine &Msg) const
Report a parse error message.
LLVMContext & Ctx
LLVM context used to emit diagnostics.
Representation of a single sample record.
uint64_t getSamples() const
const SortedCallTargetSet getSortedCallTargets() const
The virtual file system interface.
@ C
The default llvm calling convention, compatible with C.
initializer< Ty > init(const Ty &Val)
LLVM_ABI Error decompress(ArrayRef< uint8_t > Input, uint8_t *Output, size_t &UncompressedSize)
LLVM_ABI bool isAvailable()
LLVM_ABI void sortFuncProfiles(const SampleProfileMap &ProfileMap, std::vector< NameFunctionSamples > &SortedProfiles)
static uint64_t SPMagic(SampleProfileFormat Format=SPF_Binary)
std::map< LineLocation, FunctionSamplesMap > CallsiteSampleMap
static bool hasSecFlag(const SecHdrTableEntry &Entry, SecFlagType Flag)
@ HIST_TYPE_INDIR_CALL_TOPN
uint64_t MD5Hash(const FunctionId &Obj)
@ 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.
SmallVector< SampleContextFrame, 1 > SampleContextFrameVector
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[]
SmallVector< FunctionSamples *, 10 > InlineCallStack
static uint64_t SPVersion()
std::map< LineLocation, SampleRecord > BodySampleMap
uint64_t read64le(const void *P)
void write64le(void *P, uint64_t V)
value_type read(const void *memory, endianness endian)
Read a value of a particular endianness from memory.
value_type readNext(const CharT *&memory, endianness endian)
Read a value of a particular endianness from a buffer, and increment the buffer past that value.
This is an optimization pass for GlobalISel generic memory operations.
static Expected< std::unique_ptr< MemoryBuffer > > setupMemoryBuffer(const Twine &Filename, vfs::FileSystem &FS)
void handleAllErrors(Error E, HandlerTs &&... Handlers)
Behaves the same as handleErrors, except that by contract all errors must be handled by the given han...
uint64_t decodeULEB128(const uint8_t *p, unsigned *n=nullptr, const uint8_t *end=nullptr, const char **error=nullptr)
Utility function to decode a ULEB128 value.
void append_range(Container &C, Range &&R)
Wrapper function to append range R to container C.
FunctionAddr VTableAddr uintptr_t uintptr_t Version
sampleprof_error mergeSampleProfErrors(sampleprof_error &Accumulator, sampleprof_error Result)
bool isDigit(char C)
Checks if character C is one of the 10 decimal digits.
FunctionAddr VTableAddr Count
LLVM_ATTRIBUTE_VISIBILITY_DEFAULT AnalysisKey InnerAnalysisManagerProxy< AnalysisManagerT, IRUnitT, ExtraArgTs... >::Key
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
FunctionAddr VTableAddr uintptr_t uintptr_t Data
auto count(R &&Range, const E &Element)
Wrapper function around std::count to count the number of times an element Element occurs in the give...
ArrayRef(const T &OneElt) -> ArrayRef< T >
Represents the relative location of an instruction.