49#ifndef LLVM_IR_PASSINSTRUMENTATION_H
50#define LLVM_IR_PASSINSTRUMENTATION_H
103 template <
typename CallableT>
105 ShouldRunOptionalPassCallbacks.emplace_back(std::move(
C));
108 template <
typename CallableT>
110 BeforeSkippedPassCallbacks.emplace_back(std::move(
C));
113 template <
typename CallableT>
115 BeforeNonSkippedPassCallbacks.emplace_back(std::move(
C));
118 template <
typename CallableT>
121 AfterPassCallbacks.insert(AfterPassCallbacks.begin(), std::move(
C));
123 AfterPassCallbacks.emplace_back(std::move(
C));
126 template <
typename CallableT>
129 AfterPassInvalidatedCallbacks.insert(
130 AfterPassInvalidatedCallbacks.begin(), std::move(
C));
132 AfterPassInvalidatedCallbacks.emplace_back(std::move(
C));
135 template <
typename CallableT>
137 BeforeAnalysisCallbacks.emplace_back(std::move(
C));
140 template <
typename CallableT>
143 AfterAnalysisCallbacks.insert(AfterAnalysisCallbacks.begin(),
146 AfterAnalysisCallbacks.emplace_back(std::move(
C));
149 template <
typename CallableT>
151 AnalysisInvalidatedCallbacks.emplace_back(std::move(
C));
154 template <
typename CallableT>
156 AnalysesClearedCallbacks.emplace_back(std::move(
C));
159 template <
typename CallableT>
161 ClassToPassNameCallbacks.emplace_back(std::move(
C));
175 ShouldRunOptionalPassCallbacks;
178 BeforeSkippedPassCallbacks;
181 BeforeNonSkippedPassCallbacks;
186 AfterPassInvalidatedCallbacks;
189 BeforeAnalysisCallbacks;
192 AfterAnalysisCallbacks;
195 AnalysisInvalidatedCallbacks;
198 AnalysesClearedCallbacks;
215 template <
typename PassT>
216 using has_required_t =
decltype(std::declval<PassT &>().isRequired());
218 template <
typename PassT>
static bool isRequired(
const PassT &
Pass) {
220 return Pass.isRequired();
237 template <
typename IRUnitT,
typename PassT>
242 bool ShouldRun =
true;
243 if (!isRequired(
Pass)) {
244 for (
auto &
C : Callbacks->ShouldRunOptionalPassCallbacks)
249 for (
auto &
C : Callbacks->BeforeNonSkippedPassCallbacks)
252 for (
auto &
C : Callbacks->BeforeSkippedPassCallbacks)
262 template <
typename IRUnitT,
typename PassT>
266 for (
auto &
C : Callbacks->AfterPassCallbacks)
273 template <
typename IRUnitT,
typename PassT>
277 for (
auto &
C : Callbacks->AfterPassInvalidatedCallbacks)
283 template <
typename IRUnitT,
typename PassT>
286 for (
auto &
C : Callbacks->BeforeAnalysisCallbacks)
292 template <
typename IRUnitT,
typename PassT>
295 for (
auto &
C : Callbacks->AfterAnalysisCallbacks)
302 template <
typename IRUnitT,
typename PassT>
305 for (
auto &
C : Callbacks->AnalysisInvalidatedCallbacks)
313 for (
auto &
C : Callbacks->AnalysesClearedCallbacks)
322 template <
typename IRUnitT,
typename... ExtraArgsT>
328 template <
typename CallableT>
331 Callbacks->BeforeNonSkippedPassCallbacks.emplace_back(std::move(
C));
335 Callbacks->BeforeNonSkippedPassCallbacks.pop_back();
341 return Callbacks->getPassNameForClassName(ClassName);
347 const std::vector<StringRef> &Specials);
362 : Callbacks(Callbacks) {}
366 template <
typename IRUnitT,
typename AnalysisManagerT,
typename... ExtraArgTs>
367 Result run(IRUnitT &, AnalysisManagerT &, ExtraArgTs &&...) {
This file provides Any, a non-template class modeled in the spirit of std::any.
block Block Frequency Analysis
#define LLVM_TEMPLATE_ABI
This file defines the DenseMap class.
This header defines various interfaces for pass management in LLVM.
Legalize the Machine IR a function s Machine IR
This file defines the SmallVector class.
static const char PassName[]
Represents a single loop in the control flow graph.
A Module instance is used to store all the information related to an LLVM module.
Result run(IRUnitT &, AnalysisManagerT &, ExtraArgTs &&...)
PassInstrumentation Result
PassInstrumentationAnalysis(PassInstrumentationCallbacks *Callbacks=nullptr)
PassInstrumentationCallbacks object is shared, owned by something else, not this analysis.
This class manages callbacks registration, as well as provides a way for PassInstrumentation to pass ...
void registerAnalysesClearedCallback(CallableT C)
void registerBeforeAnalysisCallback(CallableT C)
void registerAfterPassInvalidatedCallback(CallableT C, bool ToFront=false)
void registerAnalysisInvalidatedCallback(CallableT C)
void registerAfterAnalysisCallback(CallableT C, bool ToFront=false)
friend class PassInstrumentation
void(StringRef, const PreservedAnalyses &) AfterPassInvalidatedFunc
void(StringRef, Any) BeforeNonSkippedPassFunc
void registerBeforeNonSkippedPassCallback(CallableT C)
void registerClassToPassNameCallback(CallableT C)
void registerBeforeSkippedPassCallback(CallableT C)
PassInstrumentationCallbacks(const PassInstrumentationCallbacks &)=delete
Copying PassInstrumentationCallbacks is not intended.
PassInstrumentationCallbacks()=default
bool(StringRef, Any) BeforePassFunc
void(StringRef) AnalysesClearedFunc
void registerShouldRunOptionalPassCallback(CallableT C)
void(StringRef, Any) BeforeSkippedPassFunc
void operator=(const PassInstrumentationCallbacks &)=delete
void(StringRef, Any) AfterAnalysisFunc
void(StringRef, Any) BeforeAnalysisFunc
void(StringRef, Any) AnalysisInvalidatedFunc
void(StringRef, Any, const PreservedAnalyses &) AfterPassFunc
void registerAfterPassCallback(CallableT C, bool ToFront=false)
This class provides instrumentation entry points for the Pass Manager, doing calls to callbacks regis...
void runAfterPassInvalidated(const PassT &Pass, const PreservedAnalyses &PA) const
AfterPassInvalidated instrumentation point - takes Pass instance that has just been executed.
void pushBeforeNonSkippedPassCallback(CallableT C)
PassInstrumentation(PassInstrumentationCallbacks *CB=nullptr)
Callbacks object is not owned by PassInstrumentation, its life-time should at least match the life-ti...
bool invalidate(IRUnitT &, const class llvm::PreservedAnalyses &, ExtraArgsT...)
Handle invalidation from the pass manager when PassInstrumentation is used as the result of PassInstr...
void runBeforeAnalysis(const PassT &Analysis, const IRUnitT &IR) const
BeforeAnalysis instrumentation point - takes Analysis instance to be executed and constant reference ...
void runAnalysisInvalidated(const PassT &Analysis, const IRUnitT &IR) const
AnalysisInvalidated instrumentation point - takes Analysis instance that has just been invalidated an...
void runAnalysesCleared(StringRef Name) const
AnalysesCleared instrumentation point - takes name of IR that analyses operated on.
StringRef getPassNameForClassName(StringRef ClassName) const
Get the pass name for a given pass class name.
void popBeforeNonSkippedPassCallback()
void runAfterPass(const PassT &Pass, const IRUnitT &IR, const PreservedAnalyses &PA) const
AfterPass instrumentation point - takes Pass instance that has just been executed and constant refere...
void runAfterAnalysis(const PassT &Analysis, const IRUnitT &IR) const
AfterAnalysis instrumentation point - takes Analysis instance that has just been executed and constan...
bool runBeforePass(const PassT &Pass, const IRUnitT &IR) const
BeforePass instrumentation point - takes Pass instance to be executed and constant reference to IR it...
Pass interface - Implemented by all 'passes'.
A set of analyses that are preserved following a run of a transformation pass.
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.
unique_function is a type-erasing functor similar to std::function.
@ C
The default llvm calling convention, compatible with C.
This is an optimization pass for GlobalISel generic memory operations.
LLVM_ABI bool isSpecialPass(StringRef PassID, const std::vector< StringRef > &Specials)
typename detail::detector< void, Op, Args... >::value_t is_detected
Detects if a given trait holds for some set of arguments 'Args'.
A CRTP mix-in that provides informational APIs needed for analysis passes.
A special type used by analysis passes to provide an address that identifies that particular analysis...