1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun #ifndef _ASM_IA64_ELF_H 3*4882a593Smuzhiyun #define _ASM_IA64_ELF_H 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun /* 6*4882a593Smuzhiyun * ELF-specific definitions. 7*4882a593Smuzhiyun * 8*4882a593Smuzhiyun * Copyright (C) 1998-1999, 2002-2004 Hewlett-Packard Co 9*4882a593Smuzhiyun * David Mosberger-Tang <davidm@hpl.hp.com> 10*4882a593Smuzhiyun */ 11*4882a593Smuzhiyun 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #include <asm/fpu.h> 14*4882a593Smuzhiyun #include <asm/page.h> 15*4882a593Smuzhiyun #include <asm/auxvec.h> 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun /* 18*4882a593Smuzhiyun * This is used to ensure we don't load something for the wrong architecture. 19*4882a593Smuzhiyun */ 20*4882a593Smuzhiyun #define elf_check_arch(x) ((x)->e_machine == EM_IA_64) 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun /* 23*4882a593Smuzhiyun * These are used to set parameters in the core dumps. 24*4882a593Smuzhiyun */ 25*4882a593Smuzhiyun #define ELF_CLASS ELFCLASS64 26*4882a593Smuzhiyun #define ELF_DATA ELFDATA2LSB 27*4882a593Smuzhiyun #define ELF_ARCH EM_IA_64 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun #define CORE_DUMP_USE_REGSET 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun /* Least-significant four bits of ELF header's e_flags are OS-specific. The bits are 32*4882a593Smuzhiyun interpreted as follows by Linux: */ 33*4882a593Smuzhiyun #define EF_IA_64_LINUX_EXECUTABLE_STACK 0x1 /* is stack (& heap) executable by default? */ 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun #define ELF_EXEC_PAGESIZE PAGE_SIZE 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun /* 38*4882a593Smuzhiyun * This is the location that an ET_DYN program is loaded if exec'ed. 39*4882a593Smuzhiyun * Typical use of this is to invoke "./ld.so someprog" to test out a 40*4882a593Smuzhiyun * new version of the loader. We need to make sure that it is out of 41*4882a593Smuzhiyun * the way of the program that it will "exec", and that there is 42*4882a593Smuzhiyun * sufficient room for the brk. 43*4882a593Smuzhiyun */ 44*4882a593Smuzhiyun #define ELF_ET_DYN_BASE (TASK_UNMAPPED_BASE + 0x800000000UL) 45*4882a593Smuzhiyun 46*4882a593Smuzhiyun #define PT_IA_64_UNWIND 0x70000001 47*4882a593Smuzhiyun 48*4882a593Smuzhiyun /* IA-64 relocations: */ 49*4882a593Smuzhiyun #define R_IA64_NONE 0x00 /* none */ 50*4882a593Smuzhiyun #define R_IA64_IMM14 0x21 /* symbol + addend, add imm14 */ 51*4882a593Smuzhiyun #define R_IA64_IMM22 0x22 /* symbol + addend, add imm22 */ 52*4882a593Smuzhiyun #define R_IA64_IMM64 0x23 /* symbol + addend, mov imm64 */ 53*4882a593Smuzhiyun #define R_IA64_DIR32MSB 0x24 /* symbol + addend, data4 MSB */ 54*4882a593Smuzhiyun #define R_IA64_DIR32LSB 0x25 /* symbol + addend, data4 LSB */ 55*4882a593Smuzhiyun #define R_IA64_DIR64MSB 0x26 /* symbol + addend, data8 MSB */ 56*4882a593Smuzhiyun #define R_IA64_DIR64LSB 0x27 /* symbol + addend, data8 LSB */ 57*4882a593Smuzhiyun #define R_IA64_GPREL22 0x2a /* @gprel(sym+add), add imm22 */ 58*4882a593Smuzhiyun #define R_IA64_GPREL64I 0x2b /* @gprel(sym+add), mov imm64 */ 59*4882a593Smuzhiyun #define R_IA64_GPREL32MSB 0x2c /* @gprel(sym+add), data4 MSB */ 60*4882a593Smuzhiyun #define R_IA64_GPREL32LSB 0x2d /* @gprel(sym+add), data4 LSB */ 61*4882a593Smuzhiyun #define R_IA64_GPREL64MSB 0x2e /* @gprel(sym+add), data8 MSB */ 62*4882a593Smuzhiyun #define R_IA64_GPREL64LSB 0x2f /* @gprel(sym+add), data8 LSB */ 63*4882a593Smuzhiyun #define R_IA64_LTOFF22 0x32 /* @ltoff(sym+add), add imm22 */ 64*4882a593Smuzhiyun #define R_IA64_LTOFF64I 0x33 /* @ltoff(sym+add), mov imm64 */ 65*4882a593Smuzhiyun #define R_IA64_PLTOFF22 0x3a /* @pltoff(sym+add), add imm22 */ 66*4882a593Smuzhiyun #define R_IA64_PLTOFF64I 0x3b /* @pltoff(sym+add), mov imm64 */ 67*4882a593Smuzhiyun #define R_IA64_PLTOFF64MSB 0x3e /* @pltoff(sym+add), data8 MSB */ 68*4882a593Smuzhiyun #define R_IA64_PLTOFF64LSB 0x3f /* @pltoff(sym+add), data8 LSB */ 69*4882a593Smuzhiyun #define R_IA64_FPTR64I 0x43 /* @fptr(sym+add), mov imm64 */ 70*4882a593Smuzhiyun #define R_IA64_FPTR32MSB 0x44 /* @fptr(sym+add), data4 MSB */ 71*4882a593Smuzhiyun #define R_IA64_FPTR32LSB 0x45 /* @fptr(sym+add), data4 LSB */ 72*4882a593Smuzhiyun #define R_IA64_FPTR64MSB 0x46 /* @fptr(sym+add), data8 MSB */ 73*4882a593Smuzhiyun #define R_IA64_FPTR64LSB 0x47 /* @fptr(sym+add), data8 LSB */ 74*4882a593Smuzhiyun #define R_IA64_PCREL60B 0x48 /* @pcrel(sym+add), brl */ 75*4882a593Smuzhiyun #define R_IA64_PCREL21B 0x49 /* @pcrel(sym+add), ptb, call */ 76*4882a593Smuzhiyun #define R_IA64_PCREL21M 0x4a /* @pcrel(sym+add), chk.s */ 77*4882a593Smuzhiyun #define R_IA64_PCREL21F 0x4b /* @pcrel(sym+add), fchkf */ 78*4882a593Smuzhiyun #define R_IA64_PCREL32MSB 0x4c /* @pcrel(sym+add), data4 MSB */ 79*4882a593Smuzhiyun #define R_IA64_PCREL32LSB 0x4d /* @pcrel(sym+add), data4 LSB */ 80*4882a593Smuzhiyun #define R_IA64_PCREL64MSB 0x4e /* @pcrel(sym+add), data8 MSB */ 81*4882a593Smuzhiyun #define R_IA64_PCREL64LSB 0x4f /* @pcrel(sym+add), data8 LSB */ 82*4882a593Smuzhiyun #define R_IA64_LTOFF_FPTR22 0x52 /* @ltoff(@fptr(s+a)), imm22 */ 83*4882a593Smuzhiyun #define R_IA64_LTOFF_FPTR64I 0x53 /* @ltoff(@fptr(s+a)), imm64 */ 84*4882a593Smuzhiyun #define R_IA64_LTOFF_FPTR32MSB 0x54 /* @ltoff(@fptr(s+a)), 4 MSB */ 85*4882a593Smuzhiyun #define R_IA64_LTOFF_FPTR32LSB 0x55 /* @ltoff(@fptr(s+a)), 4 LSB */ 86*4882a593Smuzhiyun #define R_IA64_LTOFF_FPTR64MSB 0x56 /* @ltoff(@fptr(s+a)), 8 MSB */ 87*4882a593Smuzhiyun #define R_IA64_LTOFF_FPTR64LSB 0x57 /* @ltoff(@fptr(s+a)), 8 LSB */ 88*4882a593Smuzhiyun #define R_IA64_SEGREL32MSB 0x5c /* @segrel(sym+add), data4 MSB */ 89*4882a593Smuzhiyun #define R_IA64_SEGREL32LSB 0x5d /* @segrel(sym+add), data4 LSB */ 90*4882a593Smuzhiyun #define R_IA64_SEGREL64MSB 0x5e /* @segrel(sym+add), data8 MSB */ 91*4882a593Smuzhiyun #define R_IA64_SEGREL64LSB 0x5f /* @segrel(sym+add), data8 LSB */ 92*4882a593Smuzhiyun #define R_IA64_SECREL32MSB 0x64 /* @secrel(sym+add), data4 MSB */ 93*4882a593Smuzhiyun #define R_IA64_SECREL32LSB 0x65 /* @secrel(sym+add), data4 LSB */ 94*4882a593Smuzhiyun #define R_IA64_SECREL64MSB 0x66 /* @secrel(sym+add), data8 MSB */ 95*4882a593Smuzhiyun #define R_IA64_SECREL64LSB 0x67 /* @secrel(sym+add), data8 LSB */ 96*4882a593Smuzhiyun #define R_IA64_REL32MSB 0x6c /* data 4 + REL */ 97*4882a593Smuzhiyun #define R_IA64_REL32LSB 0x6d /* data 4 + REL */ 98*4882a593Smuzhiyun #define R_IA64_REL64MSB 0x6e /* data 8 + REL */ 99*4882a593Smuzhiyun #define R_IA64_REL64LSB 0x6f /* data 8 + REL */ 100*4882a593Smuzhiyun #define R_IA64_LTV32MSB 0x74 /* symbol + addend, data4 MSB */ 101*4882a593Smuzhiyun #define R_IA64_LTV32LSB 0x75 /* symbol + addend, data4 LSB */ 102*4882a593Smuzhiyun #define R_IA64_LTV64MSB 0x76 /* symbol + addend, data8 MSB */ 103*4882a593Smuzhiyun #define R_IA64_LTV64LSB 0x77 /* symbol + addend, data8 LSB */ 104*4882a593Smuzhiyun #define R_IA64_PCREL21BI 0x79 /* @pcrel(sym+add), ptb, call */ 105*4882a593Smuzhiyun #define R_IA64_PCREL22 0x7a /* @pcrel(sym+add), imm22 */ 106*4882a593Smuzhiyun #define R_IA64_PCREL64I 0x7b /* @pcrel(sym+add), imm64 */ 107*4882a593Smuzhiyun #define R_IA64_IPLTMSB 0x80 /* dynamic reloc, imported PLT, MSB */ 108*4882a593Smuzhiyun #define R_IA64_IPLTLSB 0x81 /* dynamic reloc, imported PLT, LSB */ 109*4882a593Smuzhiyun #define R_IA64_COPY 0x84 /* dynamic reloc, data copy */ 110*4882a593Smuzhiyun #define R_IA64_SUB 0x85 /* -symbol + addend, add imm22 */ 111*4882a593Smuzhiyun #define R_IA64_LTOFF22X 0x86 /* LTOFF22, relaxable. */ 112*4882a593Smuzhiyun #define R_IA64_LDXMOV 0x87 /* Use of LTOFF22X. */ 113*4882a593Smuzhiyun #define R_IA64_TPREL14 0x91 /* @tprel(sym+add), add imm14 */ 114*4882a593Smuzhiyun #define R_IA64_TPREL22 0x92 /* @tprel(sym+add), add imm22 */ 115*4882a593Smuzhiyun #define R_IA64_TPREL64I 0x93 /* @tprel(sym+add), add imm64 */ 116*4882a593Smuzhiyun #define R_IA64_TPREL64MSB 0x96 /* @tprel(sym+add), data8 MSB */ 117*4882a593Smuzhiyun #define R_IA64_TPREL64LSB 0x97 /* @tprel(sym+add), data8 LSB */ 118*4882a593Smuzhiyun #define R_IA64_LTOFF_TPREL22 0x9a /* @ltoff(@tprel(s+a)), add imm22 */ 119*4882a593Smuzhiyun #define R_IA64_DTPMOD64MSB 0xa6 /* @dtpmod(sym+add), data8 MSB */ 120*4882a593Smuzhiyun #define R_IA64_DTPMOD64LSB 0xa7 /* @dtpmod(sym+add), data8 LSB */ 121*4882a593Smuzhiyun #define R_IA64_LTOFF_DTPMOD22 0xaa /* @ltoff(@dtpmod(s+a)), imm22 */ 122*4882a593Smuzhiyun #define R_IA64_DTPREL14 0xb1 /* @dtprel(sym+add), imm14 */ 123*4882a593Smuzhiyun #define R_IA64_DTPREL22 0xb2 /* @dtprel(sym+add), imm22 */ 124*4882a593Smuzhiyun #define R_IA64_DTPREL64I 0xb3 /* @dtprel(sym+add), imm64 */ 125*4882a593Smuzhiyun #define R_IA64_DTPREL32MSB 0xb4 /* @dtprel(sym+add), data4 MSB */ 126*4882a593Smuzhiyun #define R_IA64_DTPREL32LSB 0xb5 /* @dtprel(sym+add), data4 LSB */ 127*4882a593Smuzhiyun #define R_IA64_DTPREL64MSB 0xb6 /* @dtprel(sym+add), data8 MSB */ 128*4882a593Smuzhiyun #define R_IA64_DTPREL64LSB 0xb7 /* @dtprel(sym+add), data8 LSB */ 129*4882a593Smuzhiyun #define R_IA64_LTOFF_DTPREL22 0xba /* @ltoff(@dtprel(s+a)), imm22 */ 130*4882a593Smuzhiyun 131*4882a593Smuzhiyun /* IA-64 specific section flags: */ 132*4882a593Smuzhiyun #define SHF_IA_64_SHORT 0x10000000 /* section near gp */ 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun /* 135*4882a593Smuzhiyun * We use (abuse?) this macro to insert the (empty) vm_area that is 136*4882a593Smuzhiyun * used to map the register backing store. I don't see any better 137*4882a593Smuzhiyun * place to do this, but we should discuss this with Linus once we can 138*4882a593Smuzhiyun * talk to him... 139*4882a593Smuzhiyun */ 140*4882a593Smuzhiyun extern void ia64_init_addr_space (void); 141*4882a593Smuzhiyun #define ELF_PLAT_INIT(_r, load_addr) ia64_init_addr_space() 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun /* ELF register definitions. This is needed for core dump support. */ 144*4882a593Smuzhiyun 145*4882a593Smuzhiyun /* 146*4882a593Smuzhiyun * elf_gregset_t contains the application-level state in the following order: 147*4882a593Smuzhiyun * r0-r31 148*4882a593Smuzhiyun * NaT bits (for r0-r31; bit N == 1 iff rN is a NaT) 149*4882a593Smuzhiyun * predicate registers (p0-p63) 150*4882a593Smuzhiyun * b0-b7 151*4882a593Smuzhiyun * ip cfm psr 152*4882a593Smuzhiyun * ar.rsc ar.bsp ar.bspstore ar.rnat 153*4882a593Smuzhiyun * ar.ccv ar.unat ar.fpsr ar.pfs ar.lc ar.ec ar.csd ar.ssd 154*4882a593Smuzhiyun */ 155*4882a593Smuzhiyun #define ELF_NGREG 128 /* we really need just 72 but let's leave some headroom... */ 156*4882a593Smuzhiyun #define ELF_NFPREG 128 /* f0 and f1 could be omitted, but so what... */ 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun /* elf_gregset_t register offsets */ 159*4882a593Smuzhiyun #define ELF_GR_0_OFFSET 0 160*4882a593Smuzhiyun #define ELF_NAT_OFFSET (32 * sizeof(elf_greg_t)) 161*4882a593Smuzhiyun #define ELF_PR_OFFSET (33 * sizeof(elf_greg_t)) 162*4882a593Smuzhiyun #define ELF_BR_0_OFFSET (34 * sizeof(elf_greg_t)) 163*4882a593Smuzhiyun #define ELF_CR_IIP_OFFSET (42 * sizeof(elf_greg_t)) 164*4882a593Smuzhiyun #define ELF_CFM_OFFSET (43 * sizeof(elf_greg_t)) 165*4882a593Smuzhiyun #define ELF_CR_IPSR_OFFSET (44 * sizeof(elf_greg_t)) 166*4882a593Smuzhiyun #define ELF_GR_OFFSET(i) (ELF_GR_0_OFFSET + i * sizeof(elf_greg_t)) 167*4882a593Smuzhiyun #define ELF_BR_OFFSET(i) (ELF_BR_0_OFFSET + i * sizeof(elf_greg_t)) 168*4882a593Smuzhiyun #define ELF_AR_RSC_OFFSET (45 * sizeof(elf_greg_t)) 169*4882a593Smuzhiyun #define ELF_AR_BSP_OFFSET (46 * sizeof(elf_greg_t)) 170*4882a593Smuzhiyun #define ELF_AR_BSPSTORE_OFFSET (47 * sizeof(elf_greg_t)) 171*4882a593Smuzhiyun #define ELF_AR_RNAT_OFFSET (48 * sizeof(elf_greg_t)) 172*4882a593Smuzhiyun #define ELF_AR_CCV_OFFSET (49 * sizeof(elf_greg_t)) 173*4882a593Smuzhiyun #define ELF_AR_UNAT_OFFSET (50 * sizeof(elf_greg_t)) 174*4882a593Smuzhiyun #define ELF_AR_FPSR_OFFSET (51 * sizeof(elf_greg_t)) 175*4882a593Smuzhiyun #define ELF_AR_PFS_OFFSET (52 * sizeof(elf_greg_t)) 176*4882a593Smuzhiyun #define ELF_AR_LC_OFFSET (53 * sizeof(elf_greg_t)) 177*4882a593Smuzhiyun #define ELF_AR_EC_OFFSET (54 * sizeof(elf_greg_t)) 178*4882a593Smuzhiyun #define ELF_AR_CSD_OFFSET (55 * sizeof(elf_greg_t)) 179*4882a593Smuzhiyun #define ELF_AR_SSD_OFFSET (56 * sizeof(elf_greg_t)) 180*4882a593Smuzhiyun #define ELF_AR_END_OFFSET (57 * sizeof(elf_greg_t)) 181*4882a593Smuzhiyun 182*4882a593Smuzhiyun typedef unsigned long elf_greg_t; 183*4882a593Smuzhiyun typedef elf_greg_t elf_gregset_t[ELF_NGREG]; 184*4882a593Smuzhiyun 185*4882a593Smuzhiyun typedef struct ia64_fpreg elf_fpreg_t; 186*4882a593Smuzhiyun typedef elf_fpreg_t elf_fpregset_t[ELF_NFPREG]; 187*4882a593Smuzhiyun 188*4882a593Smuzhiyun 189*4882a593Smuzhiyun 190*4882a593Smuzhiyun struct pt_regs; /* forward declaration... */ 191*4882a593Smuzhiyun extern void ia64_elf_core_copy_regs (struct pt_regs *src, elf_gregset_t dst); 192*4882a593Smuzhiyun #define ELF_CORE_COPY_REGS(_dest,_regs) ia64_elf_core_copy_regs(_regs, _dest); 193*4882a593Smuzhiyun 194*4882a593Smuzhiyun /* This macro yields a bitmask that programs can use to figure out 195*4882a593Smuzhiyun what instruction set this CPU supports. */ 196*4882a593Smuzhiyun #define ELF_HWCAP 0 197*4882a593Smuzhiyun 198*4882a593Smuzhiyun /* This macro yields a string that ld.so will use to load 199*4882a593Smuzhiyun implementation specific libraries for optimization. Not terribly 200*4882a593Smuzhiyun relevant until we have real hardware to play with... */ 201*4882a593Smuzhiyun #define ELF_PLATFORM NULL 202*4882a593Smuzhiyun 203*4882a593Smuzhiyun #define elf_read_implies_exec(ex, executable_stack) \ 204*4882a593Smuzhiyun ((executable_stack!=EXSTACK_DISABLE_X) && ((ex).e_flags & EF_IA_64_LINUX_EXECUTABLE_STACK) != 0) 205*4882a593Smuzhiyun 206*4882a593Smuzhiyun struct task_struct; 207*4882a593Smuzhiyun 208*4882a593Smuzhiyun #define GATE_EHDR ((const struct elfhdr *) GATE_ADDR) 209*4882a593Smuzhiyun 210*4882a593Smuzhiyun /* update AT_VECTOR_SIZE_ARCH if the number of NEW_AUX_ENT entries changes */ 211*4882a593Smuzhiyun #define ARCH_DLINFO \ 212*4882a593Smuzhiyun do { \ 213*4882a593Smuzhiyun extern char __kernel_syscall_via_epc[]; \ 214*4882a593Smuzhiyun NEW_AUX_ENT(AT_SYSINFO, (unsigned long) __kernel_syscall_via_epc); \ 215*4882a593Smuzhiyun NEW_AUX_ENT(AT_SYSINFO_EHDR, (unsigned long) GATE_EHDR); \ 216*4882a593Smuzhiyun } while (0) 217*4882a593Smuzhiyun 218*4882a593Smuzhiyun /* 219*4882a593Smuzhiyun * format for entries in the Global Offset Table 220*4882a593Smuzhiyun */ 221*4882a593Smuzhiyun struct got_entry { 222*4882a593Smuzhiyun uint64_t val; 223*4882a593Smuzhiyun }; 224*4882a593Smuzhiyun 225*4882a593Smuzhiyun /* 226*4882a593Smuzhiyun * Layout of the Function Descriptor 227*4882a593Smuzhiyun */ 228*4882a593Smuzhiyun struct fdesc { 229*4882a593Smuzhiyun uint64_t ip; 230*4882a593Smuzhiyun uint64_t gp; 231*4882a593Smuzhiyun }; 232*4882a593Smuzhiyun 233*4882a593Smuzhiyun #endif /* _ASM_IA64_ELF_H */ 234