|
29 | 29 | using namespace llvm; |
30 | 30 |
|
31 | 31 | LoongArchAsmBackend::LoongArchAsmBackend(const MCSubtargetInfo &STI, |
32 | | - uint8_t OSABI, bool Is64Bit, |
| 32 | + bool Is64Bit, |
33 | 33 | const MCTargetOptions &Options) |
34 | | - : MCAsmBackend(llvm::endianness::little), STI(STI), OSABI(OSABI), |
35 | | - Is64Bit(Is64Bit), TargetOptions(Options) {} |
| 34 | + : MCAsmBackend(llvm::endianness::little), STI(STI), TargetOptions(Options), |
| 35 | + Is64Bit(Is64Bit) {} |
36 | 36 |
|
37 | 37 | std::optional<MCFixupKind> |
38 | 38 | LoongArchAsmBackend::getFixupKind(StringRef Name) const { |
@@ -484,16 +484,46 @@ bool LoongArchAsmBackend::addReloc(const MCFragment &F, const MCFixup &Fixup, |
484 | 484 | return true; |
485 | 485 | } |
486 | 486 |
|
487 | | -std::unique_ptr<MCObjectTargetWriter> |
488 | | -LoongArchAsmBackend::createObjectTargetWriter() const { |
489 | | - return createLoongArchELFObjectWriter(OSABI, Is64Bit); |
490 | | -} |
| 487 | +namespace { |
| 488 | +class ELFLoongArchAsmBackend : public LoongArchAsmBackend { |
| 489 | + uint8_t OSABI; |
| 490 | + |
| 491 | +public: |
| 492 | + ELFLoongArchAsmBackend(const MCSubtargetInfo &STI, uint8_t OSABI, |
| 493 | + bool Is64Bit, const MCTargetOptions &Options) |
| 494 | + : LoongArchAsmBackend(STI, Is64Bit, Options), OSABI(OSABI) {} |
| 495 | + |
| 496 | + std::unique_ptr<MCObjectTargetWriter> |
| 497 | + createObjectTargetWriter() const override { |
| 498 | + return createLoongArchELFObjectWriter(OSABI, Is64Bit); |
| 499 | + } |
| 500 | +}; |
| 501 | +} // namespace |
| 502 | + |
| 503 | +namespace { |
| 504 | +class COFFLoongArchAsmBackend : public LoongArchAsmBackend { |
| 505 | +public: |
| 506 | + COFFLoongArchAsmBackend(const MCSubtargetInfo &STI, bool Is64Bit, |
| 507 | + const MCTargetOptions &Options) |
| 508 | + : LoongArchAsmBackend(STI, Is64Bit, Options) {} |
| 509 | + |
| 510 | + std::unique_ptr<MCObjectTargetWriter> |
| 511 | + createObjectTargetWriter() const override { |
| 512 | + return createLoongArchWinCOFFObjectWriter(Is64Bit); |
| 513 | + } |
| 514 | +}; |
| 515 | +} // namespace |
491 | 516 |
|
492 | 517 | MCAsmBackend *llvm::createLoongArchAsmBackend(const Target &T, |
493 | 518 | const MCSubtargetInfo &STI, |
494 | 519 | const MCRegisterInfo &MRI, |
495 | 520 | const MCTargetOptions &Options) { |
496 | 521 | const Triple &TT = STI.getTargetTriple(); |
| 522 | + if (TT.isOSBinFormatCOFF()) |
| 523 | + return new COFFLoongArchAsmBackend(STI, TT.isArch64Bit(), Options); |
| 524 | + |
| 525 | + assert(TT.isOSBinFormatELF() && "Invalid target"); |
| 526 | + |
497 | 527 | uint8_t OSABI = MCELFObjectTargetWriter::getOSABI(TT.getOS()); |
498 | | - return new LoongArchAsmBackend(STI, OSABI, TT.isArch64Bit(), Options); |
| 528 | + return new ELFLoongArchAsmBackend(STI, OSABI, TT.isArch64Bit(), Options); |
499 | 529 | } |
0 commit comments