31 T,
"e-m:e-p:32:32-i1:8:32-i8:8:32-i16:16:32-i64:32-f64:32-a:0:32-n32",
32 TT, CPU, FS, Options, RM, CM, OL),
34 Subtarget(TT, CPU, FS, *this) {
48 return getTM<XCoreTargetMachine>();
51 void addIRPasses()
override;
52 bool addPreISel()
override;
53 bool addInstSelector()
override;
54 void addPreEmitPass()
override;
59 return new XCorePassConfig(
this, PM);
62 void XCorePassConfig::addIRPasses() {
68 bool XCorePassConfig::addPreISel() {
73 bool XCorePassConfig::addInstSelector() {
78 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.
XCoreTargetMachine(const Target &T, const Triple &TT, StringRef CPU, StringRef FS, const TargetOptions &Options, Reloc::Model RM, CodeModel::Model CM, CodeGenOpt::Level OL)
XCoreTargetMachine ctor - Create an ILP32 architecture model.
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...
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...
Triple - Helper class for working with autoconf configuration names.
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.