1 //===-- Support/TargetRegistry.h - Target Registration ----------*- C++ -*-===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This file exposes the TargetRegistry interface, which tools can use to access 11 // the appropriate target specific classes (TargetMachine, AsmPrinter, etc.) 12 // which have been registered. 13 // 14 // Target specific class implementations should register themselves using the 15 // appropriate TargetRegistry interfaces. 16 // 17 //===----------------------------------------------------------------------===// 18 19 #ifndef LLVM_SUPPORT_TARGETREGISTRY_H 20 #define LLVM_SUPPORT_TARGETREGISTRY_H 21 22 #include "llvm/ADT/Triple.h" 23 #include "llvm/Support/CodeGen.h" 24 #include "llvm-c/Disassembler.h" 25 #include <cassert> 26 #include <string> 27 28 namespace llvm { 29 class AsmPrinter; 30 class Module; 31 class MCAssembler; 32 class MCAsmBackend; 33 class MCAsmInfo; 34 class MCAsmParser; 35 class MCCodeEmitter; 36 class MCCodeGenInfo; 37 class MCContext; 38 class MCDisassembler; 39 class MCInstrAnalysis; 40 class MCInstPrinter; 41 class MCInstrInfo; 42 class MCRegisterInfo; 43 class MCStreamer; 44 class MCSubtargetInfo; 45 class MCSymbolizer; 46 class MCRelocationInfo; 47 class MCTargetAsmParser; 48 class TargetMachine; 49 class TargetOptions; 50 class raw_ostream; 51 class formatted_raw_ostream; 52 53 MCStreamer *createAsmStreamer(MCContext &Ctx, formatted_raw_ostream &OS, 54 bool isVerboseAsm, 55 bool useLoc, bool useCFI, 56 bool useDwarfDirectory, 57 MCInstPrinter *InstPrint, 58 MCCodeEmitter *CE, 59 MCAsmBackend *TAB, 60 bool ShowInst); 61 62 MCRelocationInfo *createMCRelocationInfo(StringRef TT, MCContext &Ctx); 63 64 MCSymbolizer *createMCSymbolizer(StringRef TT, LLVMOpInfoCallback GetOpInfo, 65 LLVMSymbolLookupCallback SymbolLookUp, 66 void *DisInfo, 67 MCContext *Ctx, 68 MCRelocationInfo *RelInfo); 69 70 /// Target - Wrapper for Target specific information. 71 /// 72 /// For registration purposes, this is a POD type so that targets can be 73 /// registered without the use of static constructors. 74 /// 75 /// Targets should implement a single global instance of this class (which 76 /// will be zero initialized), and pass that instance to the TargetRegistry as 77 /// part of their initialization. 78 class Target { 79 public: 80 friend struct TargetRegistry; 81 82 typedef unsigned (*TripleMatchQualityFnTy)(const std::string &TT); 83 84 typedef MCAsmInfo *(*MCAsmInfoCtorFnTy)(const MCRegisterInfo &MRI, 85 StringRef TT); 86 typedef MCCodeGenInfo *(*MCCodeGenInfoCtorFnTy)(StringRef TT, 87 Reloc::Model RM, 88 CodeModel::Model CM, 89 CodeGenOpt::Level OL); 90 typedef MCInstrInfo *(*MCInstrInfoCtorFnTy)(void); 91 typedef MCInstrAnalysis *(*MCInstrAnalysisCtorFnTy)(const MCInstrInfo*Info); 92 typedef MCRegisterInfo *(*MCRegInfoCtorFnTy)(StringRef TT); 93 typedef MCSubtargetInfo *(*MCSubtargetInfoCtorFnTy)(StringRef TT, 94 StringRef CPU, 95 StringRef Features); 96 typedef TargetMachine *(*TargetMachineCtorTy)(const Target &T, 97 StringRef TT, 98 StringRef CPU, 99 StringRef Features, 100 const TargetOptions &Options, 101 Reloc::Model RM, 102 CodeModel::Model CM, 103 CodeGenOpt::Level OL); 104 typedef AsmPrinter *(*AsmPrinterCtorTy)(TargetMachine &TM, 105 MCStreamer &Streamer); 106 typedef MCAsmBackend *(*MCAsmBackendCtorTy)(const Target &T, 107 StringRef TT, 108 StringRef CPU); 109 typedef MCTargetAsmParser *(*MCAsmParserCtorTy)(MCSubtargetInfo &STI, 110 MCAsmParser &P); 111 typedef MCDisassembler *(*MCDisassemblerCtorTy)(const Target &T, 112 const MCSubtargetInfo &STI); 113 typedef MCInstPrinter *(*MCInstPrinterCtorTy)(const Target &T, 114 unsigned SyntaxVariant, 115 const MCAsmInfo &MAI, 116 const MCInstrInfo &MII, 117 const MCRegisterInfo &MRI, 118 const MCSubtargetInfo &STI); 119 typedef MCCodeEmitter *(*MCCodeEmitterCtorTy)(const MCInstrInfo &II, 120 const MCRegisterInfo &MRI, 121 const MCSubtargetInfo &STI, 122 MCContext &Ctx); 123 typedef MCStreamer *(*MCObjectStreamerCtorTy)(const Target &T, 124 StringRef TT, 125 MCContext &Ctx, 126 MCAsmBackend &TAB, 127 raw_ostream &_OS, 128 MCCodeEmitter *_Emitter, 129 bool RelaxAll, 130 bool NoExecStack); 131 typedef MCStreamer *(*AsmStreamerCtorTy)(MCContext &Ctx, 132 formatted_raw_ostream &OS, 133 bool isVerboseAsm, 134 bool useLoc, 135 bool useCFI, 136 bool useDwarfDirectory, 137 MCInstPrinter *InstPrint, 138 MCCodeEmitter *CE, 139 MCAsmBackend *TAB, 140 bool ShowInst); 141 typedef MCRelocationInfo *(*MCRelocationInfoCtorTy)(StringRef TT, 142 MCContext &Ctx); 143 typedef MCSymbolizer *(*MCSymbolizerCtorTy)(StringRef TT, 144 LLVMOpInfoCallback GetOpInfo, 145 LLVMSymbolLookupCallback SymbolLookUp, 146 void *DisInfo, 147 MCContext *Ctx, 148 MCRelocationInfo *RelInfo); 149 150 private: 151 /// Next - The next registered target in the linked list, maintained by the 152 /// TargetRegistry. 153 Target *Next; 154 155 /// TripleMatchQualityFn - The target function for rating the match quality 156 /// of a triple. 157 TripleMatchQualityFnTy TripleMatchQualityFn; 158 159 /// Name - The target name. 160 const char *Name; 161 162 /// ShortDesc - A short description of the target. 163 const char *ShortDesc; 164 165 /// HasJIT - Whether this target supports the JIT. 166 bool HasJIT; 167 168 /// MCAsmInfoCtorFn - Constructor function for this target's MCAsmInfo, if 169 /// registered. 170 MCAsmInfoCtorFnTy MCAsmInfoCtorFn; 171 172 /// MCCodeGenInfoCtorFn - Constructor function for this target's 173 /// MCCodeGenInfo, if registered. 174 MCCodeGenInfoCtorFnTy MCCodeGenInfoCtorFn; 175 176 /// MCInstrInfoCtorFn - Constructor function for this target's MCInstrInfo, 177 /// if registered. 178 MCInstrInfoCtorFnTy MCInstrInfoCtorFn; 179 180 /// MCInstrAnalysisCtorFn - Constructor function for this target's 181 /// MCInstrAnalysis, if registered. 182 MCInstrAnalysisCtorFnTy MCInstrAnalysisCtorFn; 183 184 /// MCRegInfoCtorFn - Constructor function for this target's MCRegisterInfo, 185 /// if registered. 186 MCRegInfoCtorFnTy MCRegInfoCtorFn; 187 188 /// MCSubtargetInfoCtorFn - Constructor function for this target's 189 /// MCSubtargetInfo, if registered. 190 MCSubtargetInfoCtorFnTy MCSubtargetInfoCtorFn; 191 192 /// TargetMachineCtorFn - Construction function for this target's 193 /// TargetMachine, if registered. 194 TargetMachineCtorTy TargetMachineCtorFn; 195 196 /// MCAsmBackendCtorFn - Construction function for this target's 197 /// MCAsmBackend, if registered. 198 MCAsmBackendCtorTy MCAsmBackendCtorFn; 199 200 /// MCAsmParserCtorFn - Construction function for this target's 201 /// MCTargetAsmParser, if registered. 202 MCAsmParserCtorTy MCAsmParserCtorFn; 203 204 /// AsmPrinterCtorFn - Construction function for this target's AsmPrinter, 205 /// if registered. 206 AsmPrinterCtorTy AsmPrinterCtorFn; 207 208 /// MCDisassemblerCtorFn - Construction function for this target's 209 /// MCDisassembler, if registered. 210 MCDisassemblerCtorTy MCDisassemblerCtorFn; 211 212 /// MCInstPrinterCtorFn - Construction function for this target's 213 /// MCInstPrinter, if registered. 214 MCInstPrinterCtorTy MCInstPrinterCtorFn; 215 216 /// MCCodeEmitterCtorFn - Construction function for this target's 217 /// CodeEmitter, if registered. 218 MCCodeEmitterCtorTy MCCodeEmitterCtorFn; 219 220 /// MCObjectStreamerCtorFn - Construction function for this target's 221 /// MCObjectStreamer, if registered. 222 MCObjectStreamerCtorTy MCObjectStreamerCtorFn; 223 224 /// AsmStreamerCtorFn - Construction function for this target's 225 /// AsmStreamer, if registered (default = llvm::createAsmStreamer). 226 AsmStreamerCtorTy AsmStreamerCtorFn; 227 228 /// MCRelocationInfoCtorFn - Construction function for this target's 229 /// MCRelocationInfo, if registered (default = llvm::createMCRelocationInfo) 230 MCRelocationInfoCtorTy MCRelocationInfoCtorFn; 231 232 /// MCSymbolizerCtorFn - Construction function for this target's 233 /// MCSymbolizer, if registered (default = llvm::createMCSymbolizer) 234 MCSymbolizerCtorTy MCSymbolizerCtorFn; 235 236 public: Target()237 Target() : AsmStreamerCtorFn(llvm::createAsmStreamer), 238 MCRelocationInfoCtorFn(llvm::createMCRelocationInfo), 239 MCSymbolizerCtorFn(llvm::createMCSymbolizer) {} 240 241 /// @name Target Information 242 /// @{ 243 244 // getNext - Return the next registered target. getNext()245 const Target *getNext() const { return Next; } 246 247 /// getName - Get the target name. getName()248 const char *getName() const { return Name; } 249 250 /// getShortDescription - Get a short description of the target. getShortDescription()251 const char *getShortDescription() const { return ShortDesc; } 252 253 /// @} 254 /// @name Feature Predicates 255 /// @{ 256 257 /// hasJIT - Check if this targets supports the just-in-time compilation. hasJIT()258 bool hasJIT() const { return HasJIT; } 259 260 /// hasTargetMachine - Check if this target supports code generation. hasTargetMachine()261 bool hasTargetMachine() const { return TargetMachineCtorFn != 0; } 262 263 /// hasMCAsmBackend - Check if this target supports .o generation. hasMCAsmBackend()264 bool hasMCAsmBackend() const { return MCAsmBackendCtorFn != 0; } 265 266 /// hasAsmParser - Check if this target supports .s parsing. hasMCAsmParser()267 bool hasMCAsmParser() const { return MCAsmParserCtorFn != 0; } 268 269 /// hasAsmPrinter - Check if this target supports .s printing. hasAsmPrinter()270 bool hasAsmPrinter() const { return AsmPrinterCtorFn != 0; } 271 272 /// hasMCDisassembler - Check if this target has a disassembler. hasMCDisassembler()273 bool hasMCDisassembler() const { return MCDisassemblerCtorFn != 0; } 274 275 /// hasMCInstPrinter - Check if this target has an instruction printer. hasMCInstPrinter()276 bool hasMCInstPrinter() const { return MCInstPrinterCtorFn != 0; } 277 278 /// hasMCCodeEmitter - Check if this target supports instruction encoding. hasMCCodeEmitter()279 bool hasMCCodeEmitter() const { return MCCodeEmitterCtorFn != 0; } 280 281 /// hasMCObjectStreamer - Check if this target supports streaming to files. hasMCObjectStreamer()282 bool hasMCObjectStreamer() const { return MCObjectStreamerCtorFn != 0; } 283 284 /// hasAsmStreamer - Check if this target supports streaming to files. hasAsmStreamer()285 bool hasAsmStreamer() const { return AsmStreamerCtorFn != 0; } 286 287 /// @} 288 /// @name Feature Constructors 289 /// @{ 290 291 /// createMCAsmInfo - Create a MCAsmInfo implementation for the specified 292 /// target triple. 293 /// 294 /// \param Triple This argument is used to determine the target machine 295 /// feature set; it should always be provided. Generally this should be 296 /// either the target triple from the module, or the target triple of the 297 /// host if that does not exist. createMCAsmInfo(const MCRegisterInfo & MRI,StringRef Triple)298 MCAsmInfo *createMCAsmInfo(const MCRegisterInfo &MRI, 299 StringRef Triple) const { 300 if (!MCAsmInfoCtorFn) 301 return 0; 302 return MCAsmInfoCtorFn(MRI, Triple); 303 } 304 305 /// createMCCodeGenInfo - Create a MCCodeGenInfo implementation. 306 /// createMCCodeGenInfo(StringRef Triple,Reloc::Model RM,CodeModel::Model CM,CodeGenOpt::Level OL)307 MCCodeGenInfo *createMCCodeGenInfo(StringRef Triple, Reloc::Model RM, 308 CodeModel::Model CM, 309 CodeGenOpt::Level OL) const { 310 if (!MCCodeGenInfoCtorFn) 311 return 0; 312 return MCCodeGenInfoCtorFn(Triple, RM, CM, OL); 313 } 314 315 /// createMCInstrInfo - Create a MCInstrInfo implementation. 316 /// createMCInstrInfo()317 MCInstrInfo *createMCInstrInfo() const { 318 if (!MCInstrInfoCtorFn) 319 return 0; 320 return MCInstrInfoCtorFn(); 321 } 322 323 /// createMCInstrAnalysis - Create a MCInstrAnalysis implementation. 324 /// createMCInstrAnalysis(const MCInstrInfo * Info)325 MCInstrAnalysis *createMCInstrAnalysis(const MCInstrInfo *Info) const { 326 if (!MCInstrAnalysisCtorFn) 327 return 0; 328 return MCInstrAnalysisCtorFn(Info); 329 } 330 331 /// createMCRegInfo - Create a MCRegisterInfo implementation. 332 /// createMCRegInfo(StringRef Triple)333 MCRegisterInfo *createMCRegInfo(StringRef Triple) const { 334 if (!MCRegInfoCtorFn) 335 return 0; 336 return MCRegInfoCtorFn(Triple); 337 } 338 339 /// createMCSubtargetInfo - Create a MCSubtargetInfo implementation. 340 /// 341 /// \param Triple This argument is used to determine the target machine 342 /// feature set; it should always be provided. Generally this should be 343 /// either the target triple from the module, or the target triple of the 344 /// host if that does not exist. 345 /// \param CPU This specifies the name of the target CPU. 346 /// \param Features This specifies the string representation of the 347 /// additional target features. createMCSubtargetInfo(StringRef Triple,StringRef CPU,StringRef Features)348 MCSubtargetInfo *createMCSubtargetInfo(StringRef Triple, StringRef CPU, 349 StringRef Features) const { 350 if (!MCSubtargetInfoCtorFn) 351 return 0; 352 return MCSubtargetInfoCtorFn(Triple, CPU, Features); 353 } 354 355 /// createTargetMachine - Create a target specific machine implementation 356 /// for the specified \p Triple. 357 /// 358 /// \param Triple This argument is used to determine the target machine 359 /// feature set; it should always be provided. Generally this should be 360 /// either the target triple from the module, or the target triple of the 361 /// host if that does not exist. 362 TargetMachine *createTargetMachine(StringRef Triple, StringRef CPU, 363 StringRef Features, const TargetOptions &Options, 364 Reloc::Model RM = Reloc::Default, 365 CodeModel::Model CM = CodeModel::Default, 366 CodeGenOpt::Level OL = CodeGenOpt::Default) const { 367 if (!TargetMachineCtorFn) 368 return 0; 369 return TargetMachineCtorFn(*this, Triple, CPU, Features, Options, 370 RM, CM, OL); 371 } 372 373 /// createMCAsmBackend - Create a target specific assembly parser. 374 /// 375 /// \param Triple The target triple string. createMCAsmBackend(StringRef Triple,StringRef CPU)376 MCAsmBackend *createMCAsmBackend(StringRef Triple, StringRef CPU) const { 377 if (!MCAsmBackendCtorFn) 378 return 0; 379 return MCAsmBackendCtorFn(*this, Triple, CPU); 380 } 381 382 /// createMCAsmParser - Create a target specific assembly parser. 383 /// 384 /// \param Parser The target independent parser implementation to use for 385 /// parsing and lexing. createMCAsmParser(MCSubtargetInfo & STI,MCAsmParser & Parser)386 MCTargetAsmParser *createMCAsmParser(MCSubtargetInfo &STI, 387 MCAsmParser &Parser) const { 388 if (!MCAsmParserCtorFn) 389 return 0; 390 return MCAsmParserCtorFn(STI, Parser); 391 } 392 393 /// createAsmPrinter - Create a target specific assembly printer pass. This 394 /// takes ownership of the MCStreamer object. createAsmPrinter(TargetMachine & TM,MCStreamer & Streamer)395 AsmPrinter *createAsmPrinter(TargetMachine &TM, MCStreamer &Streamer) const{ 396 if (!AsmPrinterCtorFn) 397 return 0; 398 return AsmPrinterCtorFn(TM, Streamer); 399 } 400 createMCDisassembler(const MCSubtargetInfo & STI)401 MCDisassembler *createMCDisassembler(const MCSubtargetInfo &STI) const { 402 if (!MCDisassemblerCtorFn) 403 return 0; 404 return MCDisassemblerCtorFn(*this, STI); 405 } 406 createMCInstPrinter(unsigned SyntaxVariant,const MCAsmInfo & MAI,const MCInstrInfo & MII,const MCRegisterInfo & MRI,const MCSubtargetInfo & STI)407 MCInstPrinter *createMCInstPrinter(unsigned SyntaxVariant, 408 const MCAsmInfo &MAI, 409 const MCInstrInfo &MII, 410 const MCRegisterInfo &MRI, 411 const MCSubtargetInfo &STI) const { 412 if (!MCInstPrinterCtorFn) 413 return 0; 414 return MCInstPrinterCtorFn(*this, SyntaxVariant, MAI, MII, MRI, STI); 415 } 416 417 418 /// createMCCodeEmitter - Create a target specific code emitter. createMCCodeEmitter(const MCInstrInfo & II,const MCRegisterInfo & MRI,const MCSubtargetInfo & STI,MCContext & Ctx)419 MCCodeEmitter *createMCCodeEmitter(const MCInstrInfo &II, 420 const MCRegisterInfo &MRI, 421 const MCSubtargetInfo &STI, 422 MCContext &Ctx) const { 423 if (!MCCodeEmitterCtorFn) 424 return 0; 425 return MCCodeEmitterCtorFn(II, MRI, STI, Ctx); 426 } 427 428 /// createMCObjectStreamer - Create a target specific MCStreamer. 429 /// 430 /// \param TT The target triple. 431 /// \param Ctx The target context. 432 /// \param TAB The target assembler backend object. Takes ownership. 433 /// \param _OS The stream object. 434 /// \param _Emitter The target independent assembler object.Takes ownership. 435 /// \param RelaxAll Relax all fixups? 436 /// \param NoExecStack Mark file as not needing a executable stack. createMCObjectStreamer(StringRef TT,MCContext & Ctx,MCAsmBackend & TAB,raw_ostream & _OS,MCCodeEmitter * _Emitter,bool RelaxAll,bool NoExecStack)437 MCStreamer *createMCObjectStreamer(StringRef TT, MCContext &Ctx, 438 MCAsmBackend &TAB, 439 raw_ostream &_OS, 440 MCCodeEmitter *_Emitter, 441 bool RelaxAll, 442 bool NoExecStack) const { 443 if (!MCObjectStreamerCtorFn) 444 return 0; 445 return MCObjectStreamerCtorFn(*this, TT, Ctx, TAB, _OS, _Emitter, 446 RelaxAll, NoExecStack); 447 } 448 449 /// createAsmStreamer - Create a target specific MCStreamer. createAsmStreamer(MCContext & Ctx,formatted_raw_ostream & OS,bool isVerboseAsm,bool useLoc,bool useCFI,bool useDwarfDirectory,MCInstPrinter * InstPrint,MCCodeEmitter * CE,MCAsmBackend * TAB,bool ShowInst)450 MCStreamer *createAsmStreamer(MCContext &Ctx, 451 formatted_raw_ostream &OS, 452 bool isVerboseAsm, 453 bool useLoc, 454 bool useCFI, 455 bool useDwarfDirectory, 456 MCInstPrinter *InstPrint, 457 MCCodeEmitter *CE, 458 MCAsmBackend *TAB, 459 bool ShowInst) const { 460 // AsmStreamerCtorFn is default to llvm::createAsmStreamer 461 return AsmStreamerCtorFn(Ctx, OS, isVerboseAsm, useLoc, useCFI, 462 useDwarfDirectory, InstPrint, CE, TAB, ShowInst); 463 } 464 465 /// createMCRelocationInfo - Create a target specific MCRelocationInfo. 466 /// 467 /// \param TT The target triple. 468 /// \param Ctx The target context. 469 MCRelocationInfo * createMCRelocationInfo(StringRef TT,MCContext & Ctx)470 createMCRelocationInfo(StringRef TT, MCContext &Ctx) const { 471 return MCRelocationInfoCtorFn(TT, Ctx); 472 } 473 474 /// createMCSymbolizer - Create a target specific MCSymbolizer. 475 /// 476 /// \param TT The target triple. 477 /// \param GetOpInfo The function to get the symbolic information for operands. 478 /// \param SymbolLookUp The function to lookup a symbol name. 479 /// \param DisInfo The pointer to the block of symbolic information for above call 480 /// back. 481 /// \param Ctx The target context. 482 /// \param RelInfo The relocation information for this target. Takes ownership. 483 MCSymbolizer * createMCSymbolizer(StringRef TT,LLVMOpInfoCallback GetOpInfo,LLVMSymbolLookupCallback SymbolLookUp,void * DisInfo,MCContext * Ctx,MCRelocationInfo * RelInfo)484 createMCSymbolizer(StringRef TT, LLVMOpInfoCallback GetOpInfo, 485 LLVMSymbolLookupCallback SymbolLookUp, 486 void *DisInfo, 487 MCContext *Ctx, MCRelocationInfo *RelInfo) const { 488 return MCSymbolizerCtorFn(TT, GetOpInfo, SymbolLookUp, DisInfo, 489 Ctx, RelInfo); 490 } 491 492 /// @} 493 }; 494 495 /// TargetRegistry - Generic interface to target specific features. 496 struct TargetRegistry { 497 class iterator { 498 const Target *Current; iteratorTargetRegistry499 explicit iterator(Target *T) : Current(T) {} 500 friend struct TargetRegistry; 501 public: iteratorTargetRegistry502 iterator(const iterator &I) : Current(I.Current) {} iteratorTargetRegistry503 iterator() : Current(0) {} 504 505 bool operator==(const iterator &x) const { 506 return Current == x.Current; 507 } 508 bool operator!=(const iterator &x) const { 509 return !operator==(x); 510 } 511 512 // Iterator traversal: forward iteration only 513 iterator &operator++() { // Preincrement 514 assert(Current && "Cannot increment end iterator!"); 515 Current = Current->getNext(); 516 return *this; 517 } 518 iterator operator++(int) { // Postincrement 519 iterator tmp = *this; 520 ++*this; 521 return tmp; 522 } 523 524 const Target &operator*() const { 525 assert(Current && "Cannot dereference end iterator!"); 526 return *Current; 527 } 528 529 const Target *operator->() const { 530 return &operator*(); 531 } 532 }; 533 534 /// printRegisteredTargetsForVersion - Print the registered targets 535 /// appropriately for inclusion in a tool's version output. 536 static void printRegisteredTargetsForVersion(); 537 538 /// @name Registry Access 539 /// @{ 540 541 static iterator begin(); 542 endTargetRegistry543 static iterator end() { return iterator(); } 544 545 /// lookupTarget - Lookup a target based on a target triple. 546 /// 547 /// \param Triple - The triple to use for finding a target. 548 /// \param Error - On failure, an error string describing why no target was 549 /// found. 550 static const Target *lookupTarget(const std::string &Triple, 551 std::string &Error); 552 553 /// lookupTarget - Lookup a target based on an architecture name 554 /// and a target triple. If the architecture name is non-empty, 555 /// then the lookup is done by architecture. Otherwise, the target 556 /// triple is used. 557 /// 558 /// \param ArchName - The architecture to use for finding a target. 559 /// \param TheTriple - The triple to use for finding a target. The 560 /// triple is updated with canonical architecture name if a lookup 561 /// by architecture is done. 562 /// \param Error - On failure, an error string describing why no target was 563 /// found. 564 static const Target *lookupTarget(const std::string &ArchName, 565 Triple &TheTriple, 566 std::string &Error); 567 568 /// getClosestTargetForJIT - Pick the best target that is compatible with 569 /// the current host. If no close target can be found, this returns null 570 /// and sets the Error string to a reason. 571 /// 572 /// Maintained for compatibility through 2.6. 573 static const Target *getClosestTargetForJIT(std::string &Error); 574 575 /// @} 576 /// @name Target Registration 577 /// @{ 578 579 /// RegisterTarget - Register the given target. Attempts to register a 580 /// target which has already been registered will be ignored. 581 /// 582 /// Clients are responsible for ensuring that registration doesn't occur 583 /// while another thread is attempting to access the registry. Typically 584 /// this is done by initializing all targets at program startup. 585 /// 586 /// @param T - The target being registered. 587 /// @param Name - The target name. This should be a static string. 588 /// @param ShortDesc - A short target description. This should be a static 589 /// string. 590 /// @param TQualityFn - The triple match quality computation function for 591 /// this target. 592 /// @param HasJIT - Whether the target supports JIT code 593 /// generation. 594 static void RegisterTarget(Target &T, 595 const char *Name, 596 const char *ShortDesc, 597 Target::TripleMatchQualityFnTy TQualityFn, 598 bool HasJIT = false); 599 600 /// RegisterMCAsmInfo - Register a MCAsmInfo implementation for the 601 /// given target. 602 /// 603 /// Clients are responsible for ensuring that registration doesn't occur 604 /// while another thread is attempting to access the registry. Typically 605 /// this is done by initializing all targets at program startup. 606 /// 607 /// @param T - The target being registered. 608 /// @param Fn - A function to construct a MCAsmInfo for the target. RegisterMCAsmInfoTargetRegistry609 static void RegisterMCAsmInfo(Target &T, Target::MCAsmInfoCtorFnTy Fn) { 610 // Ignore duplicate registration. 611 if (!T.MCAsmInfoCtorFn) 612 T.MCAsmInfoCtorFn = Fn; 613 } 614 615 /// RegisterMCCodeGenInfo - Register a MCCodeGenInfo implementation for the 616 /// given target. 617 /// 618 /// Clients are responsible for ensuring that registration doesn't occur 619 /// while another thread is attempting to access the registry. Typically 620 /// this is done by initializing all targets at program startup. 621 /// 622 /// @param T - The target being registered. 623 /// @param Fn - A function to construct a MCCodeGenInfo for the target. RegisterMCCodeGenInfoTargetRegistry624 static void RegisterMCCodeGenInfo(Target &T, 625 Target::MCCodeGenInfoCtorFnTy Fn) { 626 // Ignore duplicate registration. 627 if (!T.MCCodeGenInfoCtorFn) 628 T.MCCodeGenInfoCtorFn = Fn; 629 } 630 631 /// RegisterMCInstrInfo - Register a MCInstrInfo implementation for the 632 /// given target. 633 /// 634 /// Clients are responsible for ensuring that registration doesn't occur 635 /// while another thread is attempting to access the registry. Typically 636 /// this is done by initializing all targets at program startup. 637 /// 638 /// @param T - The target being registered. 639 /// @param Fn - A function to construct a MCInstrInfo for the target. RegisterMCInstrInfoTargetRegistry640 static void RegisterMCInstrInfo(Target &T, Target::MCInstrInfoCtorFnTy Fn) { 641 // Ignore duplicate registration. 642 if (!T.MCInstrInfoCtorFn) 643 T.MCInstrInfoCtorFn = Fn; 644 } 645 646 /// RegisterMCInstrAnalysis - Register a MCInstrAnalysis implementation for 647 /// the given target. RegisterMCInstrAnalysisTargetRegistry648 static void RegisterMCInstrAnalysis(Target &T, 649 Target::MCInstrAnalysisCtorFnTy Fn) { 650 // Ignore duplicate registration. 651 if (!T.MCInstrAnalysisCtorFn) 652 T.MCInstrAnalysisCtorFn = Fn; 653 } 654 655 /// RegisterMCRegInfo - Register a MCRegisterInfo implementation for the 656 /// given target. 657 /// 658 /// Clients are responsible for ensuring that registration doesn't occur 659 /// while another thread is attempting to access the registry. Typically 660 /// this is done by initializing all targets at program startup. 661 /// 662 /// @param T - The target being registered. 663 /// @param Fn - A function to construct a MCRegisterInfo for the target. RegisterMCRegInfoTargetRegistry664 static void RegisterMCRegInfo(Target &T, Target::MCRegInfoCtorFnTy Fn) { 665 // Ignore duplicate registration. 666 if (!T.MCRegInfoCtorFn) 667 T.MCRegInfoCtorFn = Fn; 668 } 669 670 /// RegisterMCSubtargetInfo - Register a MCSubtargetInfo implementation for 671 /// the given target. 672 /// 673 /// Clients are responsible for ensuring that registration doesn't occur 674 /// while another thread is attempting to access the registry. Typically 675 /// this is done by initializing all targets at program startup. 676 /// 677 /// @param T - The target being registered. 678 /// @param Fn - A function to construct a MCSubtargetInfo for the target. RegisterMCSubtargetInfoTargetRegistry679 static void RegisterMCSubtargetInfo(Target &T, 680 Target::MCSubtargetInfoCtorFnTy Fn) { 681 // Ignore duplicate registration. 682 if (!T.MCSubtargetInfoCtorFn) 683 T.MCSubtargetInfoCtorFn = Fn; 684 } 685 686 /// RegisterTargetMachine - Register a TargetMachine implementation for the 687 /// given target. 688 /// 689 /// Clients are responsible for ensuring that registration doesn't occur 690 /// while another thread is attempting to access the registry. Typically 691 /// this is done by initializing all targets at program startup. 692 /// 693 /// @param T - The target being registered. 694 /// @param Fn - A function to construct a TargetMachine for the target. RegisterTargetMachineTargetRegistry695 static void RegisterTargetMachine(Target &T, 696 Target::TargetMachineCtorTy Fn) { 697 // Ignore duplicate registration. 698 if (!T.TargetMachineCtorFn) 699 T.TargetMachineCtorFn = Fn; 700 } 701 702 /// RegisterMCAsmBackend - Register a MCAsmBackend implementation for the 703 /// given target. 704 /// 705 /// Clients are responsible for ensuring that registration doesn't occur 706 /// while another thread is attempting to access the registry. Typically 707 /// this is done by initializing all targets at program startup. 708 /// 709 /// @param T - The target being registered. 710 /// @param Fn - A function to construct an AsmBackend for the target. RegisterMCAsmBackendTargetRegistry711 static void RegisterMCAsmBackend(Target &T, Target::MCAsmBackendCtorTy Fn) { 712 if (!T.MCAsmBackendCtorFn) 713 T.MCAsmBackendCtorFn = Fn; 714 } 715 716 /// RegisterMCAsmParser - Register a MCTargetAsmParser implementation for 717 /// the given target. 718 /// 719 /// Clients are responsible for ensuring that registration doesn't occur 720 /// while another thread is attempting to access the registry. Typically 721 /// this is done by initializing all targets at program startup. 722 /// 723 /// @param T - The target being registered. 724 /// @param Fn - A function to construct an MCTargetAsmParser for the target. RegisterMCAsmParserTargetRegistry725 static void RegisterMCAsmParser(Target &T, Target::MCAsmParserCtorTy Fn) { 726 if (!T.MCAsmParserCtorFn) 727 T.MCAsmParserCtorFn = Fn; 728 } 729 730 /// RegisterAsmPrinter - Register an AsmPrinter implementation for the given 731 /// target. 732 /// 733 /// Clients are responsible for ensuring that registration doesn't occur 734 /// while another thread is attempting to access the registry. Typically 735 /// this is done by initializing all targets at program startup. 736 /// 737 /// @param T - The target being registered. 738 /// @param Fn - A function to construct an AsmPrinter for the target. RegisterAsmPrinterTargetRegistry739 static void RegisterAsmPrinter(Target &T, Target::AsmPrinterCtorTy Fn) { 740 // Ignore duplicate registration. 741 if (!T.AsmPrinterCtorFn) 742 T.AsmPrinterCtorFn = Fn; 743 } 744 745 /// RegisterMCDisassembler - Register a MCDisassembler implementation for 746 /// the given target. 747 /// 748 /// Clients are responsible for ensuring that registration doesn't occur 749 /// while another thread is attempting to access the registry. Typically 750 /// this is done by initializing all targets at program startup. 751 /// 752 /// @param T - The target being registered. 753 /// @param Fn - A function to construct an MCDisassembler for the target. RegisterMCDisassemblerTargetRegistry754 static void RegisterMCDisassembler(Target &T, 755 Target::MCDisassemblerCtorTy Fn) { 756 if (!T.MCDisassemblerCtorFn) 757 T.MCDisassemblerCtorFn = Fn; 758 } 759 760 /// RegisterMCInstPrinter - Register a MCInstPrinter implementation for the 761 /// given target. 762 /// 763 /// Clients are responsible for ensuring that registration doesn't occur 764 /// while another thread is attempting to access the registry. Typically 765 /// this is done by initializing all targets at program startup. 766 /// 767 /// @param T - The target being registered. 768 /// @param Fn - A function to construct an MCInstPrinter for the target. RegisterMCInstPrinterTargetRegistry769 static void RegisterMCInstPrinter(Target &T, 770 Target::MCInstPrinterCtorTy Fn) { 771 if (!T.MCInstPrinterCtorFn) 772 T.MCInstPrinterCtorFn = Fn; 773 } 774 775 /// RegisterMCCodeEmitter - Register a MCCodeEmitter implementation for the 776 /// given target. 777 /// 778 /// Clients are responsible for ensuring that registration doesn't occur 779 /// while another thread is attempting to access the registry. Typically 780 /// this is done by initializing all targets at program startup. 781 /// 782 /// @param T - The target being registered. 783 /// @param Fn - A function to construct an MCCodeEmitter for the target. RegisterMCCodeEmitterTargetRegistry784 static void RegisterMCCodeEmitter(Target &T, 785 Target::MCCodeEmitterCtorTy Fn) { 786 if (!T.MCCodeEmitterCtorFn) 787 T.MCCodeEmitterCtorFn = Fn; 788 } 789 790 /// RegisterMCObjectStreamer - Register a object code MCStreamer 791 /// implementation for the given target. 792 /// 793 /// Clients are responsible for ensuring that registration doesn't occur 794 /// while another thread is attempting to access the registry. Typically 795 /// this is done by initializing all targets at program startup. 796 /// 797 /// @param T - The target being registered. 798 /// @param Fn - A function to construct an MCStreamer for the target. RegisterMCObjectStreamerTargetRegistry799 static void RegisterMCObjectStreamer(Target &T, 800 Target::MCObjectStreamerCtorTy Fn) { 801 if (!T.MCObjectStreamerCtorFn) 802 T.MCObjectStreamerCtorFn = Fn; 803 } 804 805 /// RegisterAsmStreamer - Register an assembly MCStreamer implementation 806 /// for the given target. 807 /// 808 /// Clients are responsible for ensuring that registration doesn't occur 809 /// while another thread is attempting to access the registry. Typically 810 /// this is done by initializing all targets at program startup. 811 /// 812 /// @param T - The target being registered. 813 /// @param Fn - A function to construct an MCStreamer for the target. RegisterAsmStreamerTargetRegistry814 static void RegisterAsmStreamer(Target &T, Target::AsmStreamerCtorTy Fn) { 815 if (T.AsmStreamerCtorFn == createAsmStreamer) 816 T.AsmStreamerCtorFn = Fn; 817 } 818 819 /// RegisterMCRelocationInfo - Register an MCRelocationInfo 820 /// implementation for the given target. 821 /// 822 /// Clients are responsible for ensuring that registration doesn't occur 823 /// while another thread is attempting to access the registry. Typically 824 /// this is done by initializing all targets at program startup. 825 /// 826 /// @param T - The target being registered. 827 /// @param Fn - A function to construct an MCRelocationInfo for the target. RegisterMCRelocationInfoTargetRegistry828 static void RegisterMCRelocationInfo(Target &T, 829 Target::MCRelocationInfoCtorTy Fn) { 830 if (T.MCRelocationInfoCtorFn == llvm::createMCRelocationInfo) 831 T.MCRelocationInfoCtorFn = Fn; 832 } 833 834 /// RegisterMCSymbolizer - Register an MCSymbolizer 835 /// implementation for the given target. 836 /// 837 /// Clients are responsible for ensuring that registration doesn't occur 838 /// while another thread is attempting to access the registry. Typically 839 /// this is done by initializing all targets at program startup. 840 /// 841 /// @param T - The target being registered. 842 /// @param Fn - A function to construct an MCSymbolizer for the target. RegisterMCSymbolizerTargetRegistry843 static void RegisterMCSymbolizer(Target &T, 844 Target::MCSymbolizerCtorTy Fn) { 845 if (T.MCSymbolizerCtorFn == llvm::createMCSymbolizer) 846 T.MCSymbolizerCtorFn = Fn; 847 } 848 849 /// @} 850 }; 851 852 853 //===--------------------------------------------------------------------===// 854 855 /// RegisterTarget - Helper template for registering a target, for use in the 856 /// target's initialization function. Usage: 857 /// 858 /// 859 /// Target TheFooTarget; // The global target instance. 860 /// 861 /// extern "C" void LLVMInitializeFooTargetInfo() { 862 /// RegisterTarget<Triple::foo> X(TheFooTarget, "foo", "Foo description"); 863 /// } 864 template<Triple::ArchType TargetArchType = Triple::UnknownArch, 865 bool HasJIT = false> 866 struct RegisterTarget { RegisterTargetRegisterTarget867 RegisterTarget(Target &T, const char *Name, const char *Desc) { 868 TargetRegistry::RegisterTarget(T, Name, Desc, 869 &getTripleMatchQuality, 870 HasJIT); 871 } 872 getTripleMatchQualityRegisterTarget873 static unsigned getTripleMatchQuality(const std::string &TT) { 874 if (Triple(TT).getArch() == TargetArchType) 875 return 20; 876 return 0; 877 } 878 }; 879 880 /// RegisterMCAsmInfo - Helper template for registering a target assembly info 881 /// implementation. This invokes the static "Create" method on the class to 882 /// actually do the construction. Usage: 883 /// 884 /// extern "C" void LLVMInitializeFooTarget() { 885 /// extern Target TheFooTarget; 886 /// RegisterMCAsmInfo<FooMCAsmInfo> X(TheFooTarget); 887 /// } 888 template<class MCAsmInfoImpl> 889 struct RegisterMCAsmInfo { RegisterMCAsmInfoRegisterMCAsmInfo890 RegisterMCAsmInfo(Target &T) { 891 TargetRegistry::RegisterMCAsmInfo(T, &Allocator); 892 } 893 private: AllocatorRegisterMCAsmInfo894 static MCAsmInfo *Allocator(const MCRegisterInfo &/*MRI*/, StringRef TT) { 895 return new MCAsmInfoImpl(TT); 896 } 897 898 }; 899 900 /// RegisterMCAsmInfoFn - Helper template for registering a target assembly info 901 /// implementation. This invokes the specified function to do the 902 /// construction. Usage: 903 /// 904 /// extern "C" void LLVMInitializeFooTarget() { 905 /// extern Target TheFooTarget; 906 /// RegisterMCAsmInfoFn X(TheFooTarget, TheFunction); 907 /// } 908 struct RegisterMCAsmInfoFn { RegisterMCAsmInfoFnRegisterMCAsmInfoFn909 RegisterMCAsmInfoFn(Target &T, Target::MCAsmInfoCtorFnTy Fn) { 910 TargetRegistry::RegisterMCAsmInfo(T, Fn); 911 } 912 }; 913 914 /// RegisterMCCodeGenInfo - Helper template for registering a target codegen info 915 /// implementation. This invokes the static "Create" method on the class 916 /// to actually do the construction. Usage: 917 /// 918 /// extern "C" void LLVMInitializeFooTarget() { 919 /// extern Target TheFooTarget; 920 /// RegisterMCCodeGenInfo<FooMCCodeGenInfo> X(TheFooTarget); 921 /// } 922 template<class MCCodeGenInfoImpl> 923 struct RegisterMCCodeGenInfo { RegisterMCCodeGenInfoRegisterMCCodeGenInfo924 RegisterMCCodeGenInfo(Target &T) { 925 TargetRegistry::RegisterMCCodeGenInfo(T, &Allocator); 926 } 927 private: AllocatorRegisterMCCodeGenInfo928 static MCCodeGenInfo *Allocator(StringRef /*TT*/, Reloc::Model /*RM*/, 929 CodeModel::Model /*CM*/, 930 CodeGenOpt::Level /*OL*/) { 931 return new MCCodeGenInfoImpl(); 932 } 933 }; 934 935 /// RegisterMCCodeGenInfoFn - Helper template for registering a target codegen 936 /// info implementation. This invokes the specified function to do the 937 /// construction. Usage: 938 /// 939 /// extern "C" void LLVMInitializeFooTarget() { 940 /// extern Target TheFooTarget; 941 /// RegisterMCCodeGenInfoFn X(TheFooTarget, TheFunction); 942 /// } 943 struct RegisterMCCodeGenInfoFn { RegisterMCCodeGenInfoFnRegisterMCCodeGenInfoFn944 RegisterMCCodeGenInfoFn(Target &T, Target::MCCodeGenInfoCtorFnTy Fn) { 945 TargetRegistry::RegisterMCCodeGenInfo(T, Fn); 946 } 947 }; 948 949 /// RegisterMCInstrInfo - Helper template for registering a target instruction 950 /// info implementation. This invokes the static "Create" method on the class 951 /// to actually do the construction. Usage: 952 /// 953 /// extern "C" void LLVMInitializeFooTarget() { 954 /// extern Target TheFooTarget; 955 /// RegisterMCInstrInfo<FooMCInstrInfo> X(TheFooTarget); 956 /// } 957 template<class MCInstrInfoImpl> 958 struct RegisterMCInstrInfo { RegisterMCInstrInfoRegisterMCInstrInfo959 RegisterMCInstrInfo(Target &T) { 960 TargetRegistry::RegisterMCInstrInfo(T, &Allocator); 961 } 962 private: AllocatorRegisterMCInstrInfo963 static MCInstrInfo *Allocator() { 964 return new MCInstrInfoImpl(); 965 } 966 }; 967 968 /// RegisterMCInstrInfoFn - Helper template for registering a target 969 /// instruction info implementation. This invokes the specified function to 970 /// do the construction. Usage: 971 /// 972 /// extern "C" void LLVMInitializeFooTarget() { 973 /// extern Target TheFooTarget; 974 /// RegisterMCInstrInfoFn X(TheFooTarget, TheFunction); 975 /// } 976 struct RegisterMCInstrInfoFn { RegisterMCInstrInfoFnRegisterMCInstrInfoFn977 RegisterMCInstrInfoFn(Target &T, Target::MCInstrInfoCtorFnTy Fn) { 978 TargetRegistry::RegisterMCInstrInfo(T, Fn); 979 } 980 }; 981 982 /// RegisterMCInstrAnalysis - Helper template for registering a target 983 /// instruction analyzer implementation. This invokes the static "Create" 984 /// method on the class to actually do the construction. Usage: 985 /// 986 /// extern "C" void LLVMInitializeFooTarget() { 987 /// extern Target TheFooTarget; 988 /// RegisterMCInstrAnalysis<FooMCInstrAnalysis> X(TheFooTarget); 989 /// } 990 template<class MCInstrAnalysisImpl> 991 struct RegisterMCInstrAnalysis { RegisterMCInstrAnalysisRegisterMCInstrAnalysis992 RegisterMCInstrAnalysis(Target &T) { 993 TargetRegistry::RegisterMCInstrAnalysis(T, &Allocator); 994 } 995 private: AllocatorRegisterMCInstrAnalysis996 static MCInstrAnalysis *Allocator(const MCInstrInfo *Info) { 997 return new MCInstrAnalysisImpl(Info); 998 } 999 }; 1000 1001 /// RegisterMCInstrAnalysisFn - Helper template for registering a target 1002 /// instruction analyzer implementation. This invokes the specified function 1003 /// to do the construction. Usage: 1004 /// 1005 /// extern "C" void LLVMInitializeFooTarget() { 1006 /// extern Target TheFooTarget; 1007 /// RegisterMCInstrAnalysisFn X(TheFooTarget, TheFunction); 1008 /// } 1009 struct RegisterMCInstrAnalysisFn { RegisterMCInstrAnalysisFnRegisterMCInstrAnalysisFn1010 RegisterMCInstrAnalysisFn(Target &T, Target::MCInstrAnalysisCtorFnTy Fn) { 1011 TargetRegistry::RegisterMCInstrAnalysis(T, Fn); 1012 } 1013 }; 1014 1015 /// RegisterMCRegInfo - Helper template for registering a target register info 1016 /// implementation. This invokes the static "Create" method on the class to 1017 /// actually do the construction. Usage: 1018 /// 1019 /// extern "C" void LLVMInitializeFooTarget() { 1020 /// extern Target TheFooTarget; 1021 /// RegisterMCRegInfo<FooMCRegInfo> X(TheFooTarget); 1022 /// } 1023 template<class MCRegisterInfoImpl> 1024 struct RegisterMCRegInfo { RegisterMCRegInfoRegisterMCRegInfo1025 RegisterMCRegInfo(Target &T) { 1026 TargetRegistry::RegisterMCRegInfo(T, &Allocator); 1027 } 1028 private: AllocatorRegisterMCRegInfo1029 static MCRegisterInfo *Allocator(StringRef /*TT*/) { 1030 return new MCRegisterInfoImpl(); 1031 } 1032 }; 1033 1034 /// RegisterMCRegInfoFn - Helper template for registering a target register 1035 /// info implementation. This invokes the specified function to do the 1036 /// construction. Usage: 1037 /// 1038 /// extern "C" void LLVMInitializeFooTarget() { 1039 /// extern Target TheFooTarget; 1040 /// RegisterMCRegInfoFn X(TheFooTarget, TheFunction); 1041 /// } 1042 struct RegisterMCRegInfoFn { RegisterMCRegInfoFnRegisterMCRegInfoFn1043 RegisterMCRegInfoFn(Target &T, Target::MCRegInfoCtorFnTy Fn) { 1044 TargetRegistry::RegisterMCRegInfo(T, Fn); 1045 } 1046 }; 1047 1048 /// RegisterMCSubtargetInfo - Helper template for registering a target 1049 /// subtarget info implementation. This invokes the static "Create" method 1050 /// on the class to actually do the construction. Usage: 1051 /// 1052 /// extern "C" void LLVMInitializeFooTarget() { 1053 /// extern Target TheFooTarget; 1054 /// RegisterMCSubtargetInfo<FooMCSubtargetInfo> X(TheFooTarget); 1055 /// } 1056 template<class MCSubtargetInfoImpl> 1057 struct RegisterMCSubtargetInfo { RegisterMCSubtargetInfoRegisterMCSubtargetInfo1058 RegisterMCSubtargetInfo(Target &T) { 1059 TargetRegistry::RegisterMCSubtargetInfo(T, &Allocator); 1060 } 1061 private: AllocatorRegisterMCSubtargetInfo1062 static MCSubtargetInfo *Allocator(StringRef /*TT*/, StringRef /*CPU*/, 1063 StringRef /*FS*/) { 1064 return new MCSubtargetInfoImpl(); 1065 } 1066 }; 1067 1068 /// RegisterMCSubtargetInfoFn - Helper template for registering a target 1069 /// subtarget info implementation. This invokes the specified function to 1070 /// do the construction. Usage: 1071 /// 1072 /// extern "C" void LLVMInitializeFooTarget() { 1073 /// extern Target TheFooTarget; 1074 /// RegisterMCSubtargetInfoFn X(TheFooTarget, TheFunction); 1075 /// } 1076 struct RegisterMCSubtargetInfoFn { RegisterMCSubtargetInfoFnRegisterMCSubtargetInfoFn1077 RegisterMCSubtargetInfoFn(Target &T, Target::MCSubtargetInfoCtorFnTy Fn) { 1078 TargetRegistry::RegisterMCSubtargetInfo(T, Fn); 1079 } 1080 }; 1081 1082 /// RegisterTargetMachine - Helper template for registering a target machine 1083 /// implementation, for use in the target machine initialization 1084 /// function. Usage: 1085 /// 1086 /// extern "C" void LLVMInitializeFooTarget() { 1087 /// extern Target TheFooTarget; 1088 /// RegisterTargetMachine<FooTargetMachine> X(TheFooTarget); 1089 /// } 1090 template<class TargetMachineImpl> 1091 struct RegisterTargetMachine { RegisterTargetMachineRegisterTargetMachine1092 RegisterTargetMachine(Target &T) { 1093 TargetRegistry::RegisterTargetMachine(T, &Allocator); 1094 } 1095 1096 private: AllocatorRegisterTargetMachine1097 static TargetMachine *Allocator(const Target &T, StringRef TT, 1098 StringRef CPU, StringRef FS, 1099 const TargetOptions &Options, 1100 Reloc::Model RM, 1101 CodeModel::Model CM, 1102 CodeGenOpt::Level OL) { 1103 return new TargetMachineImpl(T, TT, CPU, FS, Options, RM, CM, OL); 1104 } 1105 }; 1106 1107 /// RegisterMCAsmBackend - Helper template for registering a target specific 1108 /// assembler backend. Usage: 1109 /// 1110 /// extern "C" void LLVMInitializeFooMCAsmBackend() { 1111 /// extern Target TheFooTarget; 1112 /// RegisterMCAsmBackend<FooAsmLexer> X(TheFooTarget); 1113 /// } 1114 template<class MCAsmBackendImpl> 1115 struct RegisterMCAsmBackend { RegisterMCAsmBackendRegisterMCAsmBackend1116 RegisterMCAsmBackend(Target &T) { 1117 TargetRegistry::RegisterMCAsmBackend(T, &Allocator); 1118 } 1119 1120 private: AllocatorRegisterMCAsmBackend1121 static MCAsmBackend *Allocator(const Target &T, StringRef Triple, 1122 StringRef CPU) { 1123 return new MCAsmBackendImpl(T, Triple, CPU); 1124 } 1125 }; 1126 1127 /// RegisterMCAsmParser - Helper template for registering a target specific 1128 /// assembly parser, for use in the target machine initialization 1129 /// function. Usage: 1130 /// 1131 /// extern "C" void LLVMInitializeFooMCAsmParser() { 1132 /// extern Target TheFooTarget; 1133 /// RegisterMCAsmParser<FooAsmParser> X(TheFooTarget); 1134 /// } 1135 template<class MCAsmParserImpl> 1136 struct RegisterMCAsmParser { RegisterMCAsmParserRegisterMCAsmParser1137 RegisterMCAsmParser(Target &T) { 1138 TargetRegistry::RegisterMCAsmParser(T, &Allocator); 1139 } 1140 1141 private: AllocatorRegisterMCAsmParser1142 static MCTargetAsmParser *Allocator(MCSubtargetInfo &STI, MCAsmParser &P) { 1143 return new MCAsmParserImpl(STI, P); 1144 } 1145 }; 1146 1147 /// RegisterAsmPrinter - Helper template for registering a target specific 1148 /// assembly printer, for use in the target machine initialization 1149 /// function. Usage: 1150 /// 1151 /// extern "C" void LLVMInitializeFooAsmPrinter() { 1152 /// extern Target TheFooTarget; 1153 /// RegisterAsmPrinter<FooAsmPrinter> X(TheFooTarget); 1154 /// } 1155 template<class AsmPrinterImpl> 1156 struct RegisterAsmPrinter { RegisterAsmPrinterRegisterAsmPrinter1157 RegisterAsmPrinter(Target &T) { 1158 TargetRegistry::RegisterAsmPrinter(T, &Allocator); 1159 } 1160 1161 private: AllocatorRegisterAsmPrinter1162 static AsmPrinter *Allocator(TargetMachine &TM, MCStreamer &Streamer) { 1163 return new AsmPrinterImpl(TM, Streamer); 1164 } 1165 }; 1166 1167 /// RegisterMCCodeEmitter - Helper template for registering a target specific 1168 /// machine code emitter, for use in the target initialization 1169 /// function. Usage: 1170 /// 1171 /// extern "C" void LLVMInitializeFooMCCodeEmitter() { 1172 /// extern Target TheFooTarget; 1173 /// RegisterMCCodeEmitter<FooCodeEmitter> X(TheFooTarget); 1174 /// } 1175 template<class MCCodeEmitterImpl> 1176 struct RegisterMCCodeEmitter { RegisterMCCodeEmitterRegisterMCCodeEmitter1177 RegisterMCCodeEmitter(Target &T) { 1178 TargetRegistry::RegisterMCCodeEmitter(T, &Allocator); 1179 } 1180 1181 private: AllocatorRegisterMCCodeEmitter1182 static MCCodeEmitter *Allocator(const MCInstrInfo &/*II*/, 1183 const MCRegisterInfo &/*MRI*/, 1184 const MCSubtargetInfo &/*STI*/, 1185 MCContext &/*Ctx*/) { 1186 return new MCCodeEmitterImpl(); 1187 } 1188 }; 1189 1190 } 1191 1192 #endif 1193