64 Subtarget(TT, Cpu, FeatureString, *this, Options, CodeModel, OptLevel),
83 return getTM<LanaiTargetMachine>();
86 bool addInstSelector()
override;
87 void addPreSched2()
override;
88 void addPreEmitPass()
override;
94 return new LanaiPassConfig(
this, &PassManager);
98 bool LanaiPassConfig::addInstSelector() {
105 void LanaiPassConfig::addPreEmitPass() {
111 void LanaiPassConfig::addPreSched2() {
static std::string computeDataLayout()
Target & getTheLanaiTarget()
void initializeLanaiMemAluCombinerPass(PassRegistry &)
TargetIRAnalysis getTargetIRAnalysis() override
Get a TargetIRAnalysis implementation for the target.
Analysis pass providing the TargetTransformInfo.
FunctionPass * createLanaiMemAluCombinerPass()
TargetPassConfig * createPassConfig(PassManagerBase &pass_manager) override
Create a pass configuration object to be used by addPassToEmitX methods for generating a pipeline of ...
Target-Independent Code Generator Pass Configuration Options.
void LLVMInitializeLanaiTarget()
FunctionPass * createLanaiDelaySlotFillerPass(const LanaiTargetMachine &TM)
static Reloc::Model getEffectiveRelocModel(Optional< Reloc::Model > RM)
This class describes a target machine that is implemented with the LLVM target-independent code gener...
FunctionPass * createLanaiISelDag(LanaiTargetMachine &TM)
Triple - Helper class for working with autoconf configuration names.
Target - Wrapper for Target specific information.
LanaiTargetMachine(const Target &TheTarget, const Triple &TargetTriple, StringRef Cpu, StringRef FeatureString, const TargetOptions &Options, Optional< Reloc::Model > RelocationModel, CodeModel::Model CodeModel, CodeGenOpt::Level OptLevel)
Manages a sequence of passes over a particular unit of IR.
RegisterTargetMachine - Helper template for registering a target machine implementation, for use in the target machine initialization function.
StringRef - Represent a constant reference to a string, i.e.
PassRegistry - This class manages the registration and intitialization of the pass subsystem as appli...