1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux 1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ 2 #ifndef _LINUX_ELF_EM_H 2 #ifndef _LINUX_ELF_EM_H 3 #define _LINUX_ELF_EM_H 3 #define _LINUX_ELF_EM_H 4 4 5 /* These constants define the various ELF targ 5 /* These constants define the various ELF target machines */ 6 #define EM_NONE 0 6 #define EM_NONE 0 7 #define EM_M32 1 7 #define EM_M32 1 8 #define EM_SPARC 2 8 #define EM_SPARC 2 9 #define EM_386 3 9 #define EM_386 3 10 #define EM_68K 4 10 #define EM_68K 4 11 #define EM_88K 5 11 #define EM_88K 5 12 #define EM_486 6 /* Perhaps dis 12 #define EM_486 6 /* Perhaps disused */ 13 #define EM_860 7 13 #define EM_860 7 14 #define EM_MIPS 8 /* MIPS R3000 14 #define EM_MIPS 8 /* MIPS R3000 (officially, big-endian only) */ 15 /* Next two ar 15 /* Next two are historical and binaries and 16 modules of 16 modules of these types will be rejected by 17 Linux. */ 17 Linux. */ 18 #define EM_MIPS_RS3_LE 10 /* MIPS R3000 18 #define EM_MIPS_RS3_LE 10 /* MIPS R3000 little-endian */ 19 #define EM_MIPS_RS4_BE 10 /* MIPS R4000 19 #define EM_MIPS_RS4_BE 10 /* MIPS R4000 big-endian */ 20 20 21 #define EM_PARISC 15 /* HPPA */ 21 #define EM_PARISC 15 /* HPPA */ 22 #define EM_SPARC32PLUS 18 /* Sun's "v8pl 22 #define EM_SPARC32PLUS 18 /* Sun's "v8plus" */ 23 #define EM_PPC 20 /* PowerPC */ 23 #define EM_PPC 20 /* PowerPC */ 24 #define EM_PPC64 21 /* PowerPC64 24 #define EM_PPC64 21 /* PowerPC64 */ 25 #define EM_SPU 23 /* Cell BE SPU 25 #define EM_SPU 23 /* Cell BE SPU */ 26 #define EM_ARM 40 /* ARM 32 bit 26 #define EM_ARM 40 /* ARM 32 bit */ 27 #define EM_SH 42 /* SuperH */ 27 #define EM_SH 42 /* SuperH */ 28 #define EM_SPARCV9 43 /* SPARC v9 64 28 #define EM_SPARCV9 43 /* SPARC v9 64-bit */ 29 #define EM_H8_300 46 /* Renesas H8/ 29 #define EM_H8_300 46 /* Renesas H8/300 */ 30 #define EM_IA_64 50 /* HP/Intel IA 30 #define EM_IA_64 50 /* HP/Intel IA-64 */ 31 #define EM_X86_64 62 /* AMD x86-64 31 #define EM_X86_64 62 /* AMD x86-64 */ 32 #define EM_S390 22 /* IBM S/390 * 32 #define EM_S390 22 /* IBM S/390 */ 33 #define EM_CRIS 76 /* Axis Commun 33 #define EM_CRIS 76 /* Axis Communications 32-bit embedded processor */ 34 #define EM_M32R 88 /* Renesas M32 34 #define EM_M32R 88 /* Renesas M32R */ 35 #define EM_MN10300 89 /* Panasonic/M 35 #define EM_MN10300 89 /* Panasonic/MEI MN10300, AM33 */ 36 #define EM_OPENRISC 92 /* OpenRISC 32- 36 #define EM_OPENRISC 92 /* OpenRISC 32-bit embedded processor */ 37 #define EM_ARCOMPACT 93 /* ARCompact p 37 #define EM_ARCOMPACT 93 /* ARCompact processor */ 38 #define EM_XTENSA 94 /* Tensilica X 38 #define EM_XTENSA 94 /* Tensilica Xtensa Architecture */ 39 #define EM_BLACKFIN 106 /* ADI Blackfi 39 #define EM_BLACKFIN 106 /* ADI Blackfin Processor */ 40 #define EM_UNICORE 110 /* UniCore-32 40 #define EM_UNICORE 110 /* UniCore-32 */ 41 #define EM_ALTERA_NIOS2 113 /* Altera Nios 41 #define EM_ALTERA_NIOS2 113 /* Altera Nios II soft-core processor */ 42 #define EM_TI_C6000 140 /* TI C6X DSPs 42 #define EM_TI_C6000 140 /* TI C6X DSPs */ 43 #define EM_HEXAGON 164 /* QUALCOMM He 43 #define EM_HEXAGON 164 /* QUALCOMM Hexagon */ 44 #define EM_NDS32 167 /* Andes Techn 44 #define EM_NDS32 167 /* Andes Technology compact code size 45 embedded RI 45 embedded RISC processor family */ 46 #define EM_AARCH64 183 /* ARM 64 bit 46 #define EM_AARCH64 183 /* ARM 64 bit */ 47 #define EM_TILEPRO 188 /* Tilera TILE 47 #define EM_TILEPRO 188 /* Tilera TILEPro */ 48 #define EM_MICROBLAZE 189 /* Xilinx Micr 48 #define EM_MICROBLAZE 189 /* Xilinx MicroBlaze */ 49 #define EM_TILEGX 191 /* Tilera TILE 49 #define EM_TILEGX 191 /* Tilera TILE-Gx */ 50 #define EM_ARCV2 195 /* ARCv2 Cores 50 #define EM_ARCV2 195 /* ARCv2 Cores */ 51 #define EM_RISCV 243 /* RISC-V */ 51 #define EM_RISCV 243 /* RISC-V */ 52 #define EM_BPF 247 /* Linux BPF - 52 #define EM_BPF 247 /* Linux BPF - in-kernel virtual machine */ 53 #define EM_CSKY 252 /* C-SKY */ 53 #define EM_CSKY 252 /* C-SKY */ 54 #define EM_LOONGARCH 258 /* LoongArch * 54 #define EM_LOONGARCH 258 /* LoongArch */ 55 #define EM_FRV 0x5441 /* Fujitsu FR- 55 #define EM_FRV 0x5441 /* Fujitsu FR-V */ 56 56 57 /* 57 /* 58 * This is an interim value that we will use u 58 * This is an interim value that we will use until the committee comes 59 * up with a final number. 59 * up with a final number. 60 */ 60 */ 61 #define EM_ALPHA 0x9026 61 #define EM_ALPHA 0x9026 62 62 63 /* Bogus old m32r magic number, used by old to 63 /* Bogus old m32r magic number, used by old tools. */ 64 #define EM_CYGNUS_M32R 0x9041 64 #define EM_CYGNUS_M32R 0x9041 65 /* This is the old interim value for S/390 arc 65 /* This is the old interim value for S/390 architecture */ 66 #define EM_S390_OLD 0xA390 66 #define EM_S390_OLD 0xA390 67 /* Also Panasonic/MEI MN10300, AM33 */ 67 /* Also Panasonic/MEI MN10300, AM33 */ 68 #define EM_CYGNUS_MN10300 0xbeef 68 #define EM_CYGNUS_MN10300 0xbeef 69 69 70 70 71 #endif /* _LINUX_ELF_EM_H */ 71 #endif /* _LINUX_ELF_EM_H */ 72 72
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.