LLVM 23.0.0git
X86.h
Go to the documentation of this file.
1//===-- X86.h - Top-level interface for X86 representation ------*- 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//
9// This file contains the entry points for global functions defined in the x86
10// target library, as used by the LLVM JIT.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_LIB_TARGET_X86_X86_H
15#define LLVM_LIB_TARGET_X86_X86_H
16
19#include "llvm/IR/Analysis.h"
20#include "llvm/IR/Module.h"
21#include "llvm/IR/PassManager.h"
22#include "llvm/PassInfo.h"
25
26namespace llvm {
27
28class FunctionPass;
30class PassRegistry;
32class X86Subtarget;
34
35/// This pass converts a legalized DAG into a X86-specific DAG, ready for
36/// instruction scheduling.
41
43
44/// This pass initializes a global base register for PIC on x86-32.
46 : public OptionalPassInfoMixin<X86GlobalBaseRegPass> {
47public:
50};
51
53
54/// This pass combines multiple accesses to local-dynamic TLS variables so that
55/// the TLS base address for the module is only fetched once per execution path
56/// through the function.
58 : public OptionalPassInfoMixin<X86CleanupLocalDynamicTLSPass> {
59public:
62};
63
65
66/// This function returns a pass which converts floating-point register
67/// references and pseudo instructions into floating-point stack references and
68/// physical instructions.
69class X86FPStackifierPass : public OptionalPassInfoMixin<X86FPStackifierPass> {
70public:
73};
74
76
77/// This pass inserts AVX vzeroupper instructions before each call to avoid
78/// transition penalty between functions encoded with AVX and SSE.
80 : public OptionalPassInfoMixin<X86InsertVZeroUpperPass> {
81public:
84};
85
87/// This pass inserts ENDBR instructions before indirect jump/call
88/// destinations as part of CET IBT mechanism.
90 : public OptionalPassInfoMixin<X86IndirectBranchTrackingPass> {
91public:
94};
95
97
98/// Return a pass that pads short functions with NOOPs.
99/// This will prevent a stall when returning on the Atom.
101
102/// Return a pass that selectively replaces certain instructions (like add,
103/// sub, inc, dec, some shifts, and some multiplies) by equivalent LEA
104/// instructions, in order to eliminate execution delays in some processors.
105class X86FixupLEAsPass : public OptionalPassInfoMixin<X86FixupLEAsPass> {
106public:
109};
110
112
113/// Return a pass that replaces equivalent slower instructions with faster
114/// ones.
116 : public OptionalPassInfoMixin<X86FixupInstTuningPass> {
117public:
120};
121
123
124/// Return a pass that reduces the size of vector constant pool loads.
126 : public OptionalPassInfoMixin<X86FixupInstTuningPass> {
127public:
130};
131
133
134/// Return a pass that removes redundant LEA instructions and redundant address
135/// recalculations.
136class X86OptimizeLEAsPass : public OptionalPassInfoMixin<X86OptimizeLEAsPass> {
137public:
140};
141
143
144/// Return a pass that transforms setcc + movzx pairs into xor + setcc.
145class X86FixupSetCCPass : public OptionalPassInfoMixin<X86FixupSetCCPass> {
146public:
149};
150
152
153/// Return a pass that avoids creating store forward block issues in the
154/// hardware.
156 : public OptionalPassInfoMixin<X86AvoidStoreForwardingBlocksPass> {
157public:
160};
161
163
164/// Return a pass that lowers EFLAGS copy pseudo instructions.
166 : public OptionalPassInfoMixin<X86FlagsCopyLoweringPass> {
167public:
170};
171
173
174/// Return a pass that expands DynAlloca pseudo-instructions.
176 : public OptionalPassInfoMixin<X86DynAllocaExpanderPass> {
177public:
180};
181
183
184/// Return a pass that config the tile registers.
185class X86TileConfigPass : public OptionalPassInfoMixin<X86TileConfigPass> {
186public:
189};
190
192
193/// Return a pass that preconfig the tile registers before fast reg allocation.
195 : public OptionalPassInfoMixin<X86FastPreTileConfigPass> {
196public:
199};
200
202
203/// Return a pass that config the tile registers after fast reg allocation.
205 : public OptionalPassInfoMixin<X86FastTileConfigPass> {
206public:
209};
210
212
213/// Return a pass that insert pseudo tile config instruction.
215 : public OptionalPassInfoMixin<X86PreTileConfigPass> {
216public:
219};
220
222
223/// Return a pass that lower the tile copy instruction.
225 : public OptionalPassInfoMixin<X86LowerTileCopyPass> {
226public:
229};
230
232
233/// Return a pass that inserts int3 at the end of the function if it ends with a
234/// CALL instruction. The pass does the same for each funclet as well. This
235/// ensures that the open interval of function start and end PCs contains all
236/// return addresses for the benefit of the Windows x64 unwinder.
238 : public RequiredPassInfoMixin<X86AvoidTrailingCallPass> {
239public:
242};
243
245
246/// Return a pass that optimizes the code-size of x86 call sequences. This is
247/// done by replacing esp-relative movs with pushes.
249 : public OptionalPassInfoMixin<X86CallFrameOptimizationPass> {
250public:
253};
254
256
257/// Return an IR pass that inserts EH registration stack objects and explicit
258/// EH state updates. This pass must run after EH preparation, which does
259/// Windows-specific but architecture-neutral preparation.
260class X86WinEHStatePass : public OptionalPassInfoMixin<X86WinEHStatePass> {
261public:
262 X86WinEHStatePass() = default;
264};
265
267
268/// Return a Machine IR pass that expands X86-specific pseudo
269/// instructions into a sequence of actual instructions. This pass
270/// must run after prologue/epilogue insertion and before lowering
271/// the MachineInstr to MC.
272class X86ExpandPseudoPass : public OptionalPassInfoMixin<X86ExpandPseudoPass> {
273public:
276};
277
279
280/// This pass converts X86 cmov instructions into branch when profitable.
282 : public OptionalPassInfoMixin<X86CmovConversionPass> {
283public:
286};
287
289
290/// Return a Machine IR pass that selectively replaces
291/// certain byte and word instructions by equivalent 32 bit instructions,
292/// in order to eliminate partial register usage, false dependences on
293/// the upper portions of registers, and to save code size.
294class X86FixupBWInstsPass : public OptionalPassInfoMixin<X86FixupBWInstsPass> {
295public:
298};
299
301
302/// Return a Machine IR pass that reassigns instruction chains from one domain
303/// to another, when profitable.
305 : public OptionalPassInfoMixin<X86DomainReassignmentPass> {
306public:
309};
310
312
313/// This pass compress instructions from EVEX space to legacy/VEX/EVEX space when
314/// possible in order to reduce code size or facilitate HW decoding.
315class X86CompressEVEXPass : public OptionalPassInfoMixin<X86CompressEVEXPass> {
316public:
319};
320
322
323/// This pass creates the thunks for the retpoline feature.
325
326/// This pass replaces ret instructions with jmp's to __x86_return thunk.
327class X86ReturnThunksPass : public OptionalPassInfoMixin<X86ReturnThunksPass> {
328public:
331};
332
334
335/// This pass insert wait instruction after X87 instructions which could raise
336/// fp exceptions when strict-fp enabled.
338 : public OptionalPassInfoMixin<X86InsertX87WaitPass> {
339public:
341};
342
344
345/// This pass optimizes arithmetic based on knowledge that is only used by
346/// a reduction sequence and is therefore safe to reassociate in interesting
347/// ways.
349 : public OptionalPassInfoMixin<X86PartialReductionPass> {
350private:
351 const X86TargetMachine *TM;
352
353public:
356};
357
359
360/// // Analyzes and emits pseudos to support Win x64 Unwind V2.
362 : public OptionalPassInfoMixin<X86WinEHUnwindV2Pass> {
363public:
367};
368
370
371/// The pass transforms load/store <256 x i32> to AMX load/store intrinsics
372/// or split the data to two <128 x i32>.
373class X86LowerAMXTypePass : public RequiredPassInfoMixin<X86LowerAMXTypePass> {
374private:
375 const TargetMachine *TM;
376
377public:
378 X86LowerAMXTypePass(const TargetMachine *TM) : TM(TM) {}
380};
381
382FunctionPass *createX86LowerAMXTypeLegacyPass();
383
384// Suppresses APX features for relocations for supporting older linkers.
386 : public OptionalPassInfoMixin<X86SuppressAPXForRelocationPass> {
387public:
390};
391
393
394/// The pass transforms amx intrinsics to scalar operation if the function has
395/// optnone attribute or it is O0.
397 : public RequiredPassInfoMixin<X86LowerAMXIntrinsicsPass> {
398private:
399 const TargetMachine *TM;
400
401public:
404};
405
407
408/// Capacity check and sub-fragment splitting for Win x64 Unwind V3.
410
412 const X86Subtarget &,
413 const X86RegisterBankInfo &);
414
416 : public OptionalPassInfoMixin<X86PostLegalizerCombinerPass> {
417public:
420};
421
423
425 : public PassInfoMixin<X86PreLegalizerCombinerPass> {
426public:
429};
430
432
434 : public OptionalPassInfoMixin<X86LoadValueInjectionLoadHardeningPass> {
435public:
438};
439
441
443 : public OptionalPassInfoMixin<X86LoadValueInjectionRetHardeningPass> {
444public:
447};
448
450
452 : public OptionalPassInfoMixin<
453 X86SpeculativeExecutionSideEffectSuppressionPass> {
454public:
457};
458
460
462 : public OptionalPassInfoMixin<X86SpeculativeLoadHardeningPass> {
463public:
466};
467
469
471 : public OptionalPassInfoMixin<X86ArgumentStackSlotPass> {
472public:
475};
476
478
512 PassRegistry &);
520
521namespace X86AS {
522enum : unsigned {
523 GS = 256,
524 FS = 257,
525 SS = 258,
528 PTR64 = 272
529};
530} // End X86AS namespace
531
532} // End llvm namespace
533
534#endif
Module.h This file contains the declarations for the Module class.
This header defines various interfaces for pass management in LLVM.
#define F(x, y, z)
Definition MD5.cpp:54
FunctionAnalysisManager FAM
ModuleAnalysisManager MAM
FunctionPass class - This class is used to implement most global optimizations.
Definition Pass.h:314
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
PassRegistry - This class manages the registration and intitialization of the pass subsystem as appli...
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
SelectionDAGISelPass(std::unique_ptr< SelectionDAGISel > Selector)
Primary interface to the complete machine description for the target machine.
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that avoids creating store forward block issues in the hardware.
Definition X86.h:156
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that inserts int3 at the end of the function if it ends with a CALL instruction.
Definition X86.h:238
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that optimizes the code-size of x86 call sequences.
Definition X86.h:249
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This pass combines multiple accesses to local-dynamic TLS variables so that the TLS base address for ...
Definition X86.h:58
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This pass converts X86 cmov instructions into branch when profitable.
Definition X86.h:282
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This pass compress instructions from EVEX space to legacy/VEX/EVEX space when possible in order to re...
Definition X86.h:315
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a Machine IR pass that reassigns instruction chains from one domain to another,...
Definition X86.h:305
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that expands DynAlloca pseudo-instructions.
Definition X86.h:176
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a Machine IR pass that expands X86-specific pseudo instructions into a sequence of actual inst...
Definition X86.h:272
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This function returns a pass which converts floating-point register references and pseudo instruction...
Definition X86.h:69
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that preconfig the tile registers before fast reg allocation.
Definition X86.h:195
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that config the tile registers after fast reg allocation.
Definition X86.h:205
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a Machine IR pass that selectively replaces certain byte and word instructions by equivalent 3...
Definition X86.h:294
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that replaces equivalent slower instructions with faster ones.
Definition X86.h:116
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that selectively replaces certain instructions (like add, sub, inc, dec,...
Definition X86.h:105
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that transforms setcc + movzx pairs into xor + setcc.
Definition X86.h:145
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that reduces the size of vector constant pool loads.
Definition X86.h:126
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that lowers EFLAGS copy pseudo instructions.
Definition X86.h:166
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This pass initializes a global base register for PIC on x86-32.
Definition X86.h:46
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
X86ISelDAGToDAGPass(X86TargetMachine &TM)
This pass inserts ENDBR instructions before indirect jump/call destinations as part of CET IBT mechan...
Definition X86.h:90
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This pass inserts AVX vzeroupper instructions before each call to avoid transition penalty between fu...
Definition X86.h:80
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This pass insert wait instruction after X87 instructions which could raise fp exceptions when strict-...
Definition X86.h:338
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &FAM)
X86LowerAMXIntrinsicsPass(const TargetMachine *TM)
Definition X86.h:402
X86LowerAMXTypePass(const TargetMachine *TM)
Definition X86.h:378
PreservedAnalyses run(Function &F, FunctionAnalysisManager &FAM)
Return a pass that lower the tile copy instruction.
Definition X86.h:225
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that removes redundant LEA instructions and redundant address recalculations.
Definition X86.h:136
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(Function &F, FunctionAnalysisManager &FAM)
X86PartialReductionPass(const X86TargetMachine *TM)
Definition X86.h:354
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that insert pseudo tile config instruction.
Definition X86.h:215
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
This class provides the information for the target register banks.
This pass replaces ret instructions with jmp's to __x86_return thunk.
Definition X86.h:327
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Return a pass that config the tile registers.
Definition X86.h:185
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
PreservedAnalyses run(Module &M, ModuleAnalysisManager &MAM)
PreservedAnalyses run(MachineFunction &MF, MachineFunctionAnalysisManager &MFAM)
Pass manager infrastructure for declaring and invalidating analyses.
@ PTR32_UPTR
Definition X86.h:527
@ PTR64
Definition X86.h:528
@ PTR32_SPTR
Definition X86.h:526
This is an optimization pass for GlobalISel generic memory operations.
FunctionPass * createX86WinEHUnwindV3Pass()
Capacity check and sub-fragment splitting for Win x64 Unwind V3.
void initializeX86LoadValueInjectionLoadHardeningLegacyPass(PassRegistry &)
FunctionPass * createX86LowerAMXIntrinsicsLegacyPass()
FunctionPass * createX86CompressEVEXLegacyPass()
FunctionPass * createX86FastTileConfigLegacyPass()
void initializeX86PartialReductionLegacyPass(PassRegistry &)
FunctionPass * createX86DomainReassignmentLegacyPass()
FunctionPass * createX86ExpandPseudoLegacyPass()
Returns an instance of the pseudo instruction expansion pass.
FunctionPass * createX86OptimizeLEAsLegacyPass()
void initializeCompressEVEXLegacyPass(PassRegistry &)
void initializeX86PostLegalizerCombinerLegacyPass(PassRegistry &)
FunctionPass * createX86DynAllocaExpanderLegacyPass()
void initializeX86DomainReassignmentLegacyPass(PassRegistry &)
FunctionPass * createX86TileConfigLegacyPass()
FunctionPass * createX86AvoidStoreForwardingBlocksLegacyPass()
void initializeX86LowerAMXIntrinsicsLegacyPassPass(PassRegistry &)
FunctionPass * createX86InsertX87WaitLegacyPass()
FunctionPass * createX86PartialReductionLegacyPass()
void initializeX86CmovConversionLegacyPass(PassRegistry &)
AnalysisManager< MachineFunction > MachineFunctionAnalysisManager
void initializeX86DynAllocaExpanderLegacyPass(PassRegistry &)
FunctionPass * createX86FixupSetCCLegacyPass()
void initializeX86FastPreTileConfigLegacyPass(PassRegistry &)
FunctionPass * createX86SpeculativeExecutionSideEffectSuppressionLegacyPass()
FunctionPass * createX86LoadValueInjectionLoadHardeningLegacyPass()
FunctionPass * createX86PadShortFunctions()
Return a pass that pads short functions with NOOPs.
void initializeX86IndirectBranchTrackingLegacyPass(PassRegistry &)
void initializeX86FastTileConfigLegacyPass(PassRegistry &)
void initializeX86FixupVectorConstantsLegacyPass(PassRegistry &)
FunctionPass * createX86IndirectBranchTrackingLegacyPass()
void initializeX86AsmPrinterPass(PassRegistry &)
FunctionPass * createX86LowerTileCopyLegacyPass()
void initializeX86ExpandPseudoLegacyPass(PassRegistry &)
FunctionPass * createX86CmovConversionLegacyPass()
FunctionPass * createX86ArgumentStackSlotLegacyPass()
void initializeX86SpeculativeExecutionSideEffectSuppressionLegacyPass(PassRegistry &)
void initializeX86FixupInstTuningLegacyPass(PassRegistry &)
void initializeX86FlagsCopyLoweringLegacyPass(PassRegistry &)
FunctionPass * createX86PostLegalizerCombinerLegacy()
void initializeX86AvoidTrailingCallLegacyPassPass(PassRegistry &)
FunctionPass * createX86ISelDag(X86TargetMachine &TM, CodeGenOptLevel OptLevel)
This pass converts a legalized DAG into a X86-specific DAG, ready for instruction scheduling.
FunctionPass * createX86FixupLEAsLegacyPass()
FunctionPass * createX86CallFrameOptimizationLegacyPass()
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
void initializeX86CallFrameOptimizationLegacyPass(PassRegistry &)
FunctionPass * createX86FlagsCopyLoweringLegacyPass()
FunctionPass * createCleanupLocalDynamicTLSLegacyPass()
void initializeX86FixupBWInstLegacyPass(PassRegistry &)
void initializeX86LoadValueInjectionRetHardeningLegacyPass(PassRegistry &)
void initializeX86FPStackifierLegacyPass(PassRegistry &)
void initializeX86LowerTileCopyLegacyPass(PassRegistry &)
void initializeX86SpeculativeLoadHardeningLegacyPass(PassRegistry &)
void initializeX86TileConfigLegacyPass(PassRegistry &)
void initializeFixupLEAsLegacyPass(PassRegistry &)
FunctionPass * createX86PreTileConfigLegacyPass()
FunctionPass * createX86InsertVZeroUpperLegacyPass()
FunctionPass * createX86SpeculativeLoadHardeningLegacyPass()
void initializeX86LowerAMXTypeLegacyPassPass(PassRegistry &)
FunctionPass * createX86ReturnThunksLegacyPass()
void initializeX86ArgumentStackSlotLegacyPass(PassRegistry &)
FunctionPass * createX86FixupBWInstsLegacyPass()
FunctionPass * createX86PreLegalizerCombinerLegacy()
FunctionPass * createX86FPStackifierLegacyPass()
void initializeX86PreTileConfigLegacyPass(PassRegistry &)
FunctionPass * createX86SuppressAPXForRelocationLegacyPass()
FunctionPass * createX86FastPreTileConfigLegacyPass()
FunctionPass * createX86LoadValueInjectionRetHardeningLegacyPass()
FunctionPass * createX86LowerAMXTypeLegacyPass()
void initializeX86WinEHUnwindV3Pass(PassRegistry &)
void initializeX86ReturnThunksLegacyPass(PassRegistry &)
void initializeX86PreLegalizerCombinerLegacyPass(PassRegistry &)
void initializeX86SuppressAPXForRelocationLegacyPass(PassRegistry &)
FunctionPass * createX86WinEHStateLegacyPass()
FunctionPass * createX86FixupVectorConstantsLegacyPass()
void initializeX86FixupSetCCLegacyPass(PassRegistry &)
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
void initializeWinEHStateLegacyPass(PassRegistry &)
FunctionPass * createX86IndirectThunksPass()
This pass creates the thunks for the retpoline feature.
FunctionPass * createX86WinEHUnwindV2LegacyPass()
FunctionPass * createX86FixupInstTuningLegacyPass()
void initializeX86ExecutionDomainFixPass(PassRegistry &)
void initializeX86DAGToDAGISelLegacyPass(PassRegistry &)
void initializeX86OptimizeLEAsLegacyPass(PassRegistry &)
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
Definition MIRParser.h:39
void initializeX86AvoidSFBLegacyPass(PassRegistry &)
void initializeX86WinEHUnwindV2LegacyPass(PassRegistry &)
FunctionPass * createX86AvoidTrailingCallLegacyPass()
InstructionSelector * createX86InstructionSelector(const X86TargetMachine &TM, const X86Subtarget &, const X86RegisterBankInfo &)
FunctionPass * createX86GlobalBaseRegLegacyPass()
A CRTP mix-in for passes that can be skipped.
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition PassManager.h:89
A CRTP mix-in for passes that should not be skipped.