LLVM 22.0.0git
M68kTargetMachine.cpp
Go to the documentation of this file.
1//===-- M68kTargetMachine.cpp - M68k Target Machine -------------*- 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/// \file
10/// This file contains implementation for M68k target machine.
11///
12//===----------------------------------------------------------------------===//
13
14#include "M68kTargetMachine.h"
15#include "M68k.h"
16#include "M68kMachineFunction.h"
17#include "M68kSubtarget.h"
24#include "llvm/CodeGen/Passes.h"
28#include "llvm/PassRegistry.h"
29#include <memory>
30#include <optional>
31
32using namespace llvm;
33
34#define DEBUG_TYPE "m68k"
35
46
47namespace {
48
50 std::optional<Reloc::Model> RM) {
51 // If not defined we default to static
52 if (!RM.has_value())
53 return Reloc::Static;
54
55 return *RM;
56}
57
58CodeModel::Model getEffectiveCodeModel(std::optional<CodeModel::Model> CM,
59 bool JIT) {
60 if (!CM) {
61 return CodeModel::Small;
62 } else if (CM == CodeModel::Kernel) {
63 llvm_unreachable("Kernel code model is not implemented yet");
64 }
65 return CM.value();
66}
67} // end anonymous namespace
68
70 StringRef CPU, StringRef FS,
72 std::optional<Reloc::Model> RM,
73 std::optional<CodeModel::Model> CM,
74 CodeGenOptLevel OL, bool JIT)
75 : CodeGenTargetMachineImpl(T, TT.computeDataLayout(), TT, CPU, FS, Options,
77 ::getEffectiveCodeModel(CM, JIT), OL),
78 TLOF(std::make_unique<M68kELFTargetObjectFile>()),
79 Subtarget(TT, CPU, FS, *this) {
81}
82
84
85const M68kSubtarget *
87 Attribute CPUAttr = F.getFnAttribute("target-cpu");
88 Attribute FSAttr = F.getFnAttribute("target-features");
89
90 auto CPU = CPUAttr.isValid() ? CPUAttr.getValueAsString().str() : TargetCPU;
91 auto FS = FSAttr.isValid() ? FSAttr.getValueAsString().str() : TargetFS;
92
93 auto &I = SubtargetMap[CPU + FS];
94 if (!I) {
95 // This needs to be done before we create a new subtarget since any
96 // creation will depend on the TM and the code generation flags on the
97 // function that reside in TargetOptions.
99 I = std::make_unique<M68kSubtarget>(TargetTriple, CPU, FS, *this);
100 }
101 return I.get();
102}
103
110
111//===----------------------------------------------------------------------===//
112// Pass Pipeline Configuration
113//===----------------------------------------------------------------------===//
114
115namespace {
116class M68kPassConfig : public TargetPassConfig {
117public:
118 M68kPassConfig(M68kTargetMachine &TM, PassManagerBase &PM)
119 : TargetPassConfig(TM, PM) {}
120
121 M68kTargetMachine &getM68kTargetMachine() const {
123 }
124
125 const M68kSubtarget &getM68kSubtarget() const {
126 return *getM68kTargetMachine().getSubtargetImpl();
127 }
128 void addIRPasses() override;
129 bool addIRTranslator() override;
130 bool addLegalizeMachineIR() override;
131 bool addRegBankSelect() override;
132 bool addGlobalInstructionSelect() override;
133 bool addInstSelector() override;
134 void addPreSched2() override;
135 void addPreEmitPass() override;
136};
137} // namespace
138
140 return new M68kPassConfig(*this, PM);
141}
142
143void M68kPassConfig::addIRPasses() {
146}
147
148bool M68kPassConfig::addInstSelector() {
149 // Install an instruction selector.
150 addPass(createM68kISelDag(getM68kTargetMachine()));
152 return false;
153}
154
155bool M68kPassConfig::addIRTranslator() {
156 addPass(new IRTranslator());
157 return false;
158}
159
160bool M68kPassConfig::addLegalizeMachineIR() {
161 addPass(new Legalizer());
162 return false;
163}
164
165bool M68kPassConfig::addRegBankSelect() {
166 addPass(new RegBankSelect());
167 return false;
168}
169
170bool M68kPassConfig::addGlobalInstructionSelect() {
171 addPass(new InstructionSelect());
172 return false;
173}
174
175void M68kPassConfig::addPreSched2() { addPass(createM68kExpandPseudoPass()); }
176
177void M68kPassConfig::addPreEmitPass() {
179}
#define LLVM_EXTERNAL_VISIBILITY
Definition Compiler.h:132
DXIL Legalizer
This file declares the IRTranslator pass.
This file declares the M68k specific subclass of MachineFunctionInfo.
This file declares the M68k specific subclass of TargetSubtargetInfo.
LLVM_EXTERNAL_VISIBILITY void LLVMInitializeM68kTarget()
This file declares the M68k specific subclass of TargetMachine.
This file contains declarations for M68k ELF object file lowering.
This file contains the entry points for global functions defined in the M68k target library,...
#define F(x, y, z)
Definition MD5.cpp:55
#define I(x, y, z)
Definition MD5.cpp:58
#define T
This file describes the interface of the MachineFunctionPass responsible for assigning the generic vi...
const GCNTargetMachine & getTM(const GCNSubtarget *STI)
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
Target-Independent Code Generator Pass Configuration Options pass.
Functions, function parameters, and return types can have attributes to indicate how they should be t...
Definition Attributes.h:69
LLVM_ABI StringRef getValueAsString() const
Return the attribute's value as a string.
bool isValid() const
Return true if the attribute is any kind of attribute.
Definition Attributes.h:223
CodeGenTargetMachineImpl(const Target &T, StringRef DataLayoutString, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, Reloc::Model RM, CodeModel::Model CM, CodeGenOptLevel OL)
This pass is responsible for selecting generic machine instructions to target-specific instructions.
const M68kSubtarget * getSubtargetImpl() const
MachineFunctionInfo * createMachineFunctionInfo(BumpPtrAllocator &Allocator, const Function &F, const TargetSubtargetInfo *STI) const override
Create the target's instance of MachineFunctionInfo.
M68kTargetMachine(const Target &T, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, std::optional< Reloc::Model > RM, std::optional< CodeModel::Model > CM, CodeGenOptLevel OL, bool JIT)
TargetPassConfig * createPassConfig(PassManagerBase &PM) override
Create a pass configuration object to be used by addPassToEmitX methods for generating a pipeline of ...
static LLVM_ABI PassRegistry * getPassRegistry()
getPassRegistry - Access the global registry object, which is automatically initialized at applicatio...
This pass implements the reg bank selector pass used in the GlobalISel pipeline.
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
std::string str() const
str - Get the contents as an std::string.
Definition StringRef.h:233
Triple TargetTriple
Triple string, CPU name, and target feature strings the TargetMachine instance is created with.
std::unique_ptr< const MCSubtargetInfo > STI
TargetOptions Options
void resetTargetOptions(const Function &F) const
Reset the target options based on the function's attributes.
Target-Independent Code Generator Pass Configuration Options.
virtual void addIRPasses()
Add common target configurable passes that perform LLVM IR to IR transforms following machine indepen...
TargetSubtargetInfo - Generic base class for all target subtargets.
Target - Wrapper for Target specific information.
Triple - Helper class for working with autoconf configuration names.
Definition Triple.h:47
PassManagerBase - An abstract interface to allow code to add passes to a pass manager without having ...
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
This is an optimization pass for GlobalISel generic memory operations.
void initializeM68kGlobalBaseRegPass(PassRegistry &)
void initializeM68kExpandPseudoPass(PassRegistry &)
void initializeM68kCollapseMOVEMPass(PassRegistry &)
FunctionPass * createM68kGlobalBaseRegPass()
This pass initializes a global base register for PIC on M68k.
static Reloc::Model getEffectiveRelocModel(std::optional< Reloc::Model > RM)
CodeModel::Model getEffectiveCodeModel(std::optional< CodeModel::Model > CM, CodeModel::Model Default)
Helper method for getting the code model, returning Default if CM does not have a value.
FunctionPass * createM68kCollapseMOVEMPass()
Finds sequential MOVEM instruction and collapse them into a single one.
FunctionPass * createM68kISelDag(M68kTargetMachine &TM)
This pass converts a legalized DAG into a M68k-specific DAG, ready for instruction scheduling.
BumpPtrAllocatorImpl BumpPtrAllocator
The standard BumpPtrAllocator which just uses the default template parameters.
Definition Allocator.h:383
CodeGenOptLevel
Code generation optimization level.
Definition CodeGen.h:82
void initializeM68kDAGToDAGISelLegacyPass(PassRegistry &)
LLVM_ABI void initializeGlobalISel(PassRegistry &)
Initialize all passes linked into the GlobalISel library.
Target & getTheM68kTarget()
FunctionPass * createM68kExpandPseudoPass()
Return a Machine IR pass that expands M68k-specific pseudo instructions into a sequence of actual ins...
LLVM_ABI FunctionPass * createAtomicExpandLegacyPass()
AtomicExpandPass - At IR level this pass replace atomic instructions with __atomic_* library calls,...
void initializeM68kAsmPrinterPass(PassRegistry &)
Implement std::hash so that hash_code can be used in STL containers.
Definition BitVector.h:851
MachineFunctionInfo - This class can be derived from and used by targets to hold private target-speci...
static FuncInfoTy * create(BumpPtrAllocator &Allocator, const Function &F, const SubtargetTy *STI)
Factory function: default behavior is to call new using the supplied allocator.
RegisterTargetMachine - Helper template for registering a target machine implementation,...