1 //===-- M68kELFObjectWriter.cpp - M68k ELF Writer ---------------*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
10 /// This file contains definitions for M68k ELF Writers
12 //===----------------------------------------------------------------------===//
14 #include "MCTargetDesc/M68kFixupKinds.h"
15 #include "MCTargetDesc/M68kMCTargetDesc.h"
17 #include "llvm/BinaryFormat/ELF.h"
18 #include "llvm/MC/MCAsmInfo.h"
19 #include "llvm/MC/MCContext.h"
20 #include "llvm/MC/MCELFObjectWriter.h"
21 #include "llvm/MC/MCExpr.h"
22 #include "llvm/MC/MCValue.h"
23 #include "llvm/Support/ErrorHandling.h"
28 class M68kELFObjectWriter
: public MCELFObjectTargetWriter
{
30 M68kELFObjectWriter(uint8_t OSABI
);
32 ~M68kELFObjectWriter() override
;
35 unsigned getRelocType(MCContext
&Ctx
, const MCValue
&Target
,
36 const MCFixup
&Fixup
, bool IsPCRel
) const override
;
40 M68kELFObjectWriter::M68kELFObjectWriter(uint8_t OSABI
)
41 : MCELFObjectTargetWriter(false, OSABI
, ELF::EM_68K
, /* RELA */ true) {}
43 M68kELFObjectWriter::~M68kELFObjectWriter() {}
45 enum M68kRelType
{ RT_32
, RT_16
, RT_8
};
48 getType(unsigned Kind
, MCSymbolRefExpr::VariantKind
&Modifier
, bool &IsPCRel
) {
60 llvm_unreachable("Unimplemented");
63 unsigned M68kELFObjectWriter::getRelocType(MCContext
&Ctx
,
64 const MCValue
&Target
,
67 MCSymbolRefExpr::VariantKind Modifier
= Target
.getAccessVariant();
68 unsigned Kind
= Fixup
.getKind();
69 M68kRelType Type
= getType(Kind
, Modifier
, IsPCRel
);
72 llvm_unreachable("Unimplemented");
74 case MCSymbolRefExpr::VK_TLSGD
:
77 return ELF::R_68K_TLS_GD32
;
79 return ELF::R_68K_TLS_GD16
;
81 return ELF::R_68K_TLS_GD8
;
83 llvm_unreachable("Unrecognized size");
84 case MCSymbolRefExpr::VK_TLSLDM
:
87 return ELF::R_68K_TLS_LDM32
;
89 return ELF::R_68K_TLS_LDM16
;
91 return ELF::R_68K_TLS_LDM8
;
93 llvm_unreachable("Unrecognized size");
94 case MCSymbolRefExpr::VK_TLSLD
:
97 return ELF::R_68K_TLS_LDO32
;
99 return ELF::R_68K_TLS_LDO16
;
101 return ELF::R_68K_TLS_LDO8
;
103 llvm_unreachable("Unrecognized size");
104 case MCSymbolRefExpr::VK_GOTTPOFF
:
107 return ELF::R_68K_TLS_IE32
;
109 return ELF::R_68K_TLS_IE16
;
111 return ELF::R_68K_TLS_IE8
;
113 llvm_unreachable("Unrecognized size");
114 case MCSymbolRefExpr::VK_TPOFF
:
117 return ELF::R_68K_TLS_LE32
;
119 return ELF::R_68K_TLS_LE16
;
121 return ELF::R_68K_TLS_LE8
;
123 llvm_unreachable("Unrecognized size");
124 case MCSymbolRefExpr::VK_None
:
127 return IsPCRel
? ELF::R_68K_PC32
: ELF::R_68K_32
;
129 return IsPCRel
? ELF::R_68K_PC16
: ELF::R_68K_16
;
131 return IsPCRel
? ELF::R_68K_PC8
: ELF::R_68K_8
;
133 llvm_unreachable("Unrecognized size");
134 case MCSymbolRefExpr::VK_GOTPCREL
:
137 return ELF::R_68K_GOTPCREL32
;
139 return ELF::R_68K_GOTPCREL16
;
141 return ELF::R_68K_GOTPCREL8
;
143 llvm_unreachable("Unrecognized size");
144 case MCSymbolRefExpr::VK_GOTOFF
:
148 return ELF::R_68K_GOTOFF32
;
150 return ELF::R_68K_GOTOFF16
;
152 return ELF::R_68K_GOTOFF8
;
154 llvm_unreachable("Unrecognized size");
155 case MCSymbolRefExpr::VK_PLT
:
158 return ELF::R_68K_PLT32
;
160 return ELF::R_68K_PLT16
;
162 return ELF::R_68K_PLT8
;
164 llvm_unreachable("Unrecognized size");
168 std::unique_ptr
<MCObjectTargetWriter
>
169 llvm::createM68kELFObjectWriter(uint8_t OSABI
) {
170 return std::make_unique
<M68kELFObjectWriter
>(OSABI
);