LLVM 23.0.0git
LanaiCodeGenPassBuilder.cpp
Go to the documentation of this file.
1//===----------------------------------------------------------------------===//
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#include "Lanai.h"
10#include "LanaiAsmPrinter.h"
11#include "LanaiTargetMachine.h"
14#include "llvm/MC/MCStreamer.h"
18
19using namespace llvm;
20
21namespace {
22
23class LanaiCodeGenPassBuilder
24 : public CodeGenPassBuilder<LanaiCodeGenPassBuilder, LanaiTargetMachine> {
25 using Base = CodeGenPassBuilder<LanaiCodeGenPassBuilder, LanaiTargetMachine>;
26
27public:
28 explicit LanaiCodeGenPassBuilder(LanaiTargetMachine &TM,
29 const CGPassBuilderOption &Opts,
30 PassInstrumentationCallbacks *PIC)
31 : CodeGenPassBuilder(TM, Opts, PIC) {}
32
33 void addIRPasses(PassManagerWrapper &PMW) const;
34 Error addInstSelector(PassManagerWrapper &PMW) const;
35 void addPreSched2(PassManagerWrapper &PMW) const;
36 void addPreEmitPass(PassManagerWrapper &PMW) const;
37 void addAsmPrinterBegin(PassManagerWrapper &PMW) const;
38 void addAsmPrinter(PassManagerWrapper &PMW) const;
39 void addAsmPrinterEnd(PassManagerWrapper &PMW) const;
40};
41
42void LanaiCodeGenPassBuilder::addIRPasses(PassManagerWrapper &PMW) const {
43 addFunctionPass(AtomicExpandPass(TM), PMW);
44
45 Base::addIRPasses(PMW);
46}
47
48Error LanaiCodeGenPassBuilder::addInstSelector(PassManagerWrapper &PMW) const {
49 addMachineFunctionPass(LanaiISelDAGToDAGPass(TM), PMW);
50 return Error::success();
51}
52
53void LanaiCodeGenPassBuilder::addPreSched2(PassManagerWrapper &PMW) const {
54 addMachineFunctionPass(LanaiMemAluCombinerPass(), PMW);
55}
56
57void LanaiCodeGenPassBuilder::addPreEmitPass(PassManagerWrapper &PMW) const {
58 addMachineFunctionPass(LanaiDelaySlotFillerPass(), PMW);
59}
60
61void LanaiCodeGenPassBuilder::addAsmPrinterBegin(
62 PassManagerWrapper &PMW) const {
63 addModulePass(LanaiAsmPrinterBeginPass(), PMW, /*Force=*/true);
64}
65
66void LanaiCodeGenPassBuilder::addAsmPrinter(PassManagerWrapper &PMW) const {
67 addMachineFunctionPass(LanaiAsmPrinterPass(), PMW);
68}
69
70void LanaiCodeGenPassBuilder::addAsmPrinterEnd(PassManagerWrapper &PMW) const {
71 addModulePass(LanaiAsmPrinterEndPass(), PMW, /*Force=*/true);
72}
73
74} // namespace
75
77#define GET_PASS_REGISTRY "LanaiPassRegistry.def"
79 // TODO(boomanaiden154): Move this into the base CodeGenPassBuilder once all
80 // targets that currently implement it have a ported asm-printer pass.
81 if (PIC) {
82 PIC->addClassToPassName(LanaiAsmPrinterBeginPass::name(),
83 "lanai-asm-printer-begin");
84 PIC->addClassToPassName(LanaiAsmPrinterPass::name(), "lanai-asmprinter");
85 PIC->addClassToPassName(LanaiAsmPrinterEndPass::name(),
86 "lanai-asm-printer-end");
87 }
88}
89
92 raw_pwrite_stream *DwoOut, CodeGenFileType FileType,
93 const CGPassBuilderOption &Opt, MCContext &Ctx,
95 auto CGPB = LanaiCodeGenPassBuilder(*this, Opt, PIC);
96 return CGPB.buildPipeline(MPM, MAM, Out, DwoOut, FileType, Ctx);
97}
Interfaces for producing common pass manager configurations.
ModuleAnalysisManager MAM
PassInstrumentationCallbacks PIC
PassBuilder PB(Machine, PassOpts->PTO, std::nullopt, &PIC)
This file defines the Pass Instrumentation classes that provide instrumentation points into the pass ...
This class provides access to building LLVM's passes.
Lightweight error class with error context and mandatory checking.
Definition Error.h:159
static ErrorSuccess success()
Create a success value.
Definition Error.h:336
Error buildCodeGenPipeline(ModulePassManager &MPM, ModuleAnalysisManager &MAM, raw_pwrite_stream &Out, raw_pwrite_stream *DwoOut, CodeGenFileType FileType, const CGPassBuilderOption &Opt, MCContext &Ctx, PassInstrumentationCallbacks *PIC) override
void registerPassBuilderCallbacks(PassBuilder &PB) override
Allow the target to modify the pass pipeline.
Context object for machine code objects.
Definition MCContext.h:83
This class provides access to building LLVM's passes.
This class manages callbacks registration, as well as provides a way for PassInstrumentation to pass ...
An abstract base class for streams implementations that also support a pwrite operation.
Interfaces for registering analysis passes, producing common pass manager configurations,...
This is an optimization pass for GlobalISel generic memory operations.
CodeGenFileType
These enums are meant to be passed into addPassesToEmitFile to indicate what type of file to emit,...
Definition CodeGen.h:111
PassManager< Module > ModulePassManager
Convenience typedef for a pass manager over modules.
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
Definition MIRParser.h:39