LLVM 23.0.0git
CodeGenPassBuilder.h
Go to the documentation of this file.
1//===- Construction of codegen pass pipelines ------------------*- 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/// \file
9///
10/// Interfaces for producing common pass manager configurations.
11///
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_PASSES_CODEGENPASSBUILDER_H
15#define LLVM_PASSES_CODEGENPASSBUILDER_H
16
18#include "llvm/ADT/StringRef.h"
66#include "llvm/CodeGen/PEI.h"
103#include "llvm/IR/PassManager.h"
104#include "llvm/IR/Verifier.h"
106#include "llvm/MC/MCAsmInfo.h"
109#include "llvm/Support/CodeGen.h"
110#include "llvm/Support/Debug.h"
111#include "llvm/Support/Error.h"
127#include <cassert>
128#include <utility>
129
130namespace llvm {
131
132// FIXME: Dummy target independent passes definitions that have not yet been
133// ported to new pass manager. Once they do, remove these.
134#define DUMMY_FUNCTION_PASS(NAME, PASS_NAME) \
135 struct PASS_NAME : public OptionalPassInfoMixin<PASS_NAME> { \
136 template <typename... Ts> PASS_NAME(Ts &&...) {} \
137 PreservedAnalyses run(Function &, FunctionAnalysisManager &) { \
138 return PreservedAnalyses::all(); \
139 } \
140 };
141#define DUMMY_MACHINE_MODULE_PASS(NAME, PASS_NAME) \
142 struct PASS_NAME : public OptionalPassInfoMixin<PASS_NAME> { \
143 template <typename... Ts> PASS_NAME(Ts &&...) {} \
144 PreservedAnalyses run(Module &, ModuleAnalysisManager &) { \
145 return PreservedAnalyses::all(); \
146 } \
147 };
148#define DUMMY_MACHINE_FUNCTION_PASS(NAME, PASS_NAME) \
149 struct PASS_NAME : public OptionalPassInfoMixin<PASS_NAME> { \
150 template <typename... Ts> PASS_NAME(Ts &&...) {} \
151 PreservedAnalyses run(MachineFunction &, \
152 MachineFunctionAnalysisManager &) { \
153 return PreservedAnalyses::all(); \
154 } \
155 };
156#include "llvm/Passes/MachinePassRegistry.def"
157
158class PassManagerWrapper {
159private:
160 PassManagerWrapper(ModulePassManager &ModulePM) : MPM(ModulePM) {};
161
165
166 template <typename DerivedT, typename TargetMachineT>
167 friend class CodeGenPassBuilder;
168};
169
170/// This class provides access to building LLVM's passes.
171///
172/// Its members provide the baseline state available to passes during their
173/// construction. The \c MachinePassRegistry.def file specifies how to construct
174/// all of the built-in passes, and those may reference these members during
175/// construction.
176template <typename DerivedT, typename TargetMachineT> class CodeGenPassBuilder {
177public:
178 explicit CodeGenPassBuilder(TargetMachineT &TM,
179 const CGPassBuilderOption &Opts,
181 : TM(TM), Opt(Opts), PIC(PIC) {
182 // Target could set CGPassBuilderOption::MISchedPostRA to true to achieve
183 // substitutePass(&PostRASchedulerID, &PostMachineSchedulerID)
184
185 // Target should override TM.Options.EnableIPRA in their target-specific
186 // LLVMTM ctor. See TargetMachine::setGlobalISel for example.
187 if (Opt.EnableIPRA) {
188 TM.Options.EnableIPRA = *Opt.EnableIPRA;
189 } else {
190 // If not explicitly specified, use target default.
191 TM.Options.EnableIPRA |= TM.useIPRA();
192 }
193
194 if (Opt.EnableGlobalISelAbort)
195 TM.Options.GlobalISelAbort = *Opt.EnableGlobalISelAbort;
196
197 if (Opt.OptimizeRegAlloc == cl::boolOrDefault::BOU_UNSET)
198 Opt.OptimizeRegAlloc = getOptLevel() != CodeGenOptLevel::None
201 }
202
205 CodeGenFileType FileType, MCContext &Ctx) const;
206
210
211protected:
212 template <typename PassT>
213 using is_module_pass_t = decltype(std::declval<PassT &>().run(
214 std::declval<Module &>(), std::declval<ModuleAnalysisManager &>()));
215
216 template <typename PassT>
217 using is_function_pass_t = decltype(std::declval<PassT &>().run(
218 std::declval<Function &>(), std::declval<FunctionAnalysisManager &>()));
219
220 template <typename PassT>
221 using is_machine_function_pass_t = decltype(std::declval<PassT &>().run(
222 std::declval<MachineFunction &>(),
223 std::declval<MachineFunctionAnalysisManager &>()));
224
225 template <typename PassT>
227 bool Force = false,
228 StringRef Name = PassT::name()) const {
230 "Only function passes are supported.");
231 if (!Force && !runBeforeAdding(Name))
232 return;
233 PMW.FPM.addPass(std::forward<PassT>(Pass));
234 }
235
236 template <typename PassT>
237 void addModulePass(PassT &&Pass, PassManagerWrapper &PMW, bool Force = false,
238 StringRef Name = PassT::name()) const {
240 "Only module passes are suported.");
241 assert(PMW.FPM.isEmpty() && PMW.MFPM.isEmpty() &&
242 "You cannot insert a module pass without first flushing the current "
243 "function pipelines to the module pipeline.");
244 if (!Force && !runBeforeAdding(Name))
245 return;
246 PMW.MPM.addPass(std::forward<PassT>(Pass));
247 }
248
249 template <typename PassT>
251 bool Force = false,
252 StringRef Name = PassT::name()) const {
254 "Only machine function passes are supported.");
255
256 if (!Force && !runBeforeAdding(Name))
257 return;
258 PMW.MFPM.addPass(std::forward<PassT>(Pass));
259 for (auto &C : AfterCallbacks)
260 C(Name, PMW.MFPM);
261 }
262
264 bool FreeMachineFunctions = false) const {
265 if (PMW.FPM.isEmpty() && PMW.MFPM.isEmpty())
266 return;
267 if (!PMW.MFPM.isEmpty()) {
268 PMW.FPM.addPass(
269 createFunctionToMachineFunctionPassAdaptor(std::move(PMW.MFPM)));
270 PMW.MFPM = MachineFunctionPassManager();
271 }
272 if (FreeMachineFunctions)
274 if (AddInCGSCCOrder) {
276 createCGSCCToFunctionPassAdaptor(std::move(PMW.FPM))));
277 } else {
278 PMW.MPM.addPass(createModuleToFunctionPassAdaptor(std::move(PMW.FPM)));
279 }
280 PMW.FPM = FunctionPassManager();
281 }
282
284 assert(!AddInCGSCCOrder);
285 assert(PMW.FPM.isEmpty() && PMW.MFPM.isEmpty() &&
286 "Requiring CGSCC ordering requires flushing the current function "
287 "pipelines to the MPM.");
288 AddInCGSCCOrder = true;
289 }
290
292 assert(AddInCGSCCOrder);
293 assert(PMW.FPM.isEmpty() && PMW.MFPM.isEmpty() &&
294 "Stopping CGSCC ordering requires flushing the current function "
295 "pipelines to the MPM.");
296 AddInCGSCCOrder = false;
297 }
298
299 TargetMachineT &TM;
302
303 template <typename TMC> TMC &getTM() const { return static_cast<TMC &>(TM); }
304 CodeGenOptLevel getOptLevel() const { return TM.getOptLevel(); }
305
306 /// Check whether or not GlobalISel should abort on error.
307 /// When this is disabled, GlobalISel will fall back on SDISel instead of
308 /// erroring out.
310 return TM.Options.GlobalISelAbort == GlobalISelAbortMode::Enable;
311 }
312
313 /// Check whether or not a diagnostic should be emitted when GlobalISel
314 /// uses the fallback path. In other words, it will emit a diagnostic
315 /// when GlobalISel failed and isGlobalISelAbortEnabled is false.
317 return TM.Options.GlobalISelAbort == GlobalISelAbortMode::DisableWithDiag;
318 }
319
320 /// addInstSelector - This method should install an instruction selector pass,
321 /// which converts from LLVM code to machine instructions.
323 return make_error<StringError>("addInstSelector is not overridden",
325 }
326
327 /// Target can override this to add GlobalMergePass before all IR passes.
329
330 /// Add passes that optimize instruction level parallelism for out-of-order
331 /// targets. These passes are run while the machine code is still in SSA
332 /// form, so they can use MachineTraceMetrics to control their heuristics.
333 ///
334 /// All passes added here should preserve the MachineDominatorTree,
335 /// MachineLoopInfo, and MachineTraceMetrics analyses.
336 void addILPOpts(PassManagerWrapper &PMW) const {}
337
338 /// This method may be implemented by targets that want to run passes
339 /// immediately before register allocation.
341
342 /// addPreRewrite - Add passes to the optimized register allocation pipeline
343 /// after register allocation is complete, but before virtual registers are
344 /// rewritten to physical registers.
345 ///
346 /// These passes must preserve VirtRegMap and LiveIntervals, and when running
347 /// after RABasic or RAGreedy, they should take advantage of LiveRegMatrix.
348 /// When these passes run, VirtRegMap contains legal physreg assignments for
349 /// all virtual registers.
350 ///
351 /// Note if the target overloads addRegAssignAndRewriteOptimized, this may not
352 /// be honored. This is also not generally used for the fast variant,
353 /// where the allocation and rewriting are done in one pass.
355
356 /// Add passes to be run immediately after virtual registers are rewritten
357 /// to physical registers.
359
360 /// This method may be implemented by targets that want to run passes after
361 /// register allocation pass pipeline but before prolog-epilog insertion.
363
364 /// This method may be implemented by targets that want to run passes after
365 /// prolog-epilog insertion and before the second instruction scheduling pass.
367
368 /// This pass may be implemented by targets that want to run passes
369 /// immediately before machine code is emitted.
371
372 /// Targets may add passes immediately before machine code is emitted in this
373 /// callback. This is called even later than `addPreEmitPass`.
374 // FIXME: Rename `addPreEmitPass` to something more sensible given its actual
375 // position and remove the `2` suffix here as this callback is what
376 // `addPreEmitPass` *should* be but in reality isn't.
378
379 /// {{@ For GlobalISel
380 ///
381
382 /// addPreISel - This method should add any "last minute" LLVM->LLVM
383 /// passes (which are run just before instruction selector).
385 llvm_unreachable("addPreISel is not overridden");
386 }
387
388 /// This method should install an IR translator pass, which converts from
389 /// LLVM code to machine instructions with possibly generic opcodes.
391 return make_error<StringError>("addIRTranslator is not overridden",
393 }
394
395 /// This method may be implemented by targets that want to run passes
396 /// immediately before legalization.
398
399 /// This method should install a legalize pass, which converts the instruction
400 /// sequence into one that can be selected by the target.
402 return make_error<StringError>("addLegalizeMachineIR is not overridden",
404 }
405
406 /// This method may be implemented by targets that want to run passes
407 /// immediately before the register bank selection.
409
410 /// This method should install a register bank selector pass, which
411 /// assigns register banks to virtual registers without a register
412 /// class or register banks.
414 return make_error<StringError>("addRegBankSelect is not overridden",
416 }
417
418 /// This method may be implemented by targets that want to run passes
419 /// immediately before the (global) instruction selection.
421
422 /// This method should install a (global) instruction selector pass, which
423 /// converts possibly generic instructions to fully target-specific
424 /// instructions, thereby constraining all generic virtual registers to
425 /// register classes.
428 "addGlobalInstructionSelect is not overridden",
430 }
431 /// @}}
432
433 /// High level function that adds all passes necessary to go from llvm IR
434 /// representation to the MI representation.
435 /// Adds IR based lowering and target specific optimization passes and finally
436 /// the core instruction selection passes.
438
439 /// Add the actual instruction selection passes. This does not include
440 /// preparation passes on IR.
442
443 /// Add the complete, standard set of LLVM CodeGen passes.
444 /// Fully developed targets will not generally override this.
446
447 /// Add passes to lower exception handling for the code generator.
449
450 /// Add common target configurable passes that perform LLVM IR to IR
451 /// transforms following machine independent optimization.
453
454 /// Add pass to prepare the LLVM IR for code generation. This should be done
455 /// before exception handling preparation passes.
457
458 /// Add common passes that perform LLVM IR to IR transforms in preparation for
459 /// instruction selection.
461
462 /// Methods with trivial inline returns are convenient points in the common
463 /// codegen pass pipeline where targets may insert passes. Methods with
464 /// out-of-line standard implementations are major CodeGen stages called by
465 /// addMachinePasses. Some targets may override major stages when inserting
466 /// passes is insufficient, but maintaining overriden stages is more work.
467 ///
468
469 /// addMachineSSAOptimization - Add standard passes that optimize machine
470 /// instructions in SSA form.
472
473 /// addFastRegAlloc - Add the minimum set of target-independent passes that
474 /// are required for fast register allocation.
476
477 /// addOptimizedRegAlloc - Add passes related to register allocation.
478 /// CodeGenTargetMachineImpl provides standard regalloc passes for most
479 /// targets.
481
482 /// Add passes that optimize machine instructions after register allocation.
484
485 /// addGCPasses - Add late codegen passes that analyze code for garbage
486 /// collection. This should return true if GC info should be printed after
487 /// these passes.
488 void addGCPasses(PassManagerWrapper &PMW) const {}
489
490 /// Add standard basic block placement passes.
492
494
496 llvm_unreachable("addAsmPrinterBegin is not overriden");
497 }
498
500 llvm_unreachable("addAsmPrinter is not overridden");
501 }
502
504 llvm_unreachable("addAsmPrinterEnd is not overriden");
505 }
506
507 /// Utilities for targets to add passes to the pass manager.
508 ///
509
510 /// createTargetRegisterAllocator - Create the register allocator pass for
511 /// this target at the current optimization level.
513 bool Optimized) const;
514
515 /// addMachinePasses helper to create the target-selected or overriden
516 /// regalloc pass.
517 void addRegAllocPass(PassManagerWrapper &PMW, bool Optimized) const;
518
519 /// Add core register allocator passes which do the actual register assignment
520 /// and rewriting.
523
524 /// Allow the target to disable a specific pass by default.
525 /// Backend can declare unwanted passes in constructor.
526 template <typename... PassTs> void disablePass() {
527 BeforeCallbacks.emplace_back(
528 [](StringRef Name) { return ((Name != PassTs::name()) && ...); });
529 }
530
531 /// Insert InsertedPass pass after TargetPass pass.
532 /// Only machine function passes are supported.
533 template <typename TargetPassT, typename InsertedPassT>
534 void insertPass(InsertedPassT &&Pass) const {
535 AfterCallbacks.emplace_back(
536 [&](StringRef Name, MachineFunctionPassManager &MFPM) mutable {
537 if (Name == TargetPassT::name() &&
538 runBeforeAdding(InsertedPassT::name())) {
539 MFPM.addPass(std::forward<InsertedPassT>(Pass));
540 }
541 });
542 }
543
544private:
545 DerivedT &derived() { return static_cast<DerivedT &>(*this); }
546 const DerivedT &derived() const {
547 return static_cast<const DerivedT &>(*this);
548 }
549
550 bool runBeforeAdding(StringRef Name) const {
551 bool ShouldAdd = true;
552 for (auto &C : BeforeCallbacks)
553 ShouldAdd &= C(Name);
554 return ShouldAdd;
555 }
556
557 void setStartStopPasses(const TargetPassConfig::StartStopInfo &Info) const;
558
559 Error verifyStartStop(const TargetPassConfig::StartStopInfo &Info) const;
560
561 mutable SmallVector<llvm::unique_function<bool(StringRef)>, 4>
562 BeforeCallbacks;
563 mutable SmallVector<
564 llvm::unique_function<void(StringRef, MachineFunctionPassManager &)>, 4>
565 AfterCallbacks;
566
567 /// Helper variable for `-start-before/-start-after/-stop-before/-stop-after`
568 mutable bool Started = true;
569 mutable bool Stopped = true;
570 mutable bool AddInCGSCCOrder = false;
571};
572
573template <typename Derived, typename TargetMachineT>
576 raw_pwrite_stream *DwoOut, CodeGenFileType FileType, MCContext &Ctx) const {
577 auto StartStopInfo = TargetPassConfig::getStartStopInfo(*PIC);
578 if (!StartStopInfo)
579 return StartStopInfo.takeError();
580 setStartStopPasses(*StartStopInfo);
581
583 bool PrintMIR = !PrintAsm && FileType != CodeGenFileType::Null;
584
585 PassManagerWrapper PMW(MPM);
586
588 /*Force=*/true);
590 /*Force=*/true);
592 /*Force=*/true);
594 /*Force=*/true);
596 PMW,
597 /*Force=*/true);
598 addISelPasses(PMW);
599 flushFPMsToMPM(PMW);
600
601 if (PrintAsm) {
602 Expected<std::unique_ptr<MCStreamer>> MCStreamerOrErr =
603 TM.createMCStreamer(Out, DwoOut, FileType, Ctx);
604 if (!MCStreamerOrErr)
605 return MCStreamerOrErr.takeError();
606 std::unique_ptr<AsmPrinter> Printer(
607 TM.getTarget().createAsmPrinter(TM, std::move(*MCStreamerOrErr)));
608 if (!Printer)
609 return createStringError("failed to create AsmPrinter");
610 MAM.registerPass([&] { return AsmPrinterAnalysis(std::move(Printer)); });
611 derived().addAsmPrinterBegin(PMW);
612 }
613
614 if (PrintMIR)
615 addModulePass(PrintMIRPreparePass(Out), PMW, /*Force=*/true);
616
617 if (auto Err = addCoreISelPasses(PMW))
618 return std::move(Err);
619
620 if (auto Err = derived().addMachinePasses(PMW))
621 return std::move(Err);
622
623 if (!Opt.DisableVerify)
625
626 if (PrintAsm) {
627 derived().addAsmPrinter(PMW);
628 flushFPMsToMPM(PMW, /*FreeMachineFunctions=*/true);
629 derived().addAsmPrinterEnd(PMW);
630 } else {
631 if (PrintMIR)
632 addMachineFunctionPass(PrintMIRPass(Out), PMW, /*Force=*/true);
633 flushFPMsToMPM(PMW, /*FreeMachineFunctions=*/true);
634 }
635
636 return verifyStartStop(*StartStopInfo);
637}
638
639template <typename Derived, typename TargetMachineT>
640void CodeGenPassBuilder<Derived, TargetMachineT>::setStartStopPasses(
641 const TargetPassConfig::StartStopInfo &Info) const {
642 if (!Info.StartPass.empty()) {
643 Started = false;
644 BeforeCallbacks.emplace_back([this, &Info, AfterFlag = Info.StartAfter,
645 Count = 0u](StringRef ClassName) mutable {
646 if (Count == Info.StartInstanceNum) {
647 if (AfterFlag) {
648 AfterFlag = false;
649 Started = true;
650 }
651 return Started;
652 }
653
654 auto PassName = PIC->getPassNameForClassName(ClassName);
655 if (Info.StartPass == PassName && ++Count == Info.StartInstanceNum)
656 Started = !Info.StartAfter;
657
658 return Started;
659 });
660 }
661
662 if (!Info.StopPass.empty()) {
663 Stopped = false;
664 BeforeCallbacks.emplace_back([this, &Info, AfterFlag = Info.StopAfter,
665 Count = 0u](StringRef ClassName) mutable {
666 if (Count == Info.StopInstanceNum) {
667 if (AfterFlag) {
668 AfterFlag = false;
669 Stopped = true;
670 }
671 return !Stopped;
672 }
673
674 auto PassName = PIC->getPassNameForClassName(ClassName);
675 if (Info.StopPass == PassName && ++Count == Info.StopInstanceNum)
676 Stopped = !Info.StopAfter;
677 return !Stopped;
678 });
679 }
680}
681
682template <typename Derived, typename TargetMachineT>
683Error CodeGenPassBuilder<Derived, TargetMachineT>::verifyStartStop(
684 const TargetPassConfig::StartStopInfo &Info) const {
685 if (Started && Stopped)
686 return Error::success();
687
688 if (!Started)
690 "Can't find start pass \"" + Info.StartPass + "\".",
691 std::make_error_code(std::errc::invalid_argument));
692 if (!Stopped)
694 "Can't find stop pass \"" + Info.StopPass + "\".",
695 std::make_error_code(std::errc::invalid_argument));
696 return Error::success();
697}
698
699template <typename Derived, typename TargetMachineT>
701 PassManagerWrapper &PMW) const {
702 derived().addGlobalMergePass(PMW);
703 if (TM.useEmulatedTLS())
705
706 // ObjCARCContract operates on ObjC intrinsics and must run before
707 // PreISelIntrinsicLowering.
710 flushFPMsToMPM(PMW);
711 }
714
715 derived().addIRPasses(PMW);
716 derived().addCodeGenPrepare(PMW);
718 derived().addISelPrepare(PMW);
719}
720
721/// Add common target configurable passes that perform LLVM IR to IR transforms
722/// following machine independent optimization.
723template <typename Derived, typename TargetMachineT>
725 PassManagerWrapper &PMW) const {
726 // Before running any passes, run the verifier to determine if the input
727 // coming from the front-end and/or optimizer is valid.
728 if (!Opt.DisableVerify)
729 addFunctionPass(VerifierPass(), PMW, /*Force=*/true);
730
731 // Run loop strength reduction before anything else.
732 if (getOptLevel() != CodeGenOptLevel::None && !Opt.DisableLSR) {
733 // These passes do not use MSSA.
734 LoopPassManager LPM;
735 LPM.addPass(CanonicalizeFreezeInLoopsPass());
736 LPM.addPass(LoopStrengthReducePass());
737 if (Opt.EnableLoopTermFold)
738 LPM.addPass(LoopTermFoldPass());
740 /*UseMemorySSA=*/false),
741 PMW);
742 }
743
744 // Run GC lowering passes for builtin collectors
745 // TODO: add a pass insertion point here
747 // Explicitly check to see if we should add ShadowStackGCLowering to avoid
748 // splitting the function pipeline if we do not have to.
749 if (runBeforeAdding(ShadowStackGCLoweringPass::name())) {
750 flushFPMsToMPM(PMW);
752 }
753
754 // Make sure that no unreachable blocks are instruction selected.
756
757 // Prepare expensive constants for SelectionDAG.
758 if (getOptLevel() != CodeGenOptLevel::None && !Opt.DisableConstantHoisting)
760
761 // Replace calls to LLVM intrinsics (e.g., exp, log) operating on vector
762 // operands with calls to the corresponding functions in a vector library.
765
767 !Opt.DisablePartialLibcallInlining)
769
770 // Instrument function entry and exit, e.g. with calls to mcount().
771 addFunctionPass(EntryExitInstrumenterPass(/*PostInlining=*/true), PMW);
772
773 // Add scalarization of target's unsupported masked memory intrinsics pass.
774 // the unsupported intrinsic will be replaced with a chain of basic blocks,
775 // that stores/loads element one-by-one if the appropriate mask bit is set.
777
778 // Expand reduction intrinsics into shuffle sequences if the target wants to.
779 if (!Opt.DisableExpandReductions)
781
782 // Convert conditional moves to conditional jumps when profitable.
783 if (getOptLevel() != CodeGenOptLevel::None && !Opt.DisableSelectOptimize)
785
786 if (Opt.EnableGlobalMergeFunc) {
787 flushFPMsToMPM(PMW);
789 }
790}
791
792/// Turn exception handling constructs into something the code generators can
793/// handle.
794template <typename Derived, typename TargetMachineT>
796 PassManagerWrapper &PMW) const {
797 const MCAsmInfo &MCAI = TM.getMCAsmInfo();
798 switch (MCAI.getExceptionHandlingType()) {
800 // SjLj piggy-backs on dwarf for this bit. The cleanups done apply to both
801 // Dwarf EH prepare needs to be run after SjLj prepare. Otherwise,
802 // catch info can get misplaced when a selector ends up more than one block
803 // removed from the parent invoke(s). This could happen when a landing
804 // pad is shared by multiple invokes and is also a target of a normal
805 // edge from elsewhere.
807 [[fallthrough]];
813 break;
815 // We support using both GCC-style and MSVC-style exceptions on Windows, so
816 // add both preparation passes. Each pass will only actually run if it
817 // recognizes the personality function.
820 break;
822 // Wasm EH uses Windows EH instructions, but it does not need to demote PHIs
823 // on catchpads and cleanuppads because it does not outline them into
824 // funclets. Catchswitch blocks are not lowered in SelectionDAG, so we
825 // should remove PHIs there.
826 addFunctionPass(WinEHPreparePass(/*DemoteCatchSwitchPHIOnly=*/false), PMW);
828 break;
831
832 // The lower invoke pass may create unreachable code. Remove it.
834 break;
835 }
836}
837
838/// Add pass to prepare the LLVM IR for code generation. This should be done
839/// before exception handling preparation passes.
840template <typename Derived, typename TargetMachineT>
842 PassManagerWrapper &PMW) const {
843 if (getOptLevel() != CodeGenOptLevel::None && !Opt.DisableCGP)
845 // TODO: Default ctor'd RewriteSymbolPass is no-op.
846 // addPass(RewriteSymbolPass());
847}
848
849/// Add common passes that perform LLVM IR to IR transforms in preparation for
850/// instruction selection.
851template <typename Derived, typename TargetMachineT>
853 PassManagerWrapper &PMW) const {
854 derived().addPreISel(PMW);
855
856 if (Opt.RequiresCodeGenSCCOrder && !AddInCGSCCOrder)
858
860 // Add both the safe stack and the stack protection passes: each of them will
861 // only protect functions that have corresponding attributes.
864
865 if (Opt.PrintISelInput)
867 dbgs(), "\n\n*** Final LLVM Code input to ISel ***\n"),
868 PMW);
869
870 // All passes which modify the LLVM IR are now complete; run the verifier
871 // to ensure that the IR is valid.
872 if (!Opt.DisableVerify)
873 addFunctionPass(VerifierPass(), PMW, /*Force=*/true);
874}
875
876template <typename Derived, typename TargetMachineT>
878 PassManagerWrapper &PMW) const {
879 // Enable FastISel with -fast-isel, but allow that to be overridden.
880 TM.setO0WantsFastISel(Opt.EnableFastISelOption !=
882
883 // Determine an instruction selector.
884 enum class SelectorType { SelectionDAG, FastISel, GlobalISel };
885 SelectorType Selector;
886
887 if (Opt.EnableFastISelOption == cl::boolOrDefault::BOU_TRUE)
888 Selector = SelectorType::FastISel;
889 else if (Opt.EnableGlobalISelOption == cl::boolOrDefault::BOU_TRUE ||
890 (TM.Options.EnableGlobalISel &&
891 Opt.EnableGlobalISelOption != cl::boolOrDefault::BOU_FALSE))
892 Selector = SelectorType::GlobalISel;
893 else if (TM.getOptLevel() == CodeGenOptLevel::None && TM.getO0WantsFastISel())
894 Selector = SelectorType::FastISel;
895 else
896 Selector = SelectorType::SelectionDAG;
897
898 // Set consistently TM.Options.EnableFastISel and EnableGlobalISel.
899 if (Selector == SelectorType::FastISel) {
900 TM.setFastISel(true);
901 TM.setGlobalISel(false);
902 } else if (Selector == SelectorType::GlobalISel) {
903 TM.setFastISel(false);
904 TM.setGlobalISel(true);
905 }
906
907 // Add instruction selector passes.
908 if (Selector == SelectorType::GlobalISel) {
909 if (auto Err = derived().addIRTranslator(PMW))
910 return std::move(Err);
911
912 derived().addPreLegalizeMachineIR(PMW);
913
914 if (auto Err = derived().addLegalizeMachineIR(PMW))
915 return std::move(Err);
916
917 // Before running the register bank selector, ask the target if it
918 // wants to run some passes.
919 derived().addPreRegBankSelect(PMW);
920
921 if (auto Err = derived().addRegBankSelect(PMW))
922 return std::move(Err);
923
924 derived().addPreGlobalInstructionSelect(PMW);
925
926 if (auto Err = derived().addGlobalInstructionSelect(PMW))
927 return std::move(Err);
928
929 // Pass to reset the MachineFunction if the ISel failed.
931 ResetMachineFunctionPass(reportDiagnosticWhenGlobalISelFallback(),
933 PMW);
934
935 // Provide a fallback path when we do not want to abort on
936 // not-yet-supported input.
938 if (auto Err = derived().addInstSelector(PMW))
939 return std::move(Err);
940
941 } else if (auto Err = derived().addInstSelector(PMW))
942 return std::move(Err);
943
944 // Expand pseudo-instructions emitted by ISel. Don't run the verifier before
945 // FinalizeISel.
947
948 // // Print the instruction selected machine code...
949 // printAndVerify("After Instruction Selection");
950
951 return Error::success();
952}
953
954/// Add the complete set of target-independent postISel code generator passes.
955///
956/// This can be read as the standard order of major LLVM CodeGen stages. Stages
957/// with nontrivial configuration or multiple passes are broken out below in
958/// add%Stage routines.
959///
960/// Any CodeGenPassBuilder<Derived, TargetMachine>::addXX routine may be
961/// overriden by the Target. The addPre/Post methods with empty header
962/// implementations allow injecting target-specific fixups just before or after
963/// major stages. Additionally, targets have the flexibility to change pass
964/// order within a stage by overriding default implementation of add%Stage
965/// routines below. Each technique has maintainability tradeoffs because
966/// alternate pass orders are not well supported. addPre/Post works better if
967/// the target pass is easily tied to a common pass. But if it has subtle
968/// dependencies on multiple passes, the target should override the stage
969/// instead.
970template <typename Derived, typename TargetMachineT>
972 PassManagerWrapper &PMW) const {
973 // Add passes that optimize machine instructions in SSA form.
975 derived().addMachineSSAOptimization(PMW);
976 } else {
977 // If the target requests it, assign local variables to stack slots relative
978 // to one another and simplify frame index references where possible.
980 }
981
982 if (TM.Options.EnableIPRA) {
983 flushFPMsToMPM(PMW);
985 PMW, /*Force=*/true);
987 }
988 // Run pre-ra passes.
989 derived().addPreRegAlloc(PMW);
990
991 // Run register allocation and passes that are tightly coupled with it,
992 // including phi elimination and scheduling.
993 if (auto Err = Opt.OptimizeRegAlloc == cl::boolOrDefault::BOU_TRUE
994 ? derived().addOptimizedRegAlloc(PMW)
995 : derived().addFastRegAlloc(PMW))
996 return std::move(Err);
997
998 // Run post-ra passes.
999 derived().addPostRegAlloc(PMW);
1000
1003
1004 // Insert prolog/epilog code. Eliminate abstract frame index references...
1008 }
1009
1011
1012 /// Add passes that optimize machine instructions after register allocation.
1014 derived().addMachineLateOptimization(PMW);
1015
1016 // Expand pseudo instructions before second scheduling pass.
1018
1019 // Run pre-sched2 passes.
1020 derived().addPreSched2(PMW);
1021
1022 if (Opt.EnableImplicitNullChecks)
1023 addMachineFunctionPass(ImplicitNullChecksPass(), PMW);
1024
1025 // Second pass scheduler.
1026 // Let Target optionally insert this pass by itself at some other
1027 // point.
1029 !TM.targetSchedulesPostRAScheduling()) {
1030 if (Opt.MISchedPostRA)
1032 else
1034 }
1035
1036 // GC
1037 derived().addGCPasses(PMW);
1038
1039 // Basic block placement.
1041 derived().addBlockPlacement(PMW);
1042
1043 // Insert before XRay Instrumentation.
1045
1048
1049 derived().addPreEmitPass(PMW);
1050
1051 if (TM.Options.EnableIPRA) {
1052 // Collect register usage information and produce a register mask of
1053 // clobbered registers, to be used to optimize call sites.
1055 // If -print-regusage is specified, print the collected register usage info.
1056 if (Opt.PrintRegUsage) {
1057 flushFPMsToMPM(PMW);
1059 }
1060 }
1061
1062 addMachineFunctionPass(FuncletLayoutPass(), PMW);
1063
1065 addMachineFunctionPass(StackMapLivenessPass(), PMW);
1068 getTM<TargetMachine>().Options.ShouldEmitDebugEntryValues()),
1069 PMW);
1071
1072 if (TM.Options.EnableMachineOutliner &&
1074 Opt.EnableMachineOutliner != RunOutliner::NeverOutline) {
1075 if (Opt.EnableMachineOutliner != RunOutliner::TargetDefault ||
1076 TM.Options.SupportsDefaultOutlining) {
1077 flushFPMsToMPM(PMW);
1078 addModulePass(MachineOutlinerPass(Opt.EnableMachineOutliner), PMW);
1079 }
1080 }
1081
1082 if (Opt.EnableGCEmptyBlocks)
1084
1085 derived().addPostBBSections(PMW);
1086
1088
1089 // Add passes that directly emit MI after all other MI passes.
1090 derived().addPreEmitPass2(PMW);
1091
1092 return Error::success();
1093}
1094
1095/// Add passes that optimize machine instructions in SSA form.
1096template <typename Derived, typename TargetMachineT>
1098 PassManagerWrapper &PMW) const {
1099 // Pre-ra tail duplication.
1101
1102 // Optimize PHIs before DCE: removing dead PHI cycles may make more
1103 // instructions dead.
1105
1106 // This pass merges large allocas. StackSlotColoring is a different pass
1107 // which merges spill slots.
1109
1110 // If the target requests it, assign local variables to stack slots relative
1111 // to one another and simplify frame index references where possible.
1113
1114 // With optimization, dead code should already be eliminated. However
1115 // there is one known exception: lowered code for arguments that are only
1116 // used by tail calls, where the tail calls reuse the incoming stack
1117 // arguments directly (see t11 in test/CodeGen/X86/sibcall.ll).
1119
1120 // Allow targets to insert passes that improve instruction level parallelism,
1121 // like if-conversion. Such passes will typically need dominator trees and
1122 // loop info, just like LICM and CSE below.
1123 derived().addILPOpts(PMW);
1124
1127
1128 addMachineFunctionPass(MachineSinkingPass(Opt.EnableSinkAndFold), PMW);
1129
1131 // Clean-up the dead code that may have been generated by peephole
1132 // rewriting.
1134}
1135
1136//===---------------------------------------------------------------------===//
1137/// Register Allocation Pass Configuration
1138//===---------------------------------------------------------------------===//
1139
1140/// Instantiate the default register allocator pass for this target for either
1141/// the optimized or unoptimized allocation path. This will be added to the pass
1142/// manager by addFastRegAlloc in the unoptimized case or addOptimizedRegAlloc
1143/// in the optimized case.
1144///
1145/// A target that uses the standard regalloc pass order for fast or optimized
1146/// allocation may still override this for per-target regalloc
1147/// selection. But -regalloc-npm=... always takes precedence.
1148/// If a target does not want to allow users to set -regalloc-npm=... at all,
1149/// check if Opt.RegAlloc == RegAllocType::Unset.
1150template <typename Derived, typename TargetMachineT>
1152 PassManagerWrapper &PMW, bool Optimized) const {
1153 if (Optimized)
1155 else
1157}
1158
1159/// Find and instantiate the register allocation pass requested by this target
1160/// at the current optimization level. Different register allocators are
1161/// defined as separate passes because they may require different analysis.
1162///
1163/// This helper ensures that the -regalloc-npm= option is always available,
1164/// even for targets that override the default allocator.
1165template <typename Derived, typename TargetMachineT>
1167 PassManagerWrapper &PMW, bool Optimized) const {
1168 // Use the specified -regalloc-npm={basic|greedy|fast|pbqp}
1169 if (Opt.RegAlloc > RegAllocType::Default) {
1170 switch (Opt.RegAlloc) {
1171 case RegAllocType::Fast:
1173 break;
1176 break;
1177 default:
1178 reportFatalUsageError("register allocator not supported yet");
1179 }
1180 return;
1181 }
1182 // -regalloc=default or unspecified, so pick based on the optimization level
1183 // or ask the target for the regalloc pass.
1184 derived().addTargetRegisterAllocator(PMW, Optimized);
1185}
1186
1187template <typename Derived, typename TargetMachineT>
1189 PassManagerWrapper &PMW) const {
1190 // TODO: Ensure allocator is default or fast.
1191 addRegAllocPass(PMW, false);
1192 return Error::success();
1193}
1194
1195template <typename Derived, typename TargetMachineT>
1197 PassManagerWrapper &PMW) const {
1198 // Add the selected register allocation pass.
1199 addRegAllocPass(PMW, true);
1200
1201 // Allow targets to change the register assignments before rewriting.
1202 derived().addPreRewrite(PMW);
1203
1204 // Finally rewrite virtual registers.
1206 // Perform stack slot coloring and post-ra machine LICM.
1207 //
1208 // FIXME: Re-enable coloring with register when it's capable of adding
1209 // kill markers.
1211
1212 return Error::success();
1213}
1214
1215/// Add the minimum set of target-independent passes that are required for
1216/// register allocation. No coalescing or scheduling.
1217template <typename Derived, typename TargetMachineT>
1224
1225/// Add standard target-independent passes that are tightly coupled with
1226/// optimized register allocation, including coalescing, machine instruction
1227/// scheduling, and register allocation itself.
1228template <typename Derived, typename TargetMachineT>
1230 PassManagerWrapper &PMW) const {
1232
1234
1236
1237 // LiveVariables currently requires pure SSA form.
1238 //
1239 // FIXME: Once TwoAddressInstruction pass no longer uses kill flags,
1240 // LiveVariables can be removed completely, and LiveIntervals can be directly
1241 // computed. (We still either need to regenerate kill flags after regalloc, or
1242 // preferably fix the scavenger to not depend on them).
1243 // FIXME: UnreachableMachineBlockElim is a dependant pass of LiveVariables.
1244 // When LiveVariables is removed this has to be removed/moved either.
1245 // Explicit addition of UnreachableMachineBlockElim allows stopping before or
1246 // after it with -stop-before/-stop-after.
1250
1251 // Edge splitting is smarter with machine loop info.
1255
1256 // Eventually, we want to run LiveIntervals before PHI elimination.
1257 if (Opt.EarlyLiveIntervals)
1260
1263
1264 // The machine scheduler may accidentally create disconnected components
1265 // when moving subregister definitions around, avoid this by splitting them to
1266 // separate vregs before. Splitting can also improve reg. allocation quality.
1268
1269 // PreRA instruction scheduling.
1271
1272 if (auto E = derived().addRegAssignmentOptimized(PMW))
1273 return std::move(E);
1274
1276
1277 // Allow targets to expand pseudo instructions depending on the choice of
1278 // registers before MachineCopyPropagation.
1279 derived().addPostRewrite(PMW);
1280
1281 // Copy propagate to forward register uses and try to eliminate COPYs that
1282 // were not coalesced.
1284
1285 // Run post-ra machine LICM to hoist reloads / remats.
1286 //
1287 // FIXME: can this move into MachineLateOptimization?
1289
1290 return Error::success();
1291}
1292
1293//===---------------------------------------------------------------------===//
1294/// Post RegAlloc Pass Configuration
1295//===---------------------------------------------------------------------===//
1296
1297/// Add passes that optimize machine instructions after register allocation.
1298template <typename Derived, typename TargetMachineT>
1300 PassManagerWrapper &PMW) const {
1301 // Cleanup of redundant (identical) address/immediate loads.
1303
1304 // Branch folding must be run after regalloc and prolog/epilog insertion.
1305 addMachineFunctionPass(BranchFolderPass(Opt.EnableTailMerge), PMW);
1306
1307 // Tail duplication.
1308 // Note that duplicating tail just increases code size and degrades
1309 // performance for targets that require Structured Control Flow.
1310 // In addition it can also make CFG irreducible. Thus we disable it.
1311 if (!TM.requiresStructuredCFG())
1313
1314 // Copy propagation.
1316}
1317
1318/// Add standard basic block placement passes.
1319template <typename Derived, typename TargetMachineT>
1321 PassManagerWrapper &PMW) const {
1323 // Run a separate pass to collect block placement statistics.
1324 if (Opt.EnableBlockPlacementStats)
1326}
1327
1328} // namespace llvm
1329
1330#endif // LLVM_PASSES_CODEGENPASSBUILDER_H
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
amdgpu next use AMDGPU Next Use Analysis Printer
This is the interface for LLVM's primary stateless and local alias analysis.
This header provides classes for managing passes over SCCs of the call graph.
Defines an IR pass for CodeGen Prepare.
Analysis that tracks defined/used subregister lanes across COPY instructions and instructions that ge...
This file defines passes to print out IR in various granularities.
This header defines various interfaces for pass management in LLVM.
This file contains the declaration of the InterleavedAccessPass class, its corresponding pass name is...
static LVOptions Options
Definition LVOptions.cpp:25
This header provides classes for managing a pipeline of passes over loops in LLVM IR.
The header file for the LowerConstantIntrinsics pass as used by the new pass manager.
ModuleAnalysisManager MAM
if(PassOpts->AAPipeline)
PassInstrumentationCallbacks PIC
This pass is required to take advantage of the interprocedural register allocation infrastructure.
This is the interface for a metadata-based scoped no-alias analysis.
This file contains the declaration of the SelectOptimizePass class, its corresponding pass name is se...
This file defines the SmallVector class.
Target-Independent Code Generator Pass Configuration Options pass.
This pass exposes codegen information to IR-level passes.
This is the interface for a metadata-based TBAA.
static const char PassName[]
A pass that canonicalizes freeze instructions in a loop.
void addPostRegAlloc(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes after register allocation pass pipe...
void addGlobalMergePass(PassManagerWrapper &PMW) const
Target can override this to add GlobalMergePass before all IR passes.
Error addOptimizedRegAlloc(PassManagerWrapper &PMW) const
addOptimizedRegAlloc - Add passes related to register allocation.
void addModulePass(PassT &&Pass, PassManagerWrapper &PMW, bool Force=false, StringRef Name=PassT::name()) const
decltype(std::declval< PassT & >().run( std::declval< Function & >(), std::declval< FunctionAnalysisManager & >())) is_function_pass_t
void flushFPMsToMPM(PassManagerWrapper &PMW, bool FreeMachineFunctions=false) const
void addPreGlobalInstructionSelect(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before the (global) ins...
Error addRegAssignmentFast(PassManagerWrapper &PMW) const
Add core register allocator passes which do the actual register assignment and rewriting.
void requireCGSCCOrder(PassManagerWrapper &PMW) const
void addISelPrepare(PassManagerWrapper &PMW) const
Add common passes that perform LLVM IR to IR transforms in preparation for instruction selection.
void addTargetRegisterAllocator(PassManagerWrapper &PMW, bool Optimized) const
Utilities for targets to add passes to the pass manager.
bool isGlobalISelAbortEnabled() const
Check whether or not GlobalISel should abort on error.
Error addMachinePasses(PassManagerWrapper &PMW) const
Add the complete, standard set of LLVM CodeGen passes.
void insertPass(InsertedPassT &&Pass) const
Insert InsertedPass pass after TargetPass pass.
void addPreRewrite(PassManagerWrapper &PMW) const
addPreRewrite - Add passes to the optimized register allocation pipeline after register allocation is...
Error addFastRegAlloc(PassManagerWrapper &PMW) const
addFastRegAlloc - Add the minimum set of target-independent passes that are required for fast registe...
Error buildPipeline(ModulePassManager &MPM, ModuleAnalysisManager &MAM, raw_pwrite_stream &Out, raw_pwrite_stream *DwoOut, CodeGenFileType FileType, MCContext &Ctx) const
Error addRegAssignmentOptimized(PassManagerWrapper &PMW) const
void addPreISel(PassManagerWrapper &PMW) const
{{@ For GlobalISel
Error addCoreISelPasses(PassManagerWrapper &PMW) const
Add the actual instruction selection passes.
void stopAddingInCGSCCOrder(PassManagerWrapper &PMW) const
void addPreLegalizeMachineIR(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before legalization.
void addCodeGenPrepare(PassManagerWrapper &PMW) const
Add pass to prepare the LLVM IR for code generation.
void addPreEmitPass(PassManagerWrapper &PMW) const
This pass may be implemented by targets that want to run passes immediately before machine code is em...
void addMachineSSAOptimization(PassManagerWrapper &PMW) const
Methods with trivial inline returns are convenient points in the common codegen pass pipeline where t...
void addIRPasses(PassManagerWrapper &PMW) const
Add common target configurable passes that perform LLVM IR to IR transforms following machine indepen...
decltype(std::declval< PassT & >().run( std::declval< MachineFunction & >(), std::declval< MachineFunctionAnalysisManager & >())) is_machine_function_pass_t
void addMachineLateOptimization(PassManagerWrapper &PMW) const
Add passes that optimize machine instructions after register allocation.
Error addLegalizeMachineIR(PassManagerWrapper &PMW) const
This method should install a legalize pass, which converts the instruction sequence into one that can...
CodeGenPassBuilder(TargetMachineT &TM, const CGPassBuilderOption &Opts, PassInstrumentationCallbacks *PIC)
void addPreEmitPass2(PassManagerWrapper &PMW) const
Targets may add passes immediately before machine code is emitted in this callback.
Error addIRTranslator(PassManagerWrapper &PMW) const
This method should install an IR translator pass, which converts from LLVM code to machine instructio...
void addGCPasses(PassManagerWrapper &PMW) const
addGCPasses - Add late codegen passes that analyze code for garbage collection.
void addRegAllocPass(PassManagerWrapper &PMW, bool Optimized) const
addMachinePasses helper to create the target-selected or overriden regalloc pass.
Error addRegBankSelect(PassManagerWrapper &PMW) const
This method should install a register bank selector pass, which assigns register banks to virtual reg...
void addMachineFunctionPass(PassT &&Pass, PassManagerWrapper &PMW, bool Force=false, StringRef Name=PassT::name()) const
void addISelPasses(PassManagerWrapper &PMW) const
High level function that adds all passes necessary to go from llvm IR representation to the MI repres...
void disablePass()
Allow the target to disable a specific pass by default.
Error addInstSelector(PassManagerWrapper &PMW) const
addInstSelector - This method should install an instruction selector pass, which converts from LLVM c...
void addPreRegAlloc(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before register allocat...
void addPassesToHandleExceptions(PassManagerWrapper &PMW) const
Add passes to lower exception handling for the code generator.
void addBlockPlacement(PassManagerWrapper &PMW) const
Add standard basic block placement passes.
void addAsmPrinterEnd(PassManagerWrapper &PMW) const
void addPreRegBankSelect(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes immediately before the register ban...
void addPreSched2(PassManagerWrapper &PMW) const
This method may be implemented by targets that want to run passes after prolog-epilog insertion and b...
Error addGlobalInstructionSelect(PassManagerWrapper &PMWM) const
This method should install a (global) instruction selector pass, which converts possibly generic inst...
void addAsmPrinterBegin(PassManagerWrapper &PMW) const
void addFunctionPass(PassT &&Pass, PassManagerWrapper &PMW, bool Force=false, StringRef Name=PassT::name()) const
void addILPOpts(PassManagerWrapper &PMW) const
Add passes that optimize instruction level parallelism for out-of-order targets.
decltype(std::declval< PassT & >().run( std::declval< Module & >(), std::declval< ModuleAnalysisManager & >())) is_module_pass_t
void addPostBBSections(PassManagerWrapper &PMW) const
void addPostRewrite(PassManagerWrapper &PMW) const
Add passes to be run immediately after virtual registers are rewritten to physical registers.
void addAsmPrinter(PassManagerWrapper &PMW) const
PassInstrumentationCallbacks * getPassInstrumentationCallbacks() const
bool reportDiagnosticWhenGlobalISelFallback() const
Check whether or not a diagnostic should be emitted when GlobalISel uses the fallback path.
Lightweight error class with error context and mandatory checking.
Definition Error.h:159
static ErrorSuccess success()
Create a success value.
Definition Error.h:336
Tagged union holding either a T or a Error.
Definition Error.h:485
Error takeError()
Take ownership of the stored error.
Definition Error.h:612
This is a fast-path instruction selection class that generates poor code and doesn't support illegal ...
Definition FastISel.h:66
LowerIntrinsics - This pass rewrites calls to the llvm.gcread or llvm.gcwrite intrinsics,...
Definition GCMetadata.h:229
Performs Loop Strength Reduce Pass.
This class is intended to be used as a base class for asm properties and features specific to the tar...
Definition MCAsmInfo.h:66
ExceptionHandling getExceptionHandlingType() const
Definition MCAsmInfo.h:655
Context object for machine code objects.
Definition MCContext.h:83
This class manages callbacks registration, as well as provides a way for PassInstrumentation to pass ...
LLVM_ABI StringRef getPassNameForClassName(StringRef ClassName)
Get the pass name for a given pass class name. Empty if no match found.
LLVM_ATTRIBUTE_MINSIZE std::enable_if_t<!std::is_same_v< PassT, PassManager > > addPass(PassT &&Pass)
bool isEmpty() const
Returns if the pass manager contains any passes.
Pass interface - Implemented by all 'passes'.
Definition Pass.h:99
Pass (for the new pass manager) for printing a Function as LLVM's text IR assembly.
This is used to represent a portion of an LLVM function in a low-level Data Dependence DAG representa...
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
static Expected< StartStopInfo > getStartStopInfo(PassInstrumentationCallbacks &PIC)
Returns pass name in -stop-before or -stop-after NOTE: New pass manager migration only.
static bool willCompleteCodeGenPipeline()
Returns true if none of the -stop-before and -stop-after options is set.
Create a verifier pass.
Definition Verifier.h:133
An abstract base class for streams implementations that also support a pwrite operation.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ C
The default llvm calling convention, compatible with C.
Definition CallingConv.h:34
This is an optimization pass for GlobalISel generic memory operations.
ModuleToFunctionPassAdaptor createModuleToFunctionPassAdaptor(FunctionPassT &&Pass, bool EagerlyInvalidate=false)
A function to deduce a function pass type and wrap it in the templated adaptor.
LLVM_ABI std::error_code inconvertibleErrorCode()
The value returned by this function can be returned from convertToErrorCode for Error values where no...
Definition Error.cpp:94
@ SjLj
setjmp/longjmp based exceptions
Definition CodeGen.h:56
@ ZOS
z/OS MVS Exception Handling.
Definition CodeGen.h:61
@ None
No exception support.
Definition CodeGen.h:54
@ AIX
AIX Exception Handling.
Definition CodeGen.h:60
@ DwarfCFI
DWARF-like instruction based exceptions.
Definition CodeGen.h:55
@ WinEH
Windows Exception Handling.
Definition CodeGen.h:58
@ Wasm
WebAssembly Exception Handling.
Definition CodeGen.h:59
Error createStringError(std::error_code EC, char const *Fmt, const Ts &... Vals)
Create formatted StringError object.
Definition Error.h:1321
PassManager< Loop, LoopAnalysisManager, LoopStandardAnalysisResults &, LPMUpdater & > LoopPassManager
The Loop pass manager.
ModuleToPostOrderCGSCCPassAdaptor createModuleToPostOrderCGSCCPassAdaptor(CGSCCPassT &&Pass)
A function to deduce a function pass type and wrap it in the templated adaptor.
FunctionToLoopPassAdaptor createFunctionToLoopPassAdaptor(LoopPassT &&Pass, bool UseMemorySSA=false)
A function to deduce a loop pass type and wrap it in the templated adaptor.
CGSCCToFunctionPassAdaptor createCGSCCToFunctionPassAdaptor(FunctionPassT &&Pass, bool EagerlyInvalidate=false, bool NoRerun=false)
A function to deduce a function pass type and wrap it in the templated adaptor.
CodeGenFileType
These enums are meant to be passed into addPassesToEmitFile to indicate what type of file to emit,...
Definition CodeGen.h:111
FunctionToMachineFunctionPassAdaptor createFunctionToMachineFunctionPassAdaptor(MachineFunctionPassT &&Pass)
PassManager< Module > ModulePassManager
Convenience typedef for a pass manager over modules.
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:209
FunctionAddr VTableAddr Count
Definition InstrProf.h:139
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
Error make_error(ArgTs &&... Args)
Make a Error instance representing failure using the given error info type.
Definition Error.h:340
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
PassManager< Function > FunctionPassManager
Convenience typedef for a pass manager over functions.
typename detail::detector< void, Op, Args... >::value_t is_detected
Detects if a given trait holds for some set of arguments 'Args'.
PassManager< MachineFunction > MachineFunctionPassManager
Convenience typedef for a pass manager over functions.
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
Definition MIRParser.h:39
LLVM_ABI void reportFatalUsageError(Error Err)
Report a fatal error that does not indicate a bug in LLVM.
Definition Error.cpp:177
Global function merging pass for new pass manager.
A utility pass template to force an analysis result to be available.