1*9880d681SAndroid Build Coastguard Worker //===-- LanaiELFObjectWriter.cpp - Lanai ELF Writer -----------------------===//
2*9880d681SAndroid Build Coastguard Worker //
3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker //
5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker //
8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker #include "MCTargetDesc/LanaiBaseInfo.h"
11*9880d681SAndroid Build Coastguard Worker #include "MCTargetDesc/LanaiFixupKinds.h"
12*9880d681SAndroid Build Coastguard Worker #include "MCTargetDesc/LanaiMCTargetDesc.h"
13*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCELFObjectWriter.h"
14*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCSymbol.h"
15*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/ErrorHandling.h"
16*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/raw_ostream.h"
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Worker using namespace llvm;
19*9880d681SAndroid Build Coastguard Worker
20*9880d681SAndroid Build Coastguard Worker namespace {
21*9880d681SAndroid Build Coastguard Worker class LanaiELFObjectWriter : public MCELFObjectTargetWriter {
22*9880d681SAndroid Build Coastguard Worker public:
23*9880d681SAndroid Build Coastguard Worker explicit LanaiELFObjectWriter(uint8_t OSABI);
24*9880d681SAndroid Build Coastguard Worker
25*9880d681SAndroid Build Coastguard Worker ~LanaiELFObjectWriter() override;
26*9880d681SAndroid Build Coastguard Worker
27*9880d681SAndroid Build Coastguard Worker protected:
28*9880d681SAndroid Build Coastguard Worker unsigned getRelocType(MCContext &Ctx, const MCValue &Target,
29*9880d681SAndroid Build Coastguard Worker const MCFixup &Fixup, bool IsPCRel) const override;
30*9880d681SAndroid Build Coastguard Worker bool needsRelocateWithSymbol(const MCSymbol &SD,
31*9880d681SAndroid Build Coastguard Worker unsigned Type) const override;
32*9880d681SAndroid Build Coastguard Worker };
33*9880d681SAndroid Build Coastguard Worker } // namespace
34*9880d681SAndroid Build Coastguard Worker
LanaiELFObjectWriter(uint8_t OSABI)35*9880d681SAndroid Build Coastguard Worker LanaiELFObjectWriter::LanaiELFObjectWriter(uint8_t OSABI)
36*9880d681SAndroid Build Coastguard Worker : MCELFObjectTargetWriter(/*Is64Bit=*/false, OSABI, ELF::EM_LANAI,
37*9880d681SAndroid Build Coastguard Worker /*HasRelocationAddend=*/true) {}
38*9880d681SAndroid Build Coastguard Worker
~LanaiELFObjectWriter()39*9880d681SAndroid Build Coastguard Worker LanaiELFObjectWriter::~LanaiELFObjectWriter() {}
40*9880d681SAndroid Build Coastguard Worker
getRelocType(MCContext & Ctx,const MCValue & Target,const MCFixup & Fixup,bool IsPCRel) const41*9880d681SAndroid Build Coastguard Worker unsigned LanaiELFObjectWriter::getRelocType(MCContext &Ctx,
42*9880d681SAndroid Build Coastguard Worker const MCValue &Target,
43*9880d681SAndroid Build Coastguard Worker const MCFixup &Fixup,
44*9880d681SAndroid Build Coastguard Worker bool IsPCRel) const {
45*9880d681SAndroid Build Coastguard Worker unsigned Type;
46*9880d681SAndroid Build Coastguard Worker unsigned Kind = static_cast<unsigned>(Fixup.getKind());
47*9880d681SAndroid Build Coastguard Worker switch (Kind) {
48*9880d681SAndroid Build Coastguard Worker case Lanai::FIXUP_LANAI_21:
49*9880d681SAndroid Build Coastguard Worker Type = ELF::R_LANAI_21;
50*9880d681SAndroid Build Coastguard Worker break;
51*9880d681SAndroid Build Coastguard Worker case Lanai::FIXUP_LANAI_21_F:
52*9880d681SAndroid Build Coastguard Worker Type = ELF::R_LANAI_21_F;
53*9880d681SAndroid Build Coastguard Worker break;
54*9880d681SAndroid Build Coastguard Worker case Lanai::FIXUP_LANAI_25:
55*9880d681SAndroid Build Coastguard Worker Type = ELF::R_LANAI_25;
56*9880d681SAndroid Build Coastguard Worker break;
57*9880d681SAndroid Build Coastguard Worker case Lanai::FIXUP_LANAI_32:
58*9880d681SAndroid Build Coastguard Worker case FK_Data_4:
59*9880d681SAndroid Build Coastguard Worker Type = ELF::R_LANAI_32;
60*9880d681SAndroid Build Coastguard Worker break;
61*9880d681SAndroid Build Coastguard Worker case Lanai::FIXUP_LANAI_HI16:
62*9880d681SAndroid Build Coastguard Worker Type = ELF::R_LANAI_HI16;
63*9880d681SAndroid Build Coastguard Worker break;
64*9880d681SAndroid Build Coastguard Worker case Lanai::FIXUP_LANAI_LO16:
65*9880d681SAndroid Build Coastguard Worker Type = ELF::R_LANAI_LO16;
66*9880d681SAndroid Build Coastguard Worker break;
67*9880d681SAndroid Build Coastguard Worker case Lanai::FIXUP_LANAI_NONE:
68*9880d681SAndroid Build Coastguard Worker Type = ELF::R_LANAI_NONE;
69*9880d681SAndroid Build Coastguard Worker break;
70*9880d681SAndroid Build Coastguard Worker
71*9880d681SAndroid Build Coastguard Worker default:
72*9880d681SAndroid Build Coastguard Worker llvm_unreachable("Invalid fixup kind!");
73*9880d681SAndroid Build Coastguard Worker }
74*9880d681SAndroid Build Coastguard Worker return Type;
75*9880d681SAndroid Build Coastguard Worker }
76*9880d681SAndroid Build Coastguard Worker
needsRelocateWithSymbol(const MCSymbol & SD,unsigned Type) const77*9880d681SAndroid Build Coastguard Worker bool LanaiELFObjectWriter::needsRelocateWithSymbol(const MCSymbol &SD,
78*9880d681SAndroid Build Coastguard Worker unsigned Type) const {
79*9880d681SAndroid Build Coastguard Worker switch (Type) {
80*9880d681SAndroid Build Coastguard Worker case ELF::R_LANAI_21:
81*9880d681SAndroid Build Coastguard Worker case ELF::R_LANAI_21_F:
82*9880d681SAndroid Build Coastguard Worker case ELF::R_LANAI_25:
83*9880d681SAndroid Build Coastguard Worker case ELF::R_LANAI_32:
84*9880d681SAndroid Build Coastguard Worker case ELF::R_LANAI_HI16:
85*9880d681SAndroid Build Coastguard Worker return true;
86*9880d681SAndroid Build Coastguard Worker default:
87*9880d681SAndroid Build Coastguard Worker return false;
88*9880d681SAndroid Build Coastguard Worker }
89*9880d681SAndroid Build Coastguard Worker }
90*9880d681SAndroid Build Coastguard Worker
createLanaiELFObjectWriter(raw_pwrite_stream & OS,uint8_t OSABI)91*9880d681SAndroid Build Coastguard Worker MCObjectWriter *llvm::createLanaiELFObjectWriter(raw_pwrite_stream &OS,
92*9880d681SAndroid Build Coastguard Worker uint8_t OSABI) {
93*9880d681SAndroid Build Coastguard Worker MCELFObjectTargetWriter *MOTW = new LanaiELFObjectWriter(OSABI);
94*9880d681SAndroid Build Coastguard Worker return createELFObjectWriter(MOTW, OS, /*IsLittleEndian=*/false);
95*9880d681SAndroid Build Coastguard Worker }
96