39 T,
"e-m:e-p:32:32-i1:8:32-i8:8:32-i16:16:32-i64:32-f64:32-a:0:32-n32",
42 Subtarget(TT, CPU, FS, *this) {
56 return getTM<XCoreTargetMachine>();
59 void addIRPasses()
override;
60 bool addPreISel()
override;
61 bool addInstSelector()
override;
62 void addPreEmitPass()
override;
67 return new XCorePassConfig(
this, PM);
70 void XCorePassConfig::addIRPasses() {
76 bool XCorePassConfig::addPreISel() {
81 bool XCorePassConfig::addInstSelector() {
86 void XCorePassConfig::addPreEmitPass() {
void LLVMInitializeXCoreTarget()
virtual void addIRPasses()
Add common target configurable passes that perform LLVM IR to IR transforms following machine indepen...
TargetIRAnalysis getTargetIRAnalysis() override
Get a TargetIRAnalysis implementation for the target.
TargetPassConfig * createPassConfig(PassManagerBase &PM) override
Create a pass configuration object to be used by addPassToEmitX methods for generating a pipeline of ...
Analysis pass providing the TargetTransformInfo.
ModulePass * createXCoreLowerThreadLocalPass()
FunctionPass * createAtomicExpandPass(const TargetMachine *TM)
Target-Independent Code Generator Pass Configuration Options.
FunctionPass * createXCoreFrameToArgsOffsetEliminationPass()
createXCoreFrameToArgsOffsetEliminationPass - returns an instance of the Frame to args offset elimina...
std::enable_if<!std::is_array< T >::value, std::unique_ptr< T > >::type make_unique(Args &&...args)
Constructs a new T() with the given args and returns a unique_ptr<T> which owns the object...
static Reloc::Model getEffectiveRelocModel(Optional< Reloc::Model > RM)
FunctionPass * createXCoreISelDag(XCoreTargetMachine &TM, CodeGenOpt::Level OptLevel)
createXCoreISelDag - This pass converts a legalized DAG into a XCore-specific DAG, ready for instruction scheduling.
static GCMetadataPrinterRegistry::Add< ErlangGCPrinter > X("erlang","erlang-compatible garbage collector")
This class describes a target machine that is implemented with the LLVM target-independent code gener...
XCoreTargetMachine(const Target &T, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, Optional< Reloc::Model > RM, CodeModel::Model CM, CodeGenOpt::Level OL)
Create an ILP32 architecture model.
Triple - Helper class for working with autoconf configuration names.
Target & getTheXCoreTarget()
Module.h This file contains the declarations for the Module class.
Target - Wrapper for Target specific information.
~XCoreTargetMachine() override
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.