LLVM API Documentation
#include <SparcTargetMachine.h>
Inheritance diagram for llvm::SparcTargetMachine:
Public Member Functions | |
SparcTargetMachine (const Module &M, const std::string &FS) | |
virtual const SparcInstrInfo * | getInstrInfo () const |
virtual const TargetFrameInfo * | getFrameInfo () const |
virtual const TargetSubtarget * | getSubtargetImpl () const |
virtual const MRegisterInfo * | getRegisterInfo () const |
virtual bool | addPassesToEmitFile (PassManager &PM, std::ostream &Out, CodeGenFileType FileType, bool Fast) |
Static Public Member Functions | |
static unsigned | getModuleMatchQuality (const Module &M) |
Definition at line 27 of file SparcTargetMachine.h.
SparcTargetMachine::SparcTargetMachine | ( | const Module & | M, | |
const std::string & | FS | |||
) |
SparcTargetMachine ctor - Create an ILP32 architecture model
Definition at line 33 of file SparcTargetMachine.cpp.
bool SparcTargetMachine::addPassesToEmitFile | ( | PassManager & | PM, | |
std::ostream & | Out, | |||
CodeGenFileType | FileType, | |||
bool | Fast | |||
) | [virtual] |
addPassesToEmitFile - Add passes to the specified pass manager to implement a static compiler for this target.
Definition at line 61 of file SparcTargetMachine.cpp.
References llvm::PassManager::add(), llvm::TargetMachine::AssemblyFile, llvm::createLoopStrengthReducePass(), llvm::createLowerGCPass(), llvm::createLowerInvokePass(), llvm::createMachineCodeDeleter(), llvm::createMachineFunctionPrinterPass(), llvm::createPrologEpilogCodeInserter(), llvm::createRegisterAllocator(), llvm::createSparcCodePrinterPass(), llvm::createSparcDelaySlotFillerPass(), llvm::createSparcFPMoverPass(), llvm::createSparcISelDag(), llvm::createUnreachableBlockEliminationPass(), and llvm::PrintMachineCode.
virtual const TargetFrameInfo* llvm::SparcTargetMachine::getFrameInfo | ( | ) | const [inline, virtual] |
virtual const SparcInstrInfo* llvm::SparcTargetMachine::getInstrInfo | ( | ) | const [inline, virtual] |
unsigned SparcTargetMachine::getModuleMatchQuality | ( | const Module & | M | ) | [static] |
getModuleMatchQuality - This static method should be implemented by targets to indicate how closely they match the specified module. This is used by the LLC tool to determine which target to use when an explicit -march option is not specified. If a target returns zero, it will never be chosen without an explicit -march option.
Reimplemented from llvm::TargetMachine.
Definition at line 39 of file SparcTargetMachine.cpp.
References llvm::Module::AnyEndianness, llvm::Module::AnyPointerSize, llvm::Module::BigEndian, llvm::Module::getEndianness(), llvm::Module::getPointerSize(), llvm::Module::getTargetTriple(), M, and llvm::Module::Pointer32.
virtual const MRegisterInfo* llvm::SparcTargetMachine::getRegisterInfo | ( | ) | const [inline, virtual] |
getRegisterInfo - If register information is available, return it. If not, return null. This is kept separate from RegInfo until RegInfo has details of graph coloring register allocation removed from it.
Reimplemented from llvm::TargetMachine.
Definition at line 37 of file SparcTargetMachine.h.
References llvm::SparcInstrInfo::getRegisterInfo().
virtual const TargetSubtarget* llvm::SparcTargetMachine::getSubtargetImpl | ( | ) | const [inline, virtual] |
getSubtargetImpl - virtual method implemented by subclasses that returns a reference to that target's TargetSubtarget-derived member variable.
Reimplemented from llvm::TargetMachine.
Definition at line 36 of file SparcTargetMachine.h.