LLVM 20.0.0git
InstrProfCorrelator.h
Go to the documentation of this file.
1//===- InstrProfCorrelator.h ------------------------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8// This file defines InstrProfCorrelator used to generate PGO/coverage profiles
9// from raw profile data and debug info/binary file.
10//===----------------------------------------------------------------------===//
11
12#ifndef LLVM_PROFILEDATA_INSTRPROFCORRELATOR_H
13#define LLVM_PROFILEDATA_INSTRPROFCORRELATOR_H
14
15#include "llvm/ADT/DenseSet.h"
17#include "llvm/Object/BuildID.h"
19#include "llvm/Support/Error.h"
22#include <optional>
23#include <vector>
24
25namespace llvm {
26class DWARFContext;
27class DWARFDie;
28namespace object {
29class ObjectFile;
30}
31
32/// InstrProfCorrelator - A base class used to create raw instrumentation data
33/// to their functions.
35public:
36 /// Indicate if we should use the debug info or profile metadata sections to
37 /// correlate.
39
41 get(StringRef Filename, ProfCorrelatorKind FileKind,
42 const object::BuildIDFetcher *BIDFetcher = nullptr,
43 const ArrayRef<llvm::object::BuildID> BIs = {});
44
45 /// Construct a ProfileData vector used to correlate raw instrumentation data
46 /// to their functions.
47 /// \param MaxWarnings the maximum number of warnings to emit (0 = no limit)
48 virtual Error correlateProfileData(int MaxWarnings) = 0;
49
50 /// Process debug info and dump the correlation data.
51 /// \param MaxWarnings the maximum number of warnings to emit (0 = no limit)
52 virtual Error dumpYaml(int MaxWarnings, raw_ostream &OS) = 0;
53
54 /// Return the number of ProfileData elements.
55 std::optional<size_t> getDataSize() const;
56
57 /// Return a pointer to the names string that this class constructs.
58 const char *getNamesPointer() const { return Names.c_str(); }
59
60 /// Return the number of bytes in the names string.
61 size_t getNamesSize() const { return Names.size(); }
62
63 /// Return the size of the counters section in bytes.
65 return Ctx->CountersSectionEnd - Ctx->CountersSectionStart;
66 }
67
68 static const char *FunctionNameAttributeName;
69 static const char *CFGHashAttributeName;
70 static const char *NumCountersAttributeName;
71
73 InstrProfCorrelatorKind getKind() const { return Kind; }
74 virtual ~InstrProfCorrelator() = default;
75
76protected:
77 struct Context {
79 get(std::unique_ptr<MemoryBuffer> Buffer, const object::ObjectFile &Obj,
80 ProfCorrelatorKind FileKind);
81 std::unique_ptr<MemoryBuffer> Buffer;
82 /// The address range of the __llvm_prf_cnts section.
85 /// The pointer points to start/end of profile data/name sections if
86 /// FileKind is Binary.
87 const char *DataStart;
88 const char *DataEnd;
89 const char *NameStart;
90 size_t NameSize;
91 /// True if target and host have different endian orders.
93 };
94 const std::unique_ptr<Context> Ctx;
95
96 InstrProfCorrelator(InstrProfCorrelatorKind K, std::unique_ptr<Context> Ctx)
97 : Ctx(std::move(Ctx)), Kind(K) {}
98
99 std::string Names;
100 std::vector<std::string> NamesVec;
101
102 struct Probe {
103 std::string FunctionName;
104 std::optional<std::string> LinkageName;
105 yaml::Hex64 CFGHash;
106 yaml::Hex64 CounterOffset;
108 std::optional<std::string> FilePath;
109 std::optional<int> LineNumber;
110 };
111
113 std::vector<Probe> Probes;
114 };
115
116 friend struct yaml::MappingTraits<Probe>;
117 friend struct yaml::SequenceElementTraits<Probe>;
119
120private:
122 get(std::unique_ptr<MemoryBuffer> Buffer, ProfCorrelatorKind FileKind);
123
124 const InstrProfCorrelatorKind Kind;
125};
126
127/// InstrProfCorrelatorImpl - A child of InstrProfCorrelator with a template
128/// pointer type so that the ProfileData vector can be materialized.
129template <class IntPtrT>
131public:
132 InstrProfCorrelatorImpl(std::unique_ptr<InstrProfCorrelator::Context> Ctx);
133 static bool classof(const InstrProfCorrelator *C);
134
135 /// Return a pointer to the underlying ProfileData vector that this class
136 /// constructs.
138 return Data.empty() ? nullptr : Data.data();
139 }
140
141 /// Return the number of ProfileData elements.
142 size_t getDataSize() const { return Data.size(); }
143
145 get(std::unique_ptr<InstrProfCorrelator::Context> Ctx,
146 const object::ObjectFile &Obj, ProfCorrelatorKind FileKind);
147
148protected:
149 std::vector<RawInstrProf::ProfileData<IntPtrT>> Data;
150
151 Error correlateProfileData(int MaxWarnings) override;
153 int MaxWarnings,
155
157
158 Error dumpYaml(int MaxWarnings, raw_ostream &OS) override;
159
160 void addDataProbe(uint64_t FunctionName, uint64_t CFGHash,
161 IntPtrT CounterOffset, IntPtrT FunctionPtr,
162 uint32_t NumCounters);
163
164 // Byte-swap the value if necessary.
165 template <class T> T maybeSwap(T Value) const {
166 return Ctx->ShouldSwapBytes ? llvm::byteswap(Value) : Value;
167 }
168
169private:
171 std::unique_ptr<InstrProfCorrelator::Context> Ctx)
172 : InstrProfCorrelator(Kind, std::move(Ctx)){};
173 llvm::DenseSet<IntPtrT> CounterOffsets;
174};
175
176/// DwarfInstrProfCorrelator - A child of InstrProfCorrelatorImpl that takes
177/// DWARF debug info as input to correlate profiles.
178template <class IntPtrT>
180public:
181 DwarfInstrProfCorrelator(std::unique_ptr<DWARFContext> DICtx,
182 std::unique_ptr<InstrProfCorrelator::Context> Ctx)
184 DICtx(std::move(DICtx)) {}
185
186private:
187 std::unique_ptr<DWARFContext> DICtx;
188
189 /// Return the address of the object that the provided DIE symbolizes.
190 std::optional<uint64_t> getLocation(const DWARFDie &Die) const;
191
192 /// Returns true if the provided DIE symbolizes an instrumentation probe
193 /// symbol.
194 static bool isDIEOfProbe(const DWARFDie &Die);
195
196 /// Iterate over DWARF DIEs to find those that symbolize instrumentation
197 /// probes and construct the ProfileData vector and Names string.
198 ///
199 /// Here is some example DWARF for an instrumentation probe we are looking
200 /// for:
201 /// \code
202 /// DW_TAG_subprogram
203 /// DW_AT_low_pc (0x0000000000000000)
204 /// DW_AT_high_pc (0x0000000000000014)
205 /// DW_AT_name ("foo")
206 /// DW_TAG_variable
207 /// DW_AT_name ("__profc_foo")
208 /// DW_AT_location (DW_OP_addr 0x0)
209 /// DW_TAG_LLVM_annotation
210 /// DW_AT_name ("Function Name")
211 /// DW_AT_const_value ("foo")
212 /// DW_TAG_LLVM_annotation
213 /// DW_AT_name ("CFG Hash")
214 /// DW_AT_const_value (12345678)
215 /// DW_TAG_LLVM_annotation
216 /// DW_AT_name ("Num Counters")
217 /// DW_AT_const_value (2)
218 /// NULL
219 /// NULL
220 /// \endcode
221 /// \param MaxWarnings the maximum number of warnings to emit (0 = no limit)
222 /// \param Data if provided, populate with the correlation data found
223 void correlateProfileDataImpl(
224 int MaxWarnings,
225 InstrProfCorrelator::CorrelationData *Data = nullptr) override;
226
227 Error correlateProfileNameImpl() override;
228};
229
230/// BinaryInstrProfCorrelator - A child of InstrProfCorrelatorImpl that
231/// takes an object file as input to correlate profiles.
232template <class IntPtrT>
234public:
235 BinaryInstrProfCorrelator(std::unique_ptr<InstrProfCorrelator::Context> Ctx)
237
238 /// Return a pointer to the names string that this class constructs.
239 const char *getNamesPointer() const { return this->Ctx.NameStart; }
240
241 /// Return the number of bytes in the names string.
242 size_t getNamesSize() const { return this->Ctx.NameSize; }
243
244private:
245 void correlateProfileDataImpl(
246 int MaxWarnings,
247 InstrProfCorrelator::CorrelationData *Data = nullptr) override;
248
249 Error correlateProfileNameImpl() override;
250};
251
252} // end namespace llvm
253
254#endif // LLVM_PROFILEDATA_INSTRPROFCORRELATOR_H
This file declares a Build ID fetcher implementation for obtaining debug info from debuginfod.
This file declares a library for handling Build IDs and using them to find debug info.
This file defines the DenseSet and SmallDenseSet classes.
raw_pwrite_stream & OS
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
BinaryInstrProfCorrelator - A child of InstrProfCorrelatorImpl that takes an object file as input to ...
size_t getNamesSize() const
Return the number of bytes in the names string.
const char * getNamesPointer() const
Return a pointer to the names string that this class constructs.
BinaryInstrProfCorrelator(std::unique_ptr< InstrProfCorrelator::Context > Ctx)
Utility class that carries the DWARF compile/type unit and the debug info entry in an object.
Definition: DWARFDie.h:42
Implements a dense probed hash-table based set.
Definition: DenseSet.h:278
DwarfInstrProfCorrelator - A child of InstrProfCorrelatorImpl that takes DWARF debug info as input to...
DwarfInstrProfCorrelator(std::unique_ptr< DWARFContext > DICtx, std::unique_ptr< InstrProfCorrelator::Context > Ctx)
Lightweight error class with error context and mandatory checking.
Definition: Error.h:160
Tagged union holding either a T or a Error.
Definition: Error.h:481
InstrProfCorrelatorImpl - A child of InstrProfCorrelator with a template pointer type so that the Pro...
static llvm::Expected< std::unique_ptr< InstrProfCorrelatorImpl< IntPtrT > > > get(std::unique_ptr< InstrProfCorrelator::Context > Ctx, const object::ObjectFile &Obj, ProfCorrelatorKind FileKind)
virtual Error correlateProfileNameImpl()=0
virtual void correlateProfileDataImpl(int MaxWarnings, InstrProfCorrelator::CorrelationData *Data=nullptr)=0
std::vector< RawInstrProf::ProfileData< IntPtrT > > Data
Error correlateProfileData(int MaxWarnings) override
Construct a ProfileData vector used to correlate raw instrumentation data to their functions.
static bool classof(const InstrProfCorrelator *C)
InstrProfCorrelatorImpl(std::unique_ptr< InstrProfCorrelator::Context > Ctx)
void addDataProbe(uint64_t FunctionName, uint64_t CFGHash, IntPtrT CounterOffset, IntPtrT FunctionPtr, uint32_t NumCounters)
const RawInstrProf::ProfileData< IntPtrT > * getDataPointer() const
Return a pointer to the underlying ProfileData vector that this class constructs.
Error dumpYaml(int MaxWarnings, raw_ostream &OS) override
Process debug info and dump the correlation data.
size_t getDataSize() const
Return the number of ProfileData elements.
InstrProfCorrelator - A base class used to create raw instrumentation data to their functions.
virtual Error correlateProfileData(int MaxWarnings)=0
Construct a ProfileData vector used to correlate raw instrumentation data to their functions.
static const char * FunctionNameAttributeName
static const char * CFGHashAttributeName
InstrProfCorrelator(InstrProfCorrelatorKind K, std::unique_ptr< Context > Ctx)
uint64_t getCountersSectionSize() const
Return the size of the counters section in bytes.
std::vector< std::string > NamesVec
static const char * NumCountersAttributeName
virtual Error dumpYaml(int MaxWarnings, raw_ostream &OS)=0
Process debug info and dump the correlation data.
const char * getNamesPointer() const
Return a pointer to the names string that this class constructs.
ProfCorrelatorKind
Indicate if we should use the debug info or profile metadata sections to correlate.
virtual ~InstrProfCorrelator()=default
InstrProfCorrelatorKind getKind() const
const std::unique_ptr< Context > Ctx
std::optional< size_t > getDataSize() const
Return the number of ProfileData elements.
static llvm::Expected< std::unique_ptr< InstrProfCorrelator > > get(StringRef Filename, ProfCorrelatorKind FileKind, const object::BuildIDFetcher *BIDFetcher=nullptr, const ArrayRef< llvm::object::BuildID > BIs={})
size_t getNamesSize() const
Return the number of bytes in the names string.
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:51
LLVM Value Representation.
Definition: Value.h:74
BuildIDFetcher searches local cache directories for debug info.
Definition: BuildID.h:39
This class is the base class for all object file types.
Definition: ObjectFile.h:229
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition: raw_ostream.h:52
@ C
The default llvm calling convention, compatible with C.
Definition: CallingConv.h:34
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
constexpr T byteswap(T V) noexcept
Reverses the bytes in the given integer value V.
Definition: bit.h:101
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
Definition: STLExtras.h:1873
Implement std::hash so that hash_code can be used in STL containers.
Definition: BitVector.h:858
bool ShouldSwapBytes
True if target and host have different endian orders.
std::unique_ptr< MemoryBuffer > Buffer
static llvm::Expected< std::unique_ptr< Context > > get(std::unique_ptr< MemoryBuffer > Buffer, const object::ObjectFile &Obj, ProfCorrelatorKind FileKind)
uint64_t CountersSectionStart
The address range of the __llvm_prf_cnts section.
const char * DataStart
The pointer points to start/end of profile data/name sections if FileKind is Binary.
std::optional< std::string > LinkageName
std::optional< std::string > FilePath