181ad6265SDimitry Andric //===-- LoongArchELFObjectWriter.cpp - LoongArch ELF Writer ---*- C++ -*---===// 281ad6265SDimitry Andric // 381ad6265SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 481ad6265SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 581ad6265SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 681ad6265SDimitry Andric // 781ad6265SDimitry Andric //===----------------------------------------------------------------------===// 881ad6265SDimitry Andric 981ad6265SDimitry Andric #include "MCTargetDesc/LoongArchMCTargetDesc.h" 1081ad6265SDimitry Andric #include "llvm/MC/MCContext.h" 1181ad6265SDimitry Andric #include "llvm/MC/MCELFObjectWriter.h" 1281ad6265SDimitry Andric #include "llvm/MC/MCFixup.h" 1381ad6265SDimitry Andric #include "llvm/MC/MCObjectWriter.h" 1481ad6265SDimitry Andric #include "llvm/Support/ErrorHandling.h" 1581ad6265SDimitry Andric 1681ad6265SDimitry Andric using namespace llvm; 1781ad6265SDimitry Andric 1881ad6265SDimitry Andric namespace { 1981ad6265SDimitry Andric class LoongArchELFObjectWriter : public MCELFObjectTargetWriter { 2081ad6265SDimitry Andric public: 2181ad6265SDimitry Andric LoongArchELFObjectWriter(uint8_t OSABI, bool Is64Bit); 2281ad6265SDimitry Andric 2381ad6265SDimitry Andric ~LoongArchELFObjectWriter() override; 2481ad6265SDimitry Andric 2581ad6265SDimitry Andric // Return true if the given relocation must be with a symbol rather than 2681ad6265SDimitry Andric // section plus offset. 2781ad6265SDimitry Andric bool needsRelocateWithSymbol(const MCSymbol &Sym, 2881ad6265SDimitry Andric unsigned Type) const override { 2981ad6265SDimitry Andric return true; 3081ad6265SDimitry Andric } 3181ad6265SDimitry Andric 3281ad6265SDimitry Andric protected: 3381ad6265SDimitry Andric unsigned getRelocType(MCContext &Ctx, const MCValue &Target, 3481ad6265SDimitry Andric const MCFixup &Fixup, bool IsPCRel) const override; 3581ad6265SDimitry Andric }; 36*972a253aSDimitry Andric } // end namespace 3781ad6265SDimitry Andric 3881ad6265SDimitry Andric LoongArchELFObjectWriter::LoongArchELFObjectWriter(uint8_t OSABI, bool Is64Bit) 3981ad6265SDimitry Andric : MCELFObjectTargetWriter(Is64Bit, OSABI, ELF::EM_LOONGARCH, 4081ad6265SDimitry Andric /*HasRelocationAddend*/ true) {} 4181ad6265SDimitry Andric 4281ad6265SDimitry Andric LoongArchELFObjectWriter::~LoongArchELFObjectWriter() {} 4381ad6265SDimitry Andric 4481ad6265SDimitry Andric unsigned LoongArchELFObjectWriter::getRelocType(MCContext &Ctx, 4581ad6265SDimitry Andric const MCValue &Target, 4681ad6265SDimitry Andric const MCFixup &Fixup, 4781ad6265SDimitry Andric bool IsPCRel) const { 4881ad6265SDimitry Andric // Determine the type of the relocation 4981ad6265SDimitry Andric unsigned Kind = Fixup.getTargetKind(); 5081ad6265SDimitry Andric 5181ad6265SDimitry Andric if (Kind >= FirstLiteralRelocationKind) 5281ad6265SDimitry Andric return Kind - FirstLiteralRelocationKind; 5381ad6265SDimitry Andric 5481ad6265SDimitry Andric switch (Kind) { 5581ad6265SDimitry Andric // TODO: Implement this when we defined fixup kind. 5681ad6265SDimitry Andric default: 5781ad6265SDimitry Andric return ELF::R_LARCH_NONE; 5881ad6265SDimitry Andric } 5981ad6265SDimitry Andric } 6081ad6265SDimitry Andric 6181ad6265SDimitry Andric std::unique_ptr<MCObjectTargetWriter> 6281ad6265SDimitry Andric llvm::createLoongArchELFObjectWriter(uint8_t OSABI, bool Is64Bit) { 6381ad6265SDimitry Andric return std::make_unique<LoongArchELFObjectWriter>(OSABI, Is64Bit); 6481ad6265SDimitry Andric } 65