Home | History | Annotate | Line # | Download | only in include
elf_machdep.h revision 1.10
      1  1.10    skrll /*	$NetBSD: elf_machdep.h,v 1.10 2009/05/30 05:56:53 skrll Exp $	*/
      2   1.1      eeh 
      3   1.4   kleink #define ELF32_MACHDEP_ENDIANNESS	ELFDATA2MSB
      4   1.1      eeh #define	ELF32_MACHDEP_ID_CASES						\
      5   1.4   kleink 		case EM_SPARC:						\
      6   1.4   kleink 		case EM_SPARC32PLUS:					\
      7   1.1      eeh 			break;
      8   1.1      eeh 
      9   1.4   kleink #define	ELF64_MACHDEP_ENDIANNESS	ELFDATA2MSB
     10   1.1      eeh #define	ELF64_MACHDEP_ID_CASES						\
     11   1.4   kleink 		case EM_SPARC32PLUS:					\
     12   1.4   kleink 		case EM_SPARCV9:					\
     13   1.1      eeh 			break;
     14   1.8  thorpej 
     15   1.9     cube #define	ELF32_MACHDEP_ID	EM_SPARC
     16   1.9     cube #define	ELF64_MACHDEP_ID	EM_SPARCV9
     17   1.5  minoura 
     18   1.6      eeh #ifdef __arch64__
     19   1.5  minoura #define ARCH_ELFSIZE		64	/* MD native binary size */
     20   1.6      eeh #else
     21   1.6      eeh #define ARCH_ELFSIZE		32	/* MD native binary size */
     22   1.6      eeh #endif
     23   1.2      eeh 
     24   1.7      eeh /* The following are what is used for AT_SUN_HWCAP: */
     25   1.7      eeh #define AV_SPARC_HWMUL_32x32	1	/* 32x32-bit smul/umul is efficient */
     26   1.7      eeh #define	AV_SPARC_HWDIV_32x32	2	/* 32x32-bit sdiv/udiv is efficient */
     27   1.7      eeh #define	AV_SPARC_HWFSMULD	4	/* fsmuld is efficient */
     28   1.7      eeh 
     29   1.7      eeh /*
     30   1.7      eeh  * Here are some SPARC specific flags I can't
     31   1.7      eeh  * find a better home for.  They are used for AT_FLAGS
     32   1.7      eeh  * and in the exec header.
     33   1.7      eeh  */
     34   1.7      eeh #define	EF_SPARCV9_MM		0x3
     35   1.7      eeh #define	EF_SPARCV9_TSO		0x0
     36   1.7      eeh #define	EF_SPARCV9_PSO		0x1
     37   1.7      eeh #define	EF_SPARCV9_RMO		0x2
     38   1.7      eeh 
     39   1.7      eeh #define EF_SPARC_32PLUS_MASK    0xffff00        /* bits indicating V8+ type */
     40   1.7      eeh #define EF_SPARC_32PLUS         0x000100        /* generic V8+ features */
     41   1.7      eeh #define EF_SPARC_EXT_MASK       0xffff00        /* bits for vendor extensions */
     42   1.7      eeh #define	EF_SPARC_SUN_US1	0x000200	/* UltraSPARC 1 extensions */
     43   1.7      eeh #define	EF_SPARC_HAL_R1		0x000400	/* HAL R1 extensions */
     44   1.7      eeh #define	EF_SPARC_SUN_US3	0x000800	/* UltraSPARC 3 extensions */
     45   1.7      eeh 
     46   1.7      eeh /* Relocation types */
     47   1.2      eeh #define R_SPARC_NONE		0
     48   1.2      eeh #define R_SPARC_8		1
     49   1.2      eeh #define R_SPARC_16		2
     50   1.2      eeh #define R_SPARC_32		3
     51   1.2      eeh #define R_SPARC_DISP8		4
     52   1.2      eeh #define R_SPARC_DISP16		5
     53   1.2      eeh #define R_SPARC_DISP32		6
     54   1.2      eeh #define R_SPARC_WDISP30		7
     55   1.2      eeh #define R_SPARC_WDISP22		8
     56   1.2      eeh #define R_SPARC_HI22		9
     57   1.2      eeh #define R_SPARC_22		10
     58   1.2      eeh #define R_SPARC_13		11
     59   1.2      eeh #define R_SPARC_LO10		12
     60   1.2      eeh #define R_SPARC_GOT10		13
     61   1.2      eeh #define R_SPARC_GOT13		14
     62   1.2      eeh #define R_SPARC_GOT22		15
     63   1.2      eeh #define R_SPARC_PC10		16
     64   1.2      eeh #define R_SPARC_PC22		17
     65   1.2      eeh #define R_SPARC_WPLT30		18
     66   1.2      eeh #define R_SPARC_COPY		19
     67   1.2      eeh #define R_SPARC_GLOB_DAT	20
     68   1.2      eeh #define R_SPARC_JMP_SLOT	21
     69   1.2      eeh #define R_SPARC_RELATIVE	22
     70   1.2      eeh #define R_SPARC_UA32		23
     71   1.2      eeh #define R_SPARC_PLT32		24
     72   1.2      eeh #define R_SPARC_HIPLT22		25
     73   1.2      eeh #define R_SPARC_LOPLT10		26
     74   1.2      eeh #define R_SPARC_PCPLT32		27
     75   1.2      eeh #define R_SPARC_PCPLT22		28
     76   1.2      eeh #define R_SPARC_PCPLT10		29
     77   1.2      eeh #define R_SPARC_10		30
     78   1.2      eeh #define R_SPARC_11		31
     79   1.2      eeh #define R_SPARC_64		32
     80   1.2      eeh #define R_SPARC_OLO10		33
     81   1.2      eeh #define R_SPARC_HH22		34
     82   1.2      eeh #define R_SPARC_HM10		35
     83   1.2      eeh #define R_SPARC_LM22		36
     84   1.2      eeh #define R_SPARC_PC_HH22		37
     85   1.2      eeh #define R_SPARC_PC_HM10		38
     86   1.2      eeh #define R_SPARC_PC_LM22		39
     87   1.2      eeh #define R_SPARC_WDISP16		40
     88   1.2      eeh #define R_SPARC_WDISP19		41
     89   1.2      eeh #define R_SPARC_GLOB_JMP	42
     90   1.2      eeh #define R_SPARC_7		43
     91   1.2      eeh #define R_SPARC_5		44
     92   1.2      eeh #define R_SPARC_6		45
     93   1.6      eeh #define	R_SPARC_DISP64		46
     94   1.6      eeh #define	R_SPARC_PLT64		47
     95   1.6      eeh #define	R_SPARC_HIX22		48
     96   1.6      eeh #define	R_SPARC_LOX10		49
     97   1.6      eeh #define	R_SPARC_H44		50
     98   1.6      eeh #define	R_SPARC_M44		51
     99   1.6      eeh #define	R_SPARC_L44		52
    100   1.6      eeh #define	R_SPARC_REGISTER	53
    101   1.6      eeh #define	R_SPARC_UA64		54
    102   1.6      eeh #define	R_SPARC_UA16		55
    103   1.6      eeh 
    104  1.10    skrll /* TLS relocations */
    105  1.10    skrll #define R_SPARC_TLS_GD_HI22	56
    106  1.10    skrll #define R_SPARC_TLS_GD_LO10	57
    107  1.10    skrll #define R_SPARC_TLS_GD_ADD	58
    108  1.10    skrll #define R_SPARC_TLS_GD_CALL	59
    109  1.10    skrll #define R_SPARC_TLS_LDM_HI22	60
    110  1.10    skrll #define R_SPARC_TLS_LDM_LO10	61
    111  1.10    skrll #define R_SPARC_TLS_LDM_ADD	62
    112  1.10    skrll #define R_SPARC_TLS_LDM_CALL	63
    113  1.10    skrll #define R_SPARC_TLS_LDO_HIX22	64
    114  1.10    skrll #define R_SPARC_TLS_LDO_LOX10	65
    115  1.10    skrll #define R_SPARC_TLS_LDO_ADD	66
    116  1.10    skrll #define R_SPARC_TLS_IE_HI22	67
    117  1.10    skrll #define R_SPARC_TLS_IE_LO10	68
    118  1.10    skrll #define R_SPARC_TLS_IE_LD	69
    119  1.10    skrll #define R_SPARC_TLS_IE_LDX	70
    120  1.10    skrll #define R_SPARC_TLS_IE_ADD	71
    121  1.10    skrll #define R_SPARC_TLS_LE_HIX22	72
    122  1.10    skrll #define R_SPARC_TLS_LE_LOX10	73
    123  1.10    skrll #define R_SPARC_TLS_DTPMOD32	74
    124  1.10    skrll #define R_SPARC_TLS_DTPMOD64	75
    125  1.10    skrll #define R_SPARC_TLS_DTPOFF32	76
    126  1.10    skrll #define R_SPARC_TLS_DTPOFF64	77
    127  1.10    skrll #define R_SPARC_TLS_TPOFF32	78
    128  1.10    skrll #define R_SPARC_TLS_TPOFF64	79
    129   1.2      eeh 
    130   1.2      eeh #define R_TYPE(name)		__CONCAT(R_SPARC_,name)
    131