1 //===- llvm/BinaryFormat/ELF.cpp - The ELF format ---------------*- 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 //===----------------------------------------------------------------------===//
9 #include "llvm/BinaryFormat/ELF.h"
10 #include "llvm/ADT/DenseMap.h"
11 #include "llvm/ADT/StringSwitch.h"
12 #include "llvm/Support/Error.h"
17 /// Convert an architecture name into ELF's e_machine value.
18 uint16_t ELF::convertArchNameToEMachine(StringRef Arch
) {
19 std::string LowerArch
= Arch
.lower();
20 return StringSwitch
<uint16_t>(LowerArch
)
21 .Case("none", EM_NONE
)
23 .Case("sparc", EM_SPARC
)
27 .Case("iamcu", EM_IAMCU
)
29 .Case("mips", EM_MIPS
)
30 .Case("s370", EM_S370
)
31 .Case("mips_rs3_le", EM_MIPS_RS3_LE
)
32 .Case("parisc", EM_PARISC
)
33 .Case("vpp500", EM_VPP500
)
34 .Case("sparc32plus", EM_SPARC32PLUS
)
37 .Case("ppc64", EM_PPC64
)
38 .Case("s390", EM_S390
)
40 .Case("v800", EM_V800
)
41 .Case("fr20", EM_FR20
)
42 .Case("rh32", EM_RH32
)
45 .Case("alpha", EM_ALPHA
)
47 .Case("sparcv9", EM_SPARCV9
)
48 .Case("tricore", EM_TRICORE
)
50 .Case("h8_300", EM_H8_300
)
51 .Case("h8_300h", EM_H8_300H
)
53 .Case("h8_500", EM_H8_500
)
54 .Case("ia_64", EM_IA_64
)
55 .Case("mips_x", EM_MIPS_X
)
56 .Case("coldfire", EM_COLDFIRE
)
57 .Case("68hc12", EM_68HC12
)
60 .Case("ncpu", EM_NCPU
)
61 .Case("ndr1", EM_NDR1
)
62 .Case("starcore", EM_STARCORE
)
63 .Case("me16", EM_ME16
)
64 .Case("st100", EM_ST100
)
65 .Case("tinyj", EM_TINYJ
)
66 .Case("x86_64", EM_X86_64
)
67 .Case("pdsp", EM_PDSP
)
68 .Case("pdp10", EM_PDP10
)
69 .Case("pdp11", EM_PDP11
)
70 .Case("fx66", EM_FX66
)
71 .Case("st9plus", EM_ST9PLUS
)
73 .Case("68hc16", EM_68HC16
)
74 .Case("68hc11", EM_68HC11
)
75 .Case("68hc08", EM_68HC08
)
76 .Case("68hc05", EM_68HC05
)
78 .Case("st19", EM_ST19
)
80 .Case("cris", EM_CRIS
)
81 .Case("javelin", EM_JAVELIN
)
82 .Case("firepath", EM_FIREPATH
)
84 .Case("mmix", EM_MMIX
)
85 .Case("huany", EM_HUANY
)
86 .Case("prism", EM_PRISM
)
88 .Case("fr30", EM_FR30
)
89 .Case("d10v", EM_D10V
)
90 .Case("d30v", EM_D30V
)
91 .Case("v850", EM_V850
)
92 .Case("m32r", EM_M32R
)
93 .Case("mn10300", EM_MN10300
)
94 .Case("mn10200", EM_MN10200
)
96 .Case("openrisc", EM_OPENRISC
)
97 .Case("arc_compact", EM_ARC_COMPACT
)
98 .Case("xtensa", EM_XTENSA
)
99 .Case("videocore", EM_VIDEOCORE
)
100 .Case("tmm_gpp", EM_TMM_GPP
)
101 .Case("ns32k", EM_NS32K
)
103 .Case("snp1k", EM_SNP1K
)
104 .Case("st200", EM_ST200
)
105 .Case("ip2k", EM_IP2K
)
108 .Case("f2mc16", EM_F2MC16
)
109 .Case("msp430", EM_MSP430
)
110 .Case("blackfin", EM_BLACKFIN
)
111 .Case("se_c33", EM_SE_C33
)
113 .Case("arca", EM_ARCA
)
114 .Case("unicore", EM_UNICORE
)
115 .Case("excess", EM_EXCESS
)
117 .Case("altera_nios2", EM_ALTERA_NIOS2
)
119 .Case("xgate", EM_XGATE
)
120 .Case("c166", EM_C166
)
121 .Case("m16c", EM_M16C
)
122 .Case("dspic30f", EM_DSPIC30F
)
124 .Case("m32c", EM_M32C
)
125 .Case("tsk3000", EM_TSK3000
)
126 .Case("rs08", EM_RS08
)
127 .Case("sharc", EM_SHARC
)
128 .Case("ecog2", EM_ECOG2
)
129 .Case("score7", EM_SCORE7
)
130 .Case("dsp24", EM_DSP24
)
131 .Case("videocore3", EM_VIDEOCORE3
)
132 .Case("latticemico32", EM_LATTICEMICO32
)
133 .Case("se_c17", EM_SE_C17
)
134 .Case("ti_c6000", EM_TI_C6000
)
135 .Case("ti_c2000", EM_TI_C2000
)
136 .Case("ti_c5500", EM_TI_C5500
)
137 .Case("mmdsp_plus", EM_MMDSP_PLUS
)
138 .Case("cypress_m8c", EM_CYPRESS_M8C
)
139 .Case("r32c", EM_R32C
)
140 .Case("trimedia", EM_TRIMEDIA
)
141 .Case("hexagon", EM_HEXAGON
)
142 .Case("8051", EM_8051
)
143 .Case("stxp7x", EM_STXP7X
)
144 .Case("nds32", EM_NDS32
)
145 .Case("ecog1", EM_ECOG1
)
146 .Case("ecog1x", EM_ECOG1X
)
147 .Case("maxq30", EM_MAXQ30
)
148 .Case("ximo16", EM_XIMO16
)
149 .Case("manik", EM_MANIK
)
150 .Case("craynv2", EM_CRAYNV2
)
152 .Case("metag", EM_METAG
)
153 .Case("mcst_elbrus", EM_MCST_ELBRUS
)
154 .Case("ecog16", EM_ECOG16
)
155 .Case("cr16", EM_CR16
)
156 .Case("etpu", EM_ETPU
)
157 .Case("sle9x", EM_SLE9X
)
158 .Case("l10m", EM_L10M
)
159 .Case("k10m", EM_K10M
)
160 .Case("aarch64", EM_AARCH64
)
161 .Case("avr32", EM_AVR32
)
162 .Case("stm8", EM_STM8
)
163 .Case("tile64", EM_TILE64
)
164 .Case("tilepro", EM_TILEPRO
)
165 .Case("cuda", EM_CUDA
)
166 .Case("tilegx", EM_TILEGX
)
167 .Case("cloudshield", EM_CLOUDSHIELD
)
168 .Case("corea_1st", EM_COREA_1ST
)
169 .Case("corea_2nd", EM_COREA_2ND
)
170 .Case("arc_compact2", EM_ARC_COMPACT2
)
171 .Case("open8", EM_OPEN8
)
172 .Case("rl78", EM_RL78
)
173 .Case("videocore5", EM_VIDEOCORE5
)
174 .Case("78kor", EM_78KOR
)
175 .Case("56800ex", EM_56800EX
)
178 .Case("xcore", EM_XCORE
)
179 .Case("mchp_pic", EM_MCHP_PIC
)
180 .Case("intel205", EM_INTEL205
)
181 .Case("intel206", EM_INTEL206
)
182 .Case("intel207", EM_INTEL207
)
183 .Case("intel208", EM_INTEL208
)
184 .Case("intel209", EM_INTEL209
)
185 .Case("km32", EM_KM32
)
186 .Case("kmx32", EM_KMX32
)
187 .Case("kmx16", EM_KMX16
)
188 .Case("kmx8", EM_KMX8
)
189 .Case("kvarc", EM_KVARC
)
191 .Case("coge", EM_COGE
)
192 .Case("cool", EM_COOL
)
193 .Case("norc", EM_NORC
)
194 .Case("csr_kalimba", EM_CSR_KALIMBA
)
195 .Case("amdgpu", EM_AMDGPU
)
196 .Case("riscv", EM_RISCV
)
197 .Case("lanai", EM_LANAI
)
200 .Case("csky", EM_CSKY
)
204 /// Convert an ELF's e_machine value into an architecture name.
205 StringRef
ELF::convertEMachineToArchName(uint16_t EMachine
) {
228 return "mips_rs3_le";
234 return "sparc32plus";
360 return "arc_compact";
399 case EM_ALTERA_NIOS2
:
400 return "altera_nios2";
429 case EM_LATTICEMICO32
:
430 return "latticemico32";
442 return "cypress_m8c";
470 return "mcst_elbrus";
498 return "cloudshield";
503 case EM_ARC_COMPACT2
:
504 return "arc_compact2";
552 return "csr_kalimba";