2005-04-17 02:20:36 +04:00
/*
* S390 version
*
* Derived from " include/asm-i386/elf.h "
*/
# ifndef __ASMS390_ELF_H
# define __ASMS390_ELF_H
/* s390 relocations defined by the ABIs */
# define R_390_NONE 0 /* No reloc. */
# define R_390_8 1 /* Direct 8 bit. */
# define R_390_12 2 /* Direct 12 bit. */
# define R_390_16 3 /* Direct 16 bit. */
# define R_390_32 4 /* Direct 32 bit. */
# define R_390_PC32 5 /* PC relative 32 bit. */
# define R_390_GOT12 6 /* 12 bit GOT offset. */
# define R_390_GOT32 7 /* 32 bit GOT offset. */
# define R_390_PLT32 8 /* 32 bit PC relative PLT address. */
# define R_390_COPY 9 /* Copy symbol at runtime. */
# define R_390_GLOB_DAT 10 /* Create GOT entry. */
# define R_390_JMP_SLOT 11 /* Create PLT entry. */
# define R_390_RELATIVE 12 /* Adjust by program base. */
# define R_390_GOTOFF32 13 /* 32 bit offset to GOT. */
# define R_390_GOTPC 14 /* 32 bit PC rel. offset to GOT. */
# define R_390_GOT16 15 /* 16 bit GOT offset. */
# define R_390_PC16 16 /* PC relative 16 bit. */
# define R_390_PC16DBL 17 /* PC relative 16 bit shifted by 1. */
# define R_390_PLT16DBL 18 /* 16 bit PC rel. PLT shifted by 1. */
# define R_390_PC32DBL 19 /* PC relative 32 bit shifted by 1. */
# define R_390_PLT32DBL 20 /* 32 bit PC rel. PLT shifted by 1. */
# define R_390_GOTPCDBL 21 /* 32 bit PC rel. GOT shifted by 1. */
# define R_390_64 22 /* Direct 64 bit. */
# define R_390_PC64 23 /* PC relative 64 bit. */
# define R_390_GOT64 24 /* 64 bit GOT offset. */
# define R_390_PLT64 25 /* 64 bit PC relative PLT address. */
# define R_390_GOTENT 26 /* 32 bit PC rel. to GOT entry >> 1. */
# define R_390_GOTOFF16 27 /* 16 bit offset to GOT. */
# define R_390_GOTOFF64 28 /* 64 bit offset to GOT. */
# define R_390_GOTPLT12 29 /* 12 bit offset to jump slot. */
# define R_390_GOTPLT16 30 /* 16 bit offset to jump slot. */
# define R_390_GOTPLT32 31 /* 32 bit offset to jump slot. */
# define R_390_GOTPLT64 32 /* 64 bit offset to jump slot. */
# define R_390_GOTPLTENT 33 /* 32 bit rel. offset to jump slot. */
# define R_390_PLTOFF16 34 /* 16 bit offset from GOT to PLT. */
# define R_390_PLTOFF32 35 /* 32 bit offset from GOT to PLT. */
# define R_390_PLTOFF64 36 /* 16 bit offset from GOT to PLT. */
# define R_390_TLS_LOAD 37 /* Tag for load insn in TLS code. */
# define R_390_TLS_GDCALL 38 / * Tag for function call in general
dynamic TLS code . */
# define R_390_TLS_LDCALL 39 / * Tag for function call in local
dynamic TLS code . */
# define R_390_TLS_GD32 40 / * Direct 32 bit for general dynamic
thread local data . */
# define R_390_TLS_GD64 41 / * Direct 64 bit for general dynamic
thread local data . */
# define R_390_TLS_GOTIE12 42 / * 12 bit GOT offset for static TLS
block offset . */
# define R_390_TLS_GOTIE32 43 / * 32 bit GOT offset for static TLS
block offset . */
# define R_390_TLS_GOTIE64 44 / * 64 bit GOT offset for static TLS
block offset . */
# define R_390_TLS_LDM32 45 / * Direct 32 bit for local dynamic
thread local data in LD code . */
# define R_390_TLS_LDM64 46 / * Direct 64 bit for local dynamic
thread local data in LD code . */
# define R_390_TLS_IE32 47 / * 32 bit address of GOT entry for
negated static TLS block offset . */
# define R_390_TLS_IE64 48 / * 64 bit address of GOT entry for
negated static TLS block offset . */
# define R_390_TLS_IEENT 49 / * 32 bit rel. offset to GOT entry for
negated static TLS block offset . */
# define R_390_TLS_LE32 50 / * 32 bit negated offset relative to
static TLS block . */
# define R_390_TLS_LE64 51 / * 64 bit negated offset relative to
static TLS block . */
# define R_390_TLS_LDO32 52 / * 32 bit offset relative to TLS
block . */
# define R_390_TLS_LDO64 53 / * 64 bit offset relative to TLS
block . */
# define R_390_TLS_DTPMOD 54 /* ID of module containing symbol. */
# define R_390_TLS_DTPOFF 55 /* Offset in TLS block. */
# define R_390_TLS_TPOFF 56 / * Negate offset in static TLS
block . */
# define R_390_20 57 /* Direct 20 bit. */
# define R_390_GOT20 58 /* 20 bit GOT offset. */
# define R_390_GOTPLT20 59 /* 20 bit offset to jump slot. */
# define R_390_TLS_GOTIE20 60 / * 20 bit GOT offset for static TLS
block offset . */
/* Keep this the last entry. */
# define R_390_NUM 61
2009-10-06 12:34:13 +04:00
/* Bits present in AT_HWCAP. */
# define HWCAP_S390_ESAN3 1
# define HWCAP_S390_ZARCH 2
# define HWCAP_S390_STFLE 4
# define HWCAP_S390_MSA 8
# define HWCAP_S390_LDISP 16
# define HWCAP_S390_EIMM 32
# define HWCAP_S390_DFP 64
# define HWCAP_S390_HPAGE 128
# define HWCAP_S390_ETF3EH 256
# define HWCAP_S390_HIGH_GPRS 512
2012-07-31 13:03:04 +04:00
# define HWCAP_S390_TE 1024
2014-10-06 19:53:53 +04:00
# define HWCAP_S390_VXRS 2048
2009-10-06 12:34:13 +04:00
2015-02-24 17:54:47 +03:00
/* Internal bits, not exposed via elf */
# define HWCAP_INT_SIE 1UL
2005-04-17 02:20:36 +04:00
/*
* These are used to set parameters in the core dumps .
*/
# define ELF_CLASS ELFCLASS64
# define ELF_DATA ELFDATA2MSB
# define ELF_ARCH EM_S390
2006-09-16 23:15:46 +04:00
/*
* ELF register definitions . .
*/
# include <asm/ptrace.h>
2013-04-20 16:05:42 +04:00
# include <asm/compat.h>
2013-04-24 14:58:39 +04:00
# include <asm/syscall.h>
2006-09-16 23:15:46 +04:00
# include <asm/user.h>
typedef s390_fp_regs elf_fpregset_t ;
typedef s390_regs elf_gregset_t ;
2008-07-14 11:58:54 +04:00
typedef s390_fp_regs compat_elf_fpregset_t ;
typedef s390_compat_regs compat_elf_gregset_t ;
2015-11-26 11:25:35 +03:00
# include <linux/compat.h>
2006-09-16 23:15:46 +04:00
# include <linux/sched.h> /* for task_struct */
2008-02-09 20:24:35 +03:00
# include <asm/mmu_context.h>
2006-09-16 23:15:46 +04:00
2008-12-25 15:38:36 +03:00
# include <asm/vdso.h>
extern unsigned int vdso_enabled ;
2005-04-17 02:20:36 +04:00
/*
* This is used to ensure we don ' t load something for the wrong architecture .
*/
# define elf_check_arch(x) \
( ( ( x ) - > e_machine = = EM_S390 | | ( x ) - > e_machine = = EM_S390_OLD ) \
& & ( x ) - > e_ident [ EI_CLASS ] = = ELF_CLASS )
2008-07-14 11:58:54 +04:00
# define compat_elf_check_arch(x) \
( ( ( x ) - > e_machine = = EM_S390 | | ( x ) - > e_machine = = EM_S390_OLD ) \
& & ( x ) - > e_ident [ EI_CLASS ] = = ELF_CLASS )
# define compat_start_thread start_thread31
2005-04-17 02:20:36 +04:00
/* For SVR4/S390 the function pointer to be registered with `atexit` is
passed in R14 . */
# define ELF_PLAT_INIT(_r, load_addr) \
do { \
_r - > gprs [ 14 ] = 0 ; \
} while ( 0 )
2008-07-14 11:58:54 +04:00
# define CORE_DUMP_USE_REGSET
2005-04-17 02:20:36 +04:00
# define ELF_EXEC_PAGESIZE 4096
/* This is the location that an ET_DYN program is loaded if exec'ed. Typical
use of this is to invoke " ./ld.so someprog " to test out a new version of
the loader . We need to make sure that it is out of the way of the program
2015-04-15 01:48:04 +03:00
that it will " exec " , and that there is sufficient room for the brk . 64 - bit
tasks are aligned to 4 GB . */
2015-11-26 11:25:35 +03:00
# define ELF_ET_DYN_BASE (is_compat_task() ? \
2015-04-15 01:48:04 +03:00
( STACK_TOP / 3 * 2 ) : \
2015-04-15 01:48:07 +03:00
( STACK_TOP / 3 * 2 ) & ~ ( ( 1UL < < 32 ) - 1 ) )
2005-04-17 02:20:36 +04:00
/* This yields a mask that user programs can use to figure out what
instruction set this CPU supports . */
2007-05-04 20:48:28 +04:00
extern unsigned long elf_hwcap ;
# define ELF_HWCAP (elf_hwcap)
2005-04-17 02:20:36 +04:00
2015-02-24 17:54:47 +03:00
/* Internal hardware capabilities, not exposed via elf */
extern unsigned long int_hwcap ;
2005-04-17 02:20:36 +04:00
/* This yields a string that ld.so will use to load implementation
specific libraries for optimization . This is more specific in
intent than poking at uname or / proc / cpuinfo .
For the moment , we have only optimizations for the Intel generations ,
but that could change . . . */
2007-05-04 20:48:28 +04:00
# define ELF_PLATFORM_SIZE 8
extern char elf_platform [ ] ;
# define ELF_PLATFORM (elf_platform)
2005-04-17 02:20:36 +04:00
2013-04-24 14:58:39 +04:00
# ifndef CONFIG_COMPAT
# define SET_PERSONALITY(ex) \
do { \
set_personality ( PER_LINUX | \
( current - > personality & ( ~ PER_MASK ) ) ) ; \
current_thread_info ( ) - > sys_call_table = \
( unsigned long ) & sys_call_table ; \
} while ( 0 )
# else /* CONFIG_COMPAT */
2009-01-23 18:40:23 +03:00
# define SET_PERSONALITY(ex) \
do { \
if ( personality ( current - > personality ) ! = PER_LINUX32 ) \
2011-09-26 18:40:33 +04:00
set_personality ( PER_LINUX | \
( current - > personality & ~ PER_MASK ) ) ; \
2013-04-24 14:58:39 +04:00
if ( ( ex ) . e_ident [ EI_CLASS ] = = ELFCLASS32 ) { \
2009-01-23 18:40:23 +03:00
set_thread_flag ( TIF_31BIT ) ; \
2013-04-24 14:58:39 +04:00
current_thread_info ( ) - > sys_call_table = \
( unsigned long ) & sys_call_table_emu ; \
} else { \
2009-01-23 18:40:23 +03:00
clear_thread_flag ( TIF_31BIT ) ; \
2013-04-24 14:58:39 +04:00
current_thread_info ( ) - > sys_call_table = \
( unsigned long ) & sys_call_table ; \
} \
2005-04-17 02:20:36 +04:00
} while ( 0 )
2013-04-24 14:58:39 +04:00
# endif /* CONFIG_COMPAT */
2005-04-17 02:20:36 +04:00
2015-11-10 14:30:28 +03:00
/*
* Cache aliasing on the latest machines calls for a mapping granularity
* of 512 KB . For 64 - bit processes use a 512 KB alignment and a randomization
* of up to 1 GB . For 31 - bit processes the virtual address space is limited ,
* use no alignment and limit the randomization to 8 MB .
*/
2015-11-26 11:25:35 +03:00
# define BRK_RND_MASK (is_compat_task() ? 0x7ffUL : 0x3ffffUL)
# define MMAP_RND_MASK (is_compat_task() ? 0x7ffUL : 0x3ff80UL)
# define MMAP_ALIGN_MASK (is_compat_task() ? 0 : 0x7fUL)
2015-11-10 14:30:28 +03:00
# define STACK_RND_MASK MMAP_RND_MASK
2011-01-12 11:55:22 +03:00
2008-12-25 15:38:36 +03:00
# define ARCH_DLINFO \
do { \
if ( vdso_enabled ) \
NEW_AUX_ENT ( AT_SYSINFO_EHDR , \
( unsigned long ) current - > mm - > context . vdso_base ) ; \
} while ( 0 )
struct linux_binprm ;
# define ARCH_HAS_SETUP_ADDITIONAL_PAGES 1
int arch_setup_additional_pages ( struct linux_binprm * , int ) ;
2005-04-17 02:20:36 +04:00
# endif