|
LLVM 23.0.0git
|
Target - Wrapper for Target specific information. More...
#include "llvm/MC/TargetRegistry.h"
Public Types | |
| using | ArchMatchFnTy = bool (*)(Triple::ArchType Arch) |
| using | MCAsmInfoCtorFnTy |
| using | MCObjectFileInfoCtorFnTy |
| using | MCInstrInfoCtorFnTy = MCInstrInfo *(*)() |
| using | MCInstrAnalysisCtorFnTy = MCInstrAnalysis *(*)(const MCInstrInfo *Info) |
| using | MCRegInfoCtorFnTy = MCRegisterInfo *(*)(const Triple &TT) |
| using | MCSubtargetInfoCtorFnTy |
| using | TargetMachineCtorTy |
| using | AsmPrinterCtorTy |
| using | MCAsmBackendCtorTy |
| using | MCAsmParserCtorTy |
| using | MCDisassemblerCtorTy |
| using | MCInstPrinterCtorTy |
| using | MCCodeEmitterCtorTy |
| using | ELFStreamerCtorTy |
| using | MachOStreamerCtorTy |
| using | COFFStreamerCtorTy |
| using | XCOFFStreamerCtorTy |
| using | NullTargetStreamerCtorTy = MCTargetStreamer *(*)(MCStreamer &S) |
| using | AsmTargetStreamerCtorTy |
| using | AsmStreamerCtorTy |
| using | ObjectTargetStreamerCtorTy |
| using | MCRelocationInfoCtorTy |
| using | MCSymbolizerCtorTy |
| using | CustomBehaviourCtorTy |
| using | InstrPostProcessCtorTy |
| using | InstrumentManagerCtorTy |
| using | MCLFIRewriterCtorTy |
Public Member Functions | |
| Target ()=default | |
Target Information | |
| const Target * | getNext () const |
| const char * | getName () const |
| getName - Get the target name. | |
| const char * | getShortDescription () const |
| getShortDescription - Get a short description of the target. | |
| const char * | getBackendName () const |
| getBackendName - Get the backend name. | |
Feature Predicates | |
| bool | hasJIT () const |
| hasJIT - Check if this targets supports the just-in-time compilation. | |
| bool | hasTargetMachine () const |
| hasTargetMachine - Check if this target supports code generation. | |
| bool | hasMCAsmBackend () const |
| hasMCAsmBackend - Check if this target supports .o generation. | |
| bool | hasMCAsmParser () const |
| hasMCAsmParser - Check if this target supports assembly parsing. | |
Feature Constructors | |
| MCAsmInfo * | createMCAsmInfo (const MCRegisterInfo &MRI, const Triple &TheTriple, const MCTargetOptions &Options) const |
| Create a MCAsmInfo implementation for the specified target triple. | |
| MCObjectFileInfo * | createMCObjectFileInfo (MCContext &Ctx, bool PIC, bool LargeCodeModel=false) const |
| Create a MCObjectFileInfo implementation for the specified target triple. | |
| MCInstrInfo * | createMCInstrInfo () const |
| createMCInstrInfo - Create a MCInstrInfo implementation. | |
| MCInstrAnalysis * | createMCInstrAnalysis (const MCInstrInfo *Info) const |
| createMCInstrAnalysis - Create a MCInstrAnalysis implementation. | |
| MCRegisterInfo * | createMCRegInfo (const Triple &TT) const |
| Create a MCRegisterInfo implementation. | |
| MCSubtargetInfo * | createMCSubtargetInfo (const Triple &TheTriple, StringRef CPU, StringRef Features) const |
| createMCSubtargetInfo - Create a MCSubtargetInfo implementation. | |
| TargetMachine * | createTargetMachine (const Triple &TT, StringRef CPU, StringRef Features, const TargetOptions &Options, std::optional< Reloc::Model > RM, std::optional< CodeModel::Model > CM=std::nullopt, CodeGenOptLevel OL=CodeGenOptLevel::Default, bool JIT=false) const |
createTargetMachine - Create a target specific machine implementation for the specified Triple. | |
| MCAsmBackend * | createMCAsmBackend (const MCSubtargetInfo &STI, const MCRegisterInfo &MRI, const MCTargetOptions &Options) const |
| createMCAsmBackend - Create a target specific assembly parser. | |
| MCTargetAsmParser * | createMCAsmParser (const MCSubtargetInfo &STI, MCAsmParser &Parser, const MCInstrInfo &MII, const MCTargetOptions &Options) const |
| createMCAsmParser - Create a target specific assembly parser. | |
| AsmPrinter * | createAsmPrinter (TargetMachine &TM, std::unique_ptr< MCStreamer > &&Streamer) const |
| createAsmPrinter - Create a target specific assembly printer pass. | |
| MCDisassembler * | createMCDisassembler (const MCSubtargetInfo &STI, MCContext &Ctx) const |
| MCInstPrinter * | createMCInstPrinter (const Triple &T, unsigned SyntaxVariant, const MCAsmInfo &MAI, const MCInstrInfo &MII, const MCRegisterInfo &MRI) const |
| MCCodeEmitter * | createMCCodeEmitter (const MCInstrInfo &II, MCContext &Ctx) const |
| createMCCodeEmitter - Create a target specific code emitter. | |
| LLVM_ABI MCStreamer * | createMCObjectStreamer (const Triple &T, MCContext &Ctx, std::unique_ptr< MCAsmBackend > TAB, std::unique_ptr< MCObjectWriter > OW, std::unique_ptr< MCCodeEmitter > Emitter, const MCSubtargetInfo &STI) const |
| Create a target specific MCStreamer. | |
| LLVM_ABI MCStreamer * | createAsmStreamer (MCContext &Ctx, std::unique_ptr< formatted_raw_ostream > OS, std::unique_ptr< MCInstPrinter > IP, std::unique_ptr< MCCodeEmitter > CE, std::unique_ptr< MCAsmBackend > TAB) const |
| MCTargetStreamer * | createAsmTargetStreamer (MCStreamer &S, formatted_raw_ostream &OS, MCInstPrinter *InstPrint) const |
| MCStreamer * | createNullStreamer (MCContext &Ctx) const |
| MCTargetStreamer * | createNullTargetStreamer (MCStreamer &S) const |
| void | createMCLFIRewriter (MCStreamer &S, std::unique_ptr< MCRegisterInfo > &&RegInfo, std::unique_ptr< MCInstrInfo > &&InstInfo) const |
| MCRelocationInfo * | createMCRelocationInfo (const Triple &TT, MCContext &Ctx) const |
| createMCRelocationInfo - Create a target specific MCRelocationInfo. | |
| MCSymbolizer * | createMCSymbolizer (const Triple &TT, LLVMOpInfoCallback GetOpInfo, LLVMSymbolLookupCallback SymbolLookUp, void *DisInfo, MCContext *Ctx, std::unique_ptr< MCRelocationInfo > &&RelInfo) const |
| createMCSymbolizer - Create a target specific MCSymbolizer. | |
| mca::CustomBehaviour * | createCustomBehaviour (const MCSubtargetInfo &STI, const mca::SourceMgr &SrcMgr, const MCInstrInfo &MCII) const |
| createCustomBehaviour - Create a target specific CustomBehaviour. | |
| mca::InstrPostProcess * | createInstrPostProcess (const MCSubtargetInfo &STI, const MCInstrInfo &MCII) const |
| createInstrPostProcess - Create a target specific InstrPostProcess. | |
| mca::InstrumentManager * | createInstrumentManager (const MCSubtargetInfo &STI, const MCInstrInfo &MCII) const |
| createInstrumentManager - Create a target specific InstrumentManager. | |
Friends | |
| struct | TargetRegistry |
Target - Wrapper for Target specific information.
For registration purposes, this is a POD type so that targets can be registered without the use of static constructors.
Targets should implement a single global instance of this class (which will be zero initialized), and pass that instance to the TargetRegistry as part of their initialization.
Definition at line 147 of file TargetRegistry.h.
| using llvm::Target::ArchMatchFnTy = bool (*)(Triple::ArchType Arch) |
Definition at line 151 of file TargetRegistry.h.
Definition at line 172 of file TargetRegistry.h.
Definition at line 214 of file TargetRegistry.h.
Definition at line 211 of file TargetRegistry.h.
Definition at line 200 of file TargetRegistry.h.
Definition at line 228 of file TargetRegistry.h.
Definition at line 191 of file TargetRegistry.h.
Definition at line 233 of file TargetRegistry.h.
Definition at line 237 of file TargetRegistry.h.
Definition at line 196 of file TargetRegistry.h.
Definition at line 174 of file TargetRegistry.h.
Definition at line 153 of file TargetRegistry.h.
Definition at line 178 of file TargetRegistry.h.
Definition at line 189 of file TargetRegistry.h.
Definition at line 181 of file TargetRegistry.h.
Definition at line 184 of file TargetRegistry.h.
| using llvm::Target::MCInstrAnalysisCtorFnTy = MCInstrAnalysis *(*)(const MCInstrInfo *Info) |
Definition at line 160 of file TargetRegistry.h.
| using llvm::Target::MCInstrInfoCtorFnTy = MCInstrInfo *(*)() |
Definition at line 159 of file TargetRegistry.h.
Definition at line 241 of file TargetRegistry.h.
Definition at line 156 of file TargetRegistry.h.
| using llvm::Target::MCRegInfoCtorFnTy = MCRegisterInfo *(*)(const Triple &TT) |
Definition at line 161 of file TargetRegistry.h.
Definition at line 220 of file TargetRegistry.h.
Definition at line 162 of file TargetRegistry.h.
Definition at line 222 of file TargetRegistry.h.
| using llvm::Target::NullTargetStreamerCtorTy = MCTargetStreamer *(*)(MCStreamer &S) |
Definition at line 210 of file TargetRegistry.h.
Definition at line 218 of file TargetRegistry.h.
Definition at line 165 of file TargetRegistry.h.
Definition at line 204 of file TargetRegistry.h.
|
default |
Referenced by getNext().
|
inline |
createAsmPrinter - Create a target specific assembly printer pass.
This takes ownership of the MCStreamer object.
Definition at line 510 of file TargetRegistry.h.
Referenced by llvm::CodeGenTargetMachineImpl::addAsmPrinter(), llvm::CodeGenTargetMachineImpl::addPassesToEmitMC(), llvm::dwarf_linker::classic::DwarfStreamer::init(), and llvm::dwarf_linker::parallel::DwarfEmitterImpl::init().
| MCStreamer * Target::createAsmStreamer | ( | MCContext & | Ctx, |
| std::unique_ptr< formatted_raw_ostream > | OS, | ||
| std::unique_ptr< MCInstPrinter > | IP, | ||
| std::unique_ptr< MCCodeEmitter > | CE, | ||
| std::unique_ptr< MCAsmBackend > | TAB ) const |
Definition at line 85 of file TargetRegistry.cpp.
References llvm::createAsmStreamer(), createAsmTargetStreamer(), and Printer.
Referenced by llvm::CodeGenTargetMachineImpl::createMCStreamer(), llvm::dwarf_linker::classic::DwarfStreamer::init(), and llvm::dwarf_linker::parallel::DwarfEmitterImpl::init().
|
inline |
Definition at line 559 of file TargetRegistry.h.
Referenced by createAsmStreamer().
|
inline |
createCustomBehaviour - Create a target specific CustomBehaviour.
This class is used by llvm-mca and requires backend functionality.
Definition at line 622 of file TargetRegistry.h.
References llvm::SrcMgr.
|
inline |
createInstrPostProcess - Create a target specific InstrPostProcess.
This class is used by llvm-mca and requires backend functionality.
Definition at line 632 of file TargetRegistry.h.
|
inline |
createInstrumentManager - Create a target specific InstrumentManager.
This class is used by llvm-mca and requires backend functionality.
Definition at line 643 of file TargetRegistry.h.
|
inline |
createMCAsmBackend - Create a target specific assembly parser.
Definition at line 487 of file TargetRegistry.h.
Referenced by llvm::CodeGenTargetMachineImpl::addPassesToEmitMC(), llvm::CodeGenTargetMachineImpl::createMCStreamer(), llvm::dwarf_linker::classic::DwarfStreamer::init(), and llvm::dwarf_linker::parallel::DwarfEmitterImpl::init().
|
inline |
Create a MCAsmInfo implementation for the specified target triple.
| TheTriple | This argument is used to determine the target machine feature set; it should always be provided. Generally this should be either the target triple from the module, or the target triple of the host if that does not exist. |
Definition at line 409 of file TargetRegistry.h.
Referenced by llvm::dwarf_linker::classic::DwarfStreamer::init(), llvm::dwarf_linker::parallel::DwarfEmitterImpl::init(), LLVMCreateDisasmCPUFeatures(), and llvm::logicalview::LVBinaryReader::loadGenericTargetInfo().
|
inline |
createMCAsmParser - Create a target specific assembly parser.
| Parser | The target independent parser implementation to use for parsing and lexing. |
Definition at line 499 of file TargetRegistry.h.
References Options.
|
inline |
createMCCodeEmitter - Create a target specific code emitter.
Definition at line 534 of file TargetRegistry.h.
References II.
Referenced by llvm::CodeGenTargetMachineImpl::createMCStreamer(), llvm::dwarf_linker::classic::DwarfStreamer::init(), and llvm::dwarf_linker::parallel::DwarfEmitterImpl::init().
|
inline |
Definition at line 517 of file TargetRegistry.h.
Referenced by LLVMCreateDisasmCPUFeatures(), and llvm::logicalview::LVBinaryReader::loadGenericTargetInfo().
|
inline |
|
inline |
createMCInstrAnalysis - Create a MCInstrAnalysis implementation.
Definition at line 439 of file TargetRegistry.h.
|
inline |
createMCInstrInfo - Create a MCInstrInfo implementation.
Definition at line 431 of file TargetRegistry.h.
Referenced by llvm::dwarf_linker::classic::DwarfStreamer::init(), llvm::dwarf_linker::parallel::DwarfEmitterImpl::init(), llvm::initializeLFIMCStreamer(), LLVMCreateDisasmCPUFeatures(), and llvm::logicalview::LVBinaryReader::loadGenericTargetInfo().
|
inline |
Definition at line 579 of file TargetRegistry.h.
Referenced by llvm::initializeLFIMCStreamer().
|
inline |
Create a MCObjectFileInfo implementation for the specified target triple.
Definition at line 419 of file TargetRegistry.h.
References llvm::MCObjectFileInfo::initMCObjectFileInfo(), and PIC.
Referenced by llvm::dwarf_linker::classic::DwarfStreamer::init(), and llvm::dwarf_linker::parallel::DwarfEmitterImpl::init().
| MCStreamer * Target::createMCObjectStreamer | ( | const Triple & | T, |
| MCContext & | Ctx, | ||
| std::unique_ptr< MCAsmBackend > | TAB, | ||
| std::unique_ptr< MCObjectWriter > | OW, | ||
| std::unique_ptr< MCCodeEmitter > | Emitter, | ||
| const MCSubtargetInfo & | STI ) const |
Create a target specific MCStreamer.
| T | The target triple. |
| Ctx | The target context. |
| TAB | The target assembler backend object. Takes ownership. |
| OW | The stream object. |
| Emitter | The target independent assembler object.Takes ownership. |
Definition at line 27 of file TargetRegistry.cpp.
References assert(), llvm::Triple::COFF, llvm::createDXContainerStreamer(), llvm::createELFStreamer(), llvm::createGOFFStreamer(), llvm::createMachOStreamer(), llvm::createSPIRVStreamer(), llvm::createWasmStreamer(), llvm::Triple::DXContainer, llvm::Triple::ELF, Emitter, llvm::Triple::GOFF, llvm::initializeLFIMCStreamer(), llvm_unreachable, llvm::Triple::MachO, llvm::Triple::SPIRV, T, llvm::Triple::UnknownObjectFormat, llvm::Triple::Wasm, and llvm::Triple::XCOFF.
Referenced by llvm::dwarf_linker::classic::DwarfStreamer::init(), and llvm::dwarf_linker::parallel::DwarfEmitterImpl::init().
|
inline |
Create a MCRegisterInfo implementation.
Definition at line 446 of file TargetRegistry.h.
Referenced by llvm::dwarf_linker::classic::DwarfStreamer::init(), llvm::dwarf_linker::parallel::DwarfEmitterImpl::init(), llvm::initializeLFIMCStreamer(), LLVMCreateDisasmCPUFeatures(), and llvm::logicalview::LVBinaryReader::loadGenericTargetInfo().
|
inline |
createMCRelocationInfo - Create a target specific MCRelocationInfo.
| TT | The target triple. |
| Ctx | The target context. |
Definition at line 590 of file TargetRegistry.h.
References llvm::createMCRelocationInfo().
Referenced by LLVMCreateDisasmCPUFeatures().
|
inline |
createMCSubtargetInfo - Create a MCSubtargetInfo implementation.
| TheTriple | This argument is used to determine the target machine feature set; it should always be provided. Generally this should be either the target triple from the module, or the target triple of the host if that does not exist. |
| CPU | This specifies the name of the target CPU. |
| Features | This specifies the string representation of the additional target features. |
Definition at line 461 of file TargetRegistry.h.
Referenced by llvm::dwarf_linker::classic::DwarfStreamer::init(), llvm::dwarf_linker::parallel::DwarfEmitterImpl::init(), LLVMCreateDisasmCPUFeatures(), and llvm::logicalview::LVBinaryReader::loadGenericTargetInfo().
|
inline |
createMCSymbolizer - Create a target specific MCSymbolizer.
| TT | The target triple. |
| GetOpInfo | The function to get the symbolic information for operands. |
| SymbolLookUp | The function to lookup a symbol name. |
| DisInfo | The pointer to the block of symbolic information for above call back. |
| Ctx | The target context. |
| RelInfo | The relocation information for this target. Takes ownership. |
Definition at line 611 of file TargetRegistry.h.
References llvm::createMCSymbolizer().
Referenced by LLVMCreateDisasmCPUFeatures().
|
inline |
Definition at line 567 of file TargetRegistry.h.
References llvm::createNullStreamer(), and createNullTargetStreamer().
|
inline |
Definition at line 573 of file TargetRegistry.h.
Referenced by createNullStreamer().
|
inline |
createTargetMachine - Create a target specific machine implementation for the specified Triple.
| TT | This argument is used to determine the target machine feature set; it should always be provided. Generally this should be either the target triple from the module, or the target triple of the host if that does not exist. |
Definition at line 475 of file TargetRegistry.h.
References llvm::Default, and Options.
Referenced by llvm::ThinLTOCodeGeneratorImpl::TargetMachineBuilder::create(), createTargetMachine(), createTargetMachine(), llvm::codegen::createTargetMachineForTriple(), llvm::dwarf_linker::classic::DwarfStreamer::init(), llvm::dwarf_linker::parallel::DwarfEmitterImpl::init(), llvm::EngineBuilder::selectTarget(), and llvm::SPIRVTranslate().
getBackendName - Get the backend name.
Definition at line 380 of file TargetRegistry.h.
getName - Get the target name.
Definition at line 374 of file TargetRegistry.h.
Referenced by llvm::jitlink::TableManager< TableManagerImplT >::getEntryForTarget(), llvm::jitlink::PerGraphGOTAndPLTStubsBuilder< BuilderImplT >::getGOTEntry(), llvm::jitlink::PerGraphGOTAndPLTStubsBuilder< BuilderImplT >::getPLTStub(), llvm::MachObjectWriter::getSymbolAddress(), llvm::logicalview::LVScope::markMissingParents(), llvm::logicalview::LVSymbol::markMissingParents(), llvm::logicalview::LVType::markMissingParents(), llvm::jitlink::TableManager< TableManagerImplT >::registerPreExistingEntry(), llvm::jitlink::aarch32::StubsManager_prev7::visitEdge(), and llvm::jitlink::aarch32::StubsManager_v7::visitEdge().
Definition at line 371 of file TargetRegistry.h.
References Target().
getShortDescription - Get a short description of the target.
Definition at line 377 of file TargetRegistry.h.
Referenced by llvm::TargetRegistry::printRegisteredTargetsForVersion().
|
inline |
hasJIT - Check if this targets supports the just-in-time compilation.
Definition at line 387 of file TargetRegistry.h.
Referenced by llvm::EngineBuilder::create().
|
inline |
hasMCAsmBackend - Check if this target supports .o generation.
Definition at line 393 of file TargetRegistry.h.
|
inline |
hasMCAsmParser - Check if this target supports assembly parsing.
Definition at line 396 of file TargetRegistry.h.
|
inline |
hasTargetMachine - Check if this target supports code generation.
Definition at line 390 of file TargetRegistry.h.
|
friend |
Definition at line 149 of file TargetRegistry.h.
References TargetRegistry.
Referenced by TargetRegistry.