1607ca46eSDavid Howells #ifndef _LINUX_ELF_EM_H 2607ca46eSDavid Howells #define _LINUX_ELF_EM_H 3607ca46eSDavid Howells 4607ca46eSDavid Howells /* These constants define the various ELF target machines */ 5607ca46eSDavid Howells #define EM_NONE 0 6607ca46eSDavid Howells #define EM_M32 1 7607ca46eSDavid Howells #define EM_SPARC 2 8607ca46eSDavid Howells #define EM_386 3 9607ca46eSDavid Howells #define EM_68K 4 10607ca46eSDavid Howells #define EM_88K 5 11607ca46eSDavid Howells #define EM_486 6 /* Perhaps disused */ 12607ca46eSDavid Howells #define EM_860 7 13607ca46eSDavid Howells #define EM_MIPS 8 /* MIPS R3000 (officially, big-endian only) */ 14607ca46eSDavid Howells /* Next two are historical and binaries and 15607ca46eSDavid Howells modules of these types will be rejected by 16607ca46eSDavid Howells Linux. */ 17607ca46eSDavid Howells #define EM_MIPS_RS3_LE 10 /* MIPS R3000 little-endian */ 18607ca46eSDavid Howells #define EM_MIPS_RS4_BE 10 /* MIPS R4000 big-endian */ 19607ca46eSDavid Howells 20607ca46eSDavid Howells #define EM_PARISC 15 /* HPPA */ 21607ca46eSDavid Howells #define EM_SPARC32PLUS 18 /* Sun's "v8plus" */ 22607ca46eSDavid Howells #define EM_PPC 20 /* PowerPC */ 23607ca46eSDavid Howells #define EM_PPC64 21 /* PowerPC64 */ 24607ca46eSDavid Howells #define EM_SPU 23 /* Cell BE SPU */ 25909e3ee4SDan Aloni #define EM_ARM 40 /* ARM 32 bit */ 26607ca46eSDavid Howells #define EM_SH 42 /* SuperH */ 27607ca46eSDavid Howells #define EM_SPARCV9 43 /* SPARC v9 64-bit */ 282600896dSYoshinori Sato #define EM_H8_300 46 /* Renesas H8/300 */ 29607ca46eSDavid Howells #define EM_IA_64 50 /* HP/Intel IA-64 */ 30607ca46eSDavid Howells #define EM_X86_64 62 /* AMD x86-64 */ 31607ca46eSDavid Howells #define EM_S390 22 /* IBM S/390 */ 32607ca46eSDavid Howells #define EM_CRIS 76 /* Axis Communications 32-bit embedded processor */ 33607ca46eSDavid Howells #define EM_M32R 88 /* Renesas M32R */ 34607ca46eSDavid Howells #define EM_MN10300 89 /* Panasonic/MEI MN10300, AM33 */ 3529075feaSGuenter Roeck #define EM_OPENRISC 92 /* OpenRISC 32-bit embedded processor */ 36607ca46eSDavid Howells #define EM_BLACKFIN 106 /* ADI Blackfin Processor */ 374fdace8dSLey Foon Tan #define EM_ALTERA_NIOS2 113 /* Altera Nios II soft-core processor */ 38607ca46eSDavid Howells #define EM_TI_C6000 140 /* TI C6X DSPs */ 39909e3ee4SDan Aloni #define EM_AARCH64 183 /* ARM 64 bit */ 40a0ddef81SChris Metcalf #define EM_TILEPRO 188 /* Tilera TILEPro */ 41b1413279SMike Frysinger #define EM_MICROBLAZE 189 /* Xilinx MicroBlaze */ 42a0ddef81SChris Metcalf #define EM_TILEGX 191 /* Tilera TILE-Gx */ 43*b02b94b3SDaniel Borkmann #define EM_BPF 247 /* Linux BPF - in-kernel virtual machine */ 44607ca46eSDavid Howells #define EM_FRV 0x5441 /* Fujitsu FR-V */ 45607ca46eSDavid Howells #define EM_AVR32 0x18ad /* Atmel AVR32 */ 46607ca46eSDavid Howells 47607ca46eSDavid Howells /* 48607ca46eSDavid Howells * This is an interim value that we will use until the committee comes 49607ca46eSDavid Howells * up with a final number. 50607ca46eSDavid Howells */ 51607ca46eSDavid Howells #define EM_ALPHA 0x9026 52607ca46eSDavid Howells 53607ca46eSDavid Howells /* Bogus old m32r magic number, used by old tools. */ 54607ca46eSDavid Howells #define EM_CYGNUS_M32R 0x9041 55607ca46eSDavid Howells /* This is the old interim value for S/390 architecture */ 56607ca46eSDavid Howells #define EM_S390_OLD 0xA390 57607ca46eSDavid Howells /* Also Panasonic/MEI MN10300, AM33 */ 58607ca46eSDavid Howells #define EM_CYGNUS_MN10300 0xbeef 59607ca46eSDavid Howells 60607ca46eSDavid Howells 61607ca46eSDavid Howells #endif /* _LINUX_ELF_EM_H */ 62