blob: d9544b8a70967d2b6243b0d253f10dbdd8fe6b3e [file] [log] [blame]
Greg Kroah-Hartman6f52b162017-11-01 15:08:43 +01001/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
David Woodhousef001e472006-04-27 00:11:01 +01002#ifndef _LINUX_ELF_EM_H
3#define _LINUX_ELF_EM_H
4
5/* These constants define the various ELF target machines */
6#define EM_NONE 0
7#define EM_M32 1
8#define EM_SPARC 2
9#define EM_386 3
10#define EM_68K 4
11#define EM_88K 5
12#define EM_486 6 /* Perhaps disused */
13#define EM_860 7
14#define EM_MIPS 8 /* MIPS R3000 (officially, big-endian only) */
Ralf Baechle7ae7cda2006-06-29 21:10:50 +010015 /* Next two are historical and binaries and
16 modules of these types will be rejected by
17 Linux. */
18#define EM_MIPS_RS3_LE 10 /* MIPS R3000 little-endian */
David Woodhousef001e472006-04-27 00:11:01 +010019#define EM_MIPS_RS4_BE 10 /* MIPS R4000 big-endian */
Ralf Baechle7ae7cda2006-06-29 21:10:50 +010020
David Woodhousef001e472006-04-27 00:11:01 +010021#define EM_PARISC 15 /* HPPA */
22#define EM_SPARC32PLUS 18 /* Sun's "v8plus" */
23#define EM_PPC 20 /* PowerPC */
Bob Nelson14748552007-07-20 21:39:53 +020024#define EM_PPC64 21 /* PowerPC64 */
25#define EM_SPU 23 /* Cell BE SPU */
Dan Aloni909e3ee2013-08-28 14:24:53 +010026#define EM_ARM 40 /* ARM 32 bit */
David Woodhousef001e472006-04-27 00:11:01 +010027#define EM_SH 42 /* SuperH */
28#define EM_SPARCV9 43 /* SPARC v9 64-bit */
Yoshinori Sato26008962015-01-28 02:54:39 +090029#define EM_H8_300 46 /* Renesas H8/300 */
David Woodhousef001e472006-04-27 00:11:01 +010030#define EM_IA_64 50 /* HP/Intel IA-64 */
31#define EM_X86_64 62 /* AMD x86-64 */
32#define EM_S390 22 /* IBM S/390 */
33#define EM_CRIS 76 /* Axis Communications 32-bit embedded processor */
David Woodhousef001e472006-04-27 00:11:01 +010034#define EM_M32R 88 /* Renesas M32R */
David Howellsb920de1b2008-02-08 04:19:31 -080035#define EM_MN10300 89 /* Panasonic/MEI MN10300, AM33 */
Guenter Roeck29075fe2014-09-26 09:05:39 -070036#define EM_OPENRISC 92 /* OpenRISC 32-bit embedded processor */
Bryan Wu1394f032007-05-06 14:50:22 -070037#define EM_BLACKFIN 106 /* ADI Blackfin Processor */
Ley Foon Tan4fdace82014-11-06 15:19:54 +080038#define EM_ALTERA_NIOS2 113 /* Altera Nios II soft-core processor */
Mark Salter854a6852011-09-27 12:35:21 -040039#define EM_TI_C6000 140 /* TI C6X DSPs */
Dan Aloni909e3ee2013-08-28 14:24:53 +010040#define EM_AARCH64 183 /* ARM 64 bit */
Chris Metcalfa0ddef82015-07-22 14:30:14 -040041#define EM_TILEPRO 188 /* Tilera TILEPro */
Mike Frysingerb1413272015-08-18 03:28:01 -040042#define EM_MICROBLAZE 189 /* Xilinx MicroBlaze */
Chris Metcalfa0ddef82015-07-22 14:30:14 -040043#define EM_TILEGX 191 /* Tilera TILE-Gx */
Palmer Dabbelt9b4789e2018-06-25 13:23:12 -070044#define EM_RISCV 243 /* RISC-V */
Daniel Borkmannb02b94b2016-07-20 20:17:47 +020045#define EM_BPF 247 /* Linux BPF - in-kernel virtual machine */
Dmitry V. Levin077b9302018-12-13 20:22:00 +030046#define EM_CSKY 252 /* C-SKY */
David Woodhousef001e472006-04-27 00:11:01 +010047#define EM_FRV 0x5441 /* Fujitsu FR-V */
David Woodhousef001e472006-04-27 00:11:01 +010048
49/*
50 * This is an interim value that we will use until the committee comes
51 * up with a final number.
52 */
53#define EM_ALPHA 0x9026
54
David Woodhousef001e472006-04-27 00:11:01 +010055/* Bogus old m32r magic number, used by old tools. */
56#define EM_CYGNUS_M32R 0x9041
57/* This is the old interim value for S/390 architecture */
58#define EM_S390_OLD 0xA390
David Howellsb920de1b2008-02-08 04:19:31 -080059/* Also Panasonic/MEI MN10300, AM33 */
60#define EM_CYGNUS_MN10300 0xbeef
David Woodhousef001e472006-04-27 00:11:01 +010061
62
63#endif /* _LINUX_ELF_EM_H */