summaryrefslogtreecommitdiffstats
path: root/third_party/rust/goblin/src/elf/constants_header.rs
blob: 9b19c84c2c246723b52317165f32740a903a070b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
// sweet emacs regexp
// pub const \([[:word:]|_]*\)[[:space:]]*\([[:digit:]]+\)[[:space:]]*/\*\(.*\) \*/
// \\\\3 C-q C-j pub const \1: u32 = \2;

/// TODO: use Enum with explicit discriminant and get debug printer for free?

/// No machine
pub const EM_NONE: u16 = 0;
/// AT&T WE 32100
pub const EM_M32: u16 = 1;
/// SUN SPARC
pub const EM_SPARC: u16 = 2;
/// Intel 80386
pub const EM_386: u16 = 3;
/// Motorola m68k family
pub const EM_68K: u16 = 4;
/// Motorola m88k family
pub const EM_88K: u16 = 5;
/// Intel MCU
pub const EM_IAMCU: u16 = 6;
/// Intel 80860
pub const EM_860: u16 = 7;
/// MIPS R3000 big-endian
pub const EM_MIPS: u16 = 8;
/// IBM System/370
pub const EM_S370: u16 = 9;
/// MIPS R3000 little-endian
pub const EM_MIPS_RS3_LE: u16 = 10;
// reserved 11-14
/// HPPA
pub const EM_PARISC: u16 = 15;
// reserved 16
/// Fujitsu VPP500
pub const EM_VPP500: u16 = 17;
/// Sun's "v8plus"
pub const EM_SPARC32PLUS: u16 = 18;
/// Intel 80960
pub const EM_960: u16 = 19;
/// PowerPC
pub const EM_PPC: u16 = 20;
/// PowerPC 64-bit
pub const EM_PPC64: u16 = 21;
/// IBM S390
pub const EM_S390: u16 = 22;
/// IBM SPU/SPC
pub const EM_SPU: u16 = 23;
// reserved 24-35
/// NEC V800 series
pub const EM_V800: u16 = 36;
/// Fujitsu FR20
pub const EM_FR20: u16 = 37;
/// TRW RH-32
pub const EM_RH32: u16 = 38;
/// Motorola RCE
pub const EM_RCE: u16 = 39;
/// ARM
pub const EM_ARM: u16 = 40;
/// Digital Alpha
pub const EM_FAKE_ALPHA: u16 = 41;
/// Hitachi SH
pub const EM_SH: u16 = 42;
/// SPARC v9 64-bit
pub const EM_SPARCV9: u16 = 43;
/// Siemens Tricore
pub const EM_TRICORE: u16 = 44;
/// Argonaut RISC Core
pub const EM_ARC: u16 = 45;
/// Hitachi H8/300
pub const EM_H8_300: u16 = 46;
/// Hitachi H8/300H
pub const EM_H8_300H: u16 = 47;
/// Hitachi H8S
pub const EM_H8S: u16 = 48;
/// Hitachi H8/500
pub const EM_H8_500: u16 = 49;
/// Intel Merced
pub const EM_IA_64: u16 = 50;
/// Stanford MIPS-X
pub const EM_MIPS_X: u16 = 51;
/// Motorola Coldfire
pub const EM_COLDFIRE: u16 = 52;
/// Motorola M68HC12
pub const EM_68HC12: u16 = 53;
/// Fujitsu MMA Multimedia Accelerator
pub const EM_MMA: u16 = 54;
/// Siemens PCP
pub const EM_PCP: u16 = 55;
/// Sony nCPU embeeded RISC
pub const EM_NCPU: u16 = 56;
/// Denso NDR1 microprocessor
pub const EM_NDR1: u16 = 57;
/// Motorola Start*Core processor
pub const EM_STARCORE: u16 = 58;
/// Toyota ME16 processor
pub const EM_ME16: u16 = 59;
/// STMicroelectronic ST100 processor
pub const EM_ST100: u16 = 60;
/// Advanced Logic Corp. Tinyj emb.fam
pub const EM_TINYJ: u16 = 61;
/// AMD x86-64 architecture
pub const EM_X86_64: u16 = 62;
/// Sony DSP Processor
pub const EM_PDSP: u16 = 63;
/// Digital PDP-10
pub const EM_PDP10: u16 = 64;
/// Digital PDP-11
pub const EM_PDP11: u16 = 65;
/// Siemens FX66 microcontroller
pub const EM_FX66: u16 = 66;
/// STMicroelectronics ST9+ 8/16 mc
pub const EM_ST9PLUS: u16 = 67;
/// STmicroelectronics ST7 8 bit mc
pub const EM_ST7: u16 = 68;
/// Motorola MC68HC16 microcontroller
pub const EM_68HC16: u16 = 69;
/// Motorola MC68HC11 microcontroller
pub const EM_68HC11: u16 = 70;
/// Motorola MC68HC08 microcontroller
pub const EM_68HC08: u16 = 71;
/// Motorola MC68HC05 microcontroller
pub const EM_68HC05: u16 = 72;
/// Silicon Graphics SVx
pub const EM_SVX: u16 = 73;
/// STMicroelectronics ST19 8 bit mc
pub const EM_ST19: u16 = 74;
/// Digital VAX
pub const EM_VAX: u16 = 75;
/// Axis Communications 32-bit emb.proc
pub const EM_CRIS: u16 = 76;
/// Infineon Technologies 32-bit emb.proc
pub const EM_JAVELIN: u16 = 77;
/// Element 14 64-bit DSP Processor
pub const EM_FIREPATH: u16 = 78;
/// LSI Logic 16-bit DSP Processor
pub const EM_ZSP: u16 = 79;
/// Donald Knuth's educational 64-bit proc
pub const EM_MMIX: u16 = 80;
/// Harvard University machine-independent object files
pub const EM_HUANY: u16 = 81;
/// SiTera Prism
pub const EM_PRISM: u16 = 82;
/// Atmel AVR 8-bit microcontroller
pub const EM_AVR: u16 = 83;
/// Fujitsu FR30
pub const EM_FR30: u16 = 84;
/// Mitsubishi D10V
pub const EM_D10V: u16 = 85;
/// Mitsubishi D30V
pub const EM_D30V: u16 = 86;
/// NEC v850
pub const EM_V850: u16 = 87;
/// Mitsubishi M32R
pub const EM_M32R: u16 = 88;
/// Matsushita MN10300
pub const EM_MN10300: u16 = 89;
/// Matsushita MN10200
pub const EM_MN10200: u16 = 90;
/// picoJava
pub const EM_PJ: u16 = 91;
/// OpenRISC 32-bit embedded processor
pub const EM_OPENRISC: u16 = 92;
/// ARC International ARCompact
pub const EM_ARC_COMPACT: u16 = 93;
/// Tensilica Xtensa Architecture
pub const EM_XTENSA: u16 = 94;
/// Alphamosaic VideoCore
pub const EM_VIDEOCORE: u16 = 95;
/// Thompson Multimedia General Purpose Proc
pub const EM_TMM_GPP: u16 = 96;
/// National Semi. 32000
pub const EM_NS32K: u16 = 97;
/// Tenor Network TPC
pub const EM_TPC: u16 = 98;
/// Trebia SNP 1000
pub const EM_SNP1K: u16 = 99;
/// STMicroelectronics ST200
pub const EM_ST200: u16 = 100;
/// Ubicom IP2xxx
pub const EM_IP2K: u16 = 101;
/// MAX processor
pub const EM_MAX: u16 = 102;
/// National Semi. CompactRISC
pub const EM_CR: u16 = 103;
/// Fujitsu F2MC16
pub const EM_F2MC16: u16 = 104;
/// Texas Instruments msp430
pub const EM_MSP430: u16 = 105;
/// Analog Devices Blackfin DSP
pub const EM_BLACKFIN: u16 = 106;
/// Seiko Epson S1C33 family
pub const EM_SE_C33: u16 = 107;
/// Sharp embedded microprocessor
pub const EM_SEP: u16 = 108;
/// Arca RISC
pub const EM_ARCA: u16 = 109;
/// PKU-Unity & MPRC Peking Uni. mc series
pub const EM_UNICORE: u16 = 110;
/// eXcess configurable cpu
pub const EM_EXCESS: u16 = 111;
/// Icera Semi. Deep Execution Processor
pub const EM_DXP: u16 = 112;
/// Altera Nios II
pub const EM_ALTERA_NIOS2: u16 = 113;
/// National Semi. CompactRISC CRX
pub const EM_CRX: u16 = 114;
/// Motorola XGATE
pub const EM_XGATE: u16 = 115;
/// Infineon C16x/XC16x
pub const EM_C166: u16 = 116;
/// Renesas M16C
pub const EM_M16C: u16 = 117;
/// Microchip Technology dsPIC30F
pub const EM_DSPIC30F: u16 = 118;
/// Freescale Communication Engine RISC
pub const EM_CE: u16 = 119;
/// Renesas M32C
pub const EM_M32C: u16 = 120;
// reserved 121-130
/// Altium TSK3000
pub const EM_TSK3000: u16 = 131;
/// Freescale RS08
pub const EM_RS08: u16 = 132;
/// Analog Devices SHARC family
pub const EM_SHARC: u16 = 133;
/// Cyan Technology eCOG2
pub const EM_ECOG2: u16 = 134;
/// Sunplus S+core7 RISC
pub const EM_SCORE7: u16 = 135;
/// New Japan Radio (NJR) 24-bit DSP
pub const EM_DSP24: u16 = 136;
/// Broadcom VideoCore III
pub const EM_VIDEOCORE3: u16 = 137;
/// RISC for Lattice FPGA
pub const EM_LATTICEMICO32: u16 = 138;
/// Seiko Epson C17
pub const EM_SE_C17: u16 = 139;
/// Texas Instruments TMS320C6000 DSP
pub const EM_TI_C6000: u16 = 140;
/// Texas Instruments TMS320C2000 DSP
pub const EM_TI_C2000: u16 = 141;
/// Texas Instruments TMS320C55x DSP
pub const EM_TI_C5500: u16 = 142;
/// Texas Instruments App. Specific RISC
pub const EM_TI_ARP32: u16 = 143;
/// Texas Instruments Prog. Realtime Unit
pub const EM_TI_PRU: u16 = 144;
// reserved 145-159
/// STMicroelectronics 64bit VLIW DSP
pub const EM_MMDSP_PLUS: u16 = 160;
/// Cypress M8C
pub const EM_CYPRESS_M8C: u16 = 161;
/// Renesas R32C
pub const EM_R32C: u16 = 162;
/// NXP Semi. TriMedia
pub const EM_TRIMEDIA: u16 = 163;
/// QUALCOMM DSP6
pub const EM_QDSP6: u16 = 164;
/// Intel 8051 and variants
pub const EM_8051: u16 = 165;
/// STMicroelectronics STxP7x
pub const EM_STXP7X: u16 = 166;
/// Andes Tech. compact code emb. RISC
pub const EM_NDS32: u16 = 167;
/// Cyan Technology eCOG1X
pub const EM_ECOG1X: u16 = 168;
/// Dallas Semi. MAXQ30 mc
pub const EM_MAXQ30: u16 = 169;
/// New Japan Radio (NJR) 16-bit DSP
pub const EM_XIMO16: u16 = 170;
/// M2000 Reconfigurable RISC
pub const EM_MANIK: u16 = 171;
/// Cray NV2 vector architecture
pub const EM_CRAYNV2: u16 = 172;
/// Renesas RX
pub const EM_RX: u16 = 173;
/// Imagination Tech. META
pub const EM_METAG: u16 = 174;
/// MCST Elbrus
pub const EM_MCST_ELBRUS: u16 = 175;
/// Cyan Technology eCOG16
pub const EM_ECOG16: u16 = 176;
/// National Semi. CompactRISC CR16
pub const EM_CR16: u16 = 177;
/// Freescale Extended Time Processing Unit
pub const EM_ETPU: u16 = 178;
/// Infineon Tech. SLE9X
pub const EM_SLE9X: u16 = 179;
/// Intel L10M
pub const EM_L10M: u16 = 180;
/// Intel K10M
pub const EM_K10M: u16 = 181;
// reserved 182
/// ARM AARCH64
pub const EM_AARCH64: u16 = 183;
// reserved 184
/// Amtel 32-bit microprocessor
pub const EM_AVR32: u16 = 185;
/// STMicroelectronics STM8
pub const EM_STM8: u16 = 186;
/// Tileta TILE64
pub const EM_TILE64: u16 = 187;
/// Tilera TILEPro
pub const EM_TILEPRO: u16 = 188;
/// Xilinx MicroBlaze
pub const EM_MICROBLAZE: u16 = 189;
/// NVIDIA CUDA
pub const EM_CUDA: u16 = 190;
/// Tilera TILE-Gx
pub const EM_TILEGX: u16 = 191;
/// CloudShield
pub const EM_CLOUDSHIELD: u16 = 192;
/// KIPO-KAIST Core-A 1st gen.
pub const EM_COREA_1ST: u16 = 193;
/// KIPO-KAIST Core-A 2nd gen.
pub const EM_COREA_2ND: u16 = 194;
/// Synopsys ARCompact V2
pub const EM_ARC_COMPACT2: u16 = 195;
/// Open8 RISC
pub const EM_OPEN8: u16 = 196;
/// Renesas RL78
pub const EM_RL78: u16 = 197;
/// Broadcom VideoCore V
pub const EM_VIDEOCORE5: u16 = 198;
/// Renesas 78KOR
pub const EM_78KOR: u16 = 199;
/// Freescale 56800EX DSC
pub const EM_56800EX: u16 = 200;
/// Beyond BA1
pub const EM_BA1: u16 = 201;
/// Beyond BA2
pub const EM_BA2: u16 = 202;
/// XMOS xCORE
pub const EM_XCORE: u16 = 203;
/// Microchip 8-bit PIC(r)
pub const EM_MCHP_PIC: u16 = 204;
/// Intel Graphics Technology
pub const EM_INTELGT: u16 = 205;
// reserved 206-209
/// KM211 KM32
pub const EM_KM32: u16 = 210;
/// KM211 KMX32
pub const EM_KMX32: u16 = 211;
/// KM211 KMX16
pub const EM_EMX16: u16 = 212;
/// KM211 KMX8
pub const EM_EMX8: u16 = 213;
/// KM211 KVARC
pub const EM_KVARC: u16 = 214;
/// Paneve CDP
pub const EM_CDP: u16 = 215;
/// Cognitive Smart Memory Processor
pub const EM_COGE: u16 = 216;
/// Bluechip CoolEngine
pub const EM_COOL: u16 = 217;
/// Nanoradio Optimized RISC
pub const EM_NORC: u16 = 218;
/// CSR Kalimba
pub const EM_CSR_KALIMBA: u16 = 219;
/// Zilog Z80
pub const EM_Z80: u16 = 220;
/// Controls and Data Services VISIUMcore
pub const EM_VISIUM: u16 = 221;
/// FTDI Chip FT32
pub const EM_FT32: u16 = 222;
/// Moxie processor
pub const EM_MOXIE: u16 = 223;
/// AMD GPU
pub const EM_AMDGPU: u16 = 224;
// reserved 225-242
/// RISC-V
pub const EM_RISCV: u16 = 243;

/// Linux BPF -- in-kernel virtual machine
pub const EM_BPF: u16 = 247;

/// C-SKY
pub const EM_CSKY: u16 = 252;

pub const EM_NUM: u16 = 248;

/// Convert machine to str representation
pub fn machine_to_str (machine: u16) -> &'static str {
    match machine {
        EM_M32 => "M32",
        EM_SPARC => "SPARC",
        EM_386 => "386",
        EM_68K => "68K",
        EM_88K => "88K",
        EM_IAMCU => "IAMCU",
        EM_860 => "860",
        EM_MIPS => "MIPS",
        EM_S370 => "S370",
        EM_MIPS_RS3_LE => "MIPS_RS3_LE",
        EM_PARISC => "PARISC",
        EM_VPP500 => "VPP500",
        EM_SPARC32PLUS => "SPARC32PLUS",
        EM_960 => "960",
        EM_PPC => "PPC",
        EM_PPC64 => "PPC64",
        EM_S390 => "S390",
        EM_SPU => "SPU",
        EM_V800 => "V800",
        EM_FR20 => "FR20",
        EM_RH32 => "RH32",
        EM_RCE => "RCE",
        EM_ARM => "ARM",
        EM_FAKE_ALPHA => "FAKE_ALPHA",
        EM_SH => "SH",
        EM_SPARCV9 => "SPARCV9",
        EM_TRICORE => "TRICORE",
        EM_ARC => "ARC",
        EM_H8_300 => "H8_300",
        EM_H8_300H => "H8_300H",
        EM_H8S => "H8S",
        EM_H8_500 => "H8_500",
        EM_IA_64 => "IA_64",
        EM_MIPS_X => "MIPS_X",
        EM_COLDFIRE => "COLDFIRE",
        EM_68HC12 => "68HC12",
        EM_MMA => "MMA",
        EM_PCP => "PCP",
        EM_NCPU => "NCPU",
        EM_NDR1 => "NDR1",
        EM_STARCORE => "STARCORE",
        EM_ME16 => "ME16",
        EM_ST100 => "ST100",
        EM_TINYJ => "TINYJ",
        EM_X86_64 => "X86_64",
        EM_PDSP => "PDSP",
        EM_PDP10 => "PDP10",
        EM_PDP11 => "PDP11",
        EM_FX66 => "FX66",
        EM_ST9PLUS => "ST9PLUS",
        EM_ST7 => "ST7",
        EM_68HC16 => "68HC16",
        EM_68HC11 => "68HC11",
        EM_68HC08 => "68HC08",
        EM_68HC05 => "68HC05",
        EM_SVX => "SVX",
        EM_ST19 => "ST19",
        EM_VAX => "VAX",
        EM_CRIS => "CRIS",
        EM_JAVELIN => "JAVELIN",
        EM_FIREPATH => "FIREPATH",
        EM_ZSP => "ZSP",
        EM_MMIX => "MMIX",
        EM_HUANY => "HUANY",
        EM_PRISM => "PRISM",
        EM_AVR => "AVR",
        EM_FR30 => "FR30",
        EM_D10V => "D10V",
        EM_D30V => "D30V",
        EM_V850 => "V850",
        EM_M32R => "M32R",
        EM_MN10300 => "MN10300",
        EM_MN10200 => "MN10200",
        EM_PJ => "PJ",
        EM_OPENRISC => "OPENRISC",
        EM_ARC_COMPACT => "ARC_COMPACT",
        EM_XTENSA => "XTENSA",
        EM_VIDEOCORE => "VIDEOCORE",
        EM_TMM_GPP => "TMM_GPP",
        EM_NS32K => "NS32K",
        EM_TPC => "TPC",
        EM_SNP1K => "SNP1K",
        EM_ST200 => "ST200",
        EM_IP2K => "IP2K",
        EM_MAX => "MAX",
        EM_CR => "CR",
        EM_F2MC16 => "F2MC16",
        EM_MSP430 => "MSP430",
        EM_BLACKFIN => "BLACKFIN",
        EM_SE_C33 => "SE_C33",
        EM_SEP => "SEP",
        EM_ARCA => "ARCA",
        EM_UNICORE => "UNICORE",
        EM_EXCESS => "EXCESS",
        EM_DXP => "DXP",
        EM_ALTERA_NIOS2 => "ALTERA_NIOS2",
        EM_CRX => "CRX",
        EM_XGATE => "XGATE",
        EM_C166 => "C166",
        EM_M16C => "M16C",
        EM_DSPIC30F => "DSPIC30F",
        EM_CE => "CE",
        EM_M32C => "M32C",
        EM_TSK3000 => "TSK3000",
        EM_RS08 => "RS08",
        EM_SHARC => "SHARC",
        EM_ECOG2 => "ECOG2",
        EM_SCORE7 => "SCORE7",
        EM_DSP24 => "DSP24",
        EM_VIDEOCORE3 => "VIDEOCORE3",
        EM_LATTICEMICO32 => "LATTICEMICO32",
        EM_SE_C17 => "SE_C17",
        EM_TI_C6000 => "TI_C6000",
        EM_TI_C2000 => "TI_C2000",
        EM_TI_C5500 => "TI_C5500",
        EM_TI_ARP32 => "TI_ARP32",
        EM_TI_PRU => "TI_PRU",
        EM_MMDSP_PLUS => "MMDSP_PLUS",
        EM_CYPRESS_M8C => "CYPRESS_M8C",
        EM_R32C => "R32C",
        EM_TRIMEDIA => "TRIMEDIA",
        EM_QDSP6 => "QDSP6",
        EM_8051 => "8051",
        EM_STXP7X => "STXP7X",
        EM_NDS32 => "NDS32",
        EM_ECOG1X => "ECOG1X",
        EM_MAXQ30 => "MAXQ30",
        EM_XIMO16 => "XIMO16",
        EM_MANIK => "MANIK",
        EM_CRAYNV2 => "CRAYNV2",
        EM_RX => "RX",
        EM_METAG => "METAG",
        EM_MCST_ELBRUS => "MCST_ELBRUS",
        EM_ECOG16 => "ECOG16",
        EM_CR16 => "CR16",
        EM_ETPU => "ETPU",
        EM_SLE9X => "SLE9X",
        EM_L10M => "L10M",
        EM_K10M => "K10M",
        EM_AARCH64 => "AARCH64",
        EM_AVR32 => "AVR32",
        EM_STM8 => "STM8",
        EM_TILE64 => "TILE64",
        EM_TILEPRO => "TILEPRO",
        EM_MICROBLAZE => "MICROBLAZE",
        EM_CUDA => "CUDA",
        EM_TILEGX => "TILEGX",
        EM_CLOUDSHIELD => "CLOUDSHIELD",
        EM_COREA_1ST => "COREA_1ST",
        EM_COREA_2ND => "COREA_2ND",
        EM_ARC_COMPACT2 => "ARC_COMPACT2",
        EM_OPEN8 => "OPEN8",
        EM_RL78 => "RL78",
        EM_VIDEOCORE5 => "VIDEOCORE5",
        EM_78KOR => "78KOR",
        EM_56800EX => "56800EX",
        EM_BA1 => "BA1",
        EM_BA2 => "BA2",
        EM_XCORE => "XCORE",
        EM_MCHP_PIC => "MCHP_PIC",
        EM_KM32 => "KM32",
        EM_KMX32 => "KMX32",
        EM_EMX16 => "EMX16",
        EM_EMX8 => "EMX8",
        EM_KVARC => "KVARC",
        EM_CDP => "CDP",
        EM_COGE => "COGE",
        EM_COOL => "COOL",
        EM_NORC => "NORC",
        EM_CSR_KALIMBA => "CSR_KALIMBA",
        EM_Z80 => "Z80",
        EM_VISIUM => "VISIUM",
        EM_FT32 => "FT32",
        EM_MOXIE => "MOXIE",
        EM_AMDGPU => "AMDGPU",
        EM_RISCV => "RISCV",
        EM_BPF => "BPF",
        _val => "EM_UNKNOWN",
    }
}