LLVM 23.0.0git
MSP430CodeGenPassBuilder.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 "MSP430.h"
10#include "MSP430AsmPrinter.h"
11#include "MSP430TargetMachine.h"
12
15#include "llvm/MC/MCStreamer.h"
19
20using namespace llvm;
21
22namespace {
23
24class MSP430CodeGenPassBuilder
25 : public CodeGenPassBuilder<MSP430CodeGenPassBuilder, MSP430TargetMachine> {
26 using Base =
27 CodeGenPassBuilder<MSP430CodeGenPassBuilder, MSP430TargetMachine>;
28
29public:
30 explicit MSP430CodeGenPassBuilder(MSP430TargetMachine &TM,
31 const CGPassBuilderOption &Opts,
32 PassInstrumentationCallbacks *PIC)
33 : CodeGenPassBuilder(TM, Opts, PIC) {}
34
35 void addIRPasses(PassManagerWrapper &PMW) const;
36 Error addInstSelector(PassManagerWrapper &PMW) const;
37 void addPreEmitPass(PassManagerWrapper &PMW) const;
38 void addAsmPrinterBegin(PassManagerWrapper &PMW) const;
39 void addAsmPrinter(PassManagerWrapper &PMW) const;
40 void addAsmPrinterEnd(PassManagerWrapper &PMW) const;
41};
42
43void MSP430CodeGenPassBuilder::addIRPasses(PassManagerWrapper &PMW) const {
44 addFunctionPass(AtomicExpandPass(TM), PMW);
45
46 Base::addIRPasses(PMW);
47}
48
49Error MSP430CodeGenPassBuilder::addInstSelector(PassManagerWrapper &PMW) const {
50 addMachineFunctionPass(MSP430ISelDAGToDAGPass(TM, getOptLevel()), PMW);
51 return Error::success();
52}
53
54void MSP430CodeGenPassBuilder::addPreEmitPass(PassManagerWrapper &PMW) const {
55 addMachineFunctionPass(MSP430BranchSelectPass(), PMW);
56}
57
58void MSP430CodeGenPassBuilder::addAsmPrinterBegin(
59 PassManagerWrapper &PMW) const {
60 addModulePass(MSP430AsmPrinterBeginPass(), PMW, /*Force=*/true);
61}
62
63void MSP430CodeGenPassBuilder::addAsmPrinter(PassManagerWrapper &PMW) const {
64 addMachineFunctionPass(MSP430AsmPrinterPass(), PMW);
65}
66
67void MSP430CodeGenPassBuilder::addAsmPrinterEnd(PassManagerWrapper &PMW) const {
68 addModulePass(MSP430AsmPrinterEndPass(), PMW);
69}
70
71} // namespace
72
74#define GET_PASS_REGISTRY "MSP430PassRegistry.def"
76}
77
80 raw_pwrite_stream *DwoOut, CodeGenFileType FileType,
81 const CGPassBuilderOption &Opt, MCContext &Ctx,
83 auto CGPB = MSP430CodeGenPassBuilder(*this, Opt, PIC);
84 return CGPB.buildPipeline(MPM, MAM, Out, DwoOut, FileType, Ctx);
85}
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
Context object for machine code objects.
Definition MCContext.h:83
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.
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