1*0Sstevel@tonic-gate /* 2*0Sstevel@tonic-gate * CDDL HEADER START 3*0Sstevel@tonic-gate * 4*0Sstevel@tonic-gate * The contents of this file are subject to the terms of the 5*0Sstevel@tonic-gate * Common Development and Distribution License, Version 1.0 only 6*0Sstevel@tonic-gate * (the "License"). You may not use this file except in compliance 7*0Sstevel@tonic-gate * with the License. 8*0Sstevel@tonic-gate * 9*0Sstevel@tonic-gate * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 10*0Sstevel@tonic-gate * or http://www.opensolaris.org/os/licensing. 11*0Sstevel@tonic-gate * See the License for the specific language governing permissions 12*0Sstevel@tonic-gate * and limitations under the License. 13*0Sstevel@tonic-gate * 14*0Sstevel@tonic-gate * When distributing Covered Code, include this CDDL HEADER in each 15*0Sstevel@tonic-gate * file and include the License file at usr/src/OPENSOLARIS.LICENSE. 16*0Sstevel@tonic-gate * If applicable, add the following below this CDDL HEADER, with the 17*0Sstevel@tonic-gate * fields enclosed by brackets "[]" replaced with your own identifying 18*0Sstevel@tonic-gate * information: Portions Copyright [yyyy] [name of copyright owner] 19*0Sstevel@tonic-gate * 20*0Sstevel@tonic-gate * CDDL HEADER END 21*0Sstevel@tonic-gate */ 22*0Sstevel@tonic-gate /* 23*0Sstevel@tonic-gate * Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T 24*0Sstevel@tonic-gate * All Rights Reserved 25*0Sstevel@tonic-gate * 26*0Sstevel@tonic-gate * 27*0Sstevel@tonic-gate * Copyright 2003 Sun Microsystems, Inc. All rights reserved. 28*0Sstevel@tonic-gate * Use is subject to license terms. 29*0Sstevel@tonic-gate */ 30*0Sstevel@tonic-gate 31*0Sstevel@tonic-gate #ifndef _SYS_ELF_SPARC_H 32*0Sstevel@tonic-gate #define _SYS_ELF_SPARC_H 33*0Sstevel@tonic-gate 34*0Sstevel@tonic-gate #pragma ident "%Z%%M% %I% %E% SMI" /* SVr4.0 1.2 */ 35*0Sstevel@tonic-gate 36*0Sstevel@tonic-gate #ifdef __cplusplus 37*0Sstevel@tonic-gate extern "C" { 38*0Sstevel@tonic-gate #endif 39*0Sstevel@tonic-gate 40*0Sstevel@tonic-gate #define EF_SPARC_32PLUS_MASK 0xffff00 /* bits indicating V8+ type */ 41*0Sstevel@tonic-gate #define EF_SPARC_32PLUS 0x000100 /* generic V8+ features */ 42*0Sstevel@tonic-gate #define EF_SPARC_EXT_MASK 0xffff00 /* bits for vendor extensions */ 43*0Sstevel@tonic-gate #define EF_SPARC_SUN_US1 0x000200 /* Sun UltraSPARC1 extensions */ 44*0Sstevel@tonic-gate #define EF_SPARC_HAL_R1 0x000400 /* HAL R1 extensions */ 45*0Sstevel@tonic-gate #define EF_SPARC_SUN_US3 0x000800 /* Sun UltraSPARC3 extensions */ 46*0Sstevel@tonic-gate 47*0Sstevel@tonic-gate #define EF_SPARCV9_MM 0x3 /* mask for memory model */ 48*0Sstevel@tonic-gate #define EF_SPARCV9_TSO 0x0 /* total store ordering */ 49*0Sstevel@tonic-gate #define EF_SPARCV9_PSO 0x1 /* partial store ordering */ 50*0Sstevel@tonic-gate #define EF_SPARCV9_RMO 0x2 /* relaxed memory ordering */ 51*0Sstevel@tonic-gate 52*0Sstevel@tonic-gate #define R_SPARC_NONE 0 /* relocation type */ 53*0Sstevel@tonic-gate #define R_SPARC_8 1 54*0Sstevel@tonic-gate #define R_SPARC_16 2 55*0Sstevel@tonic-gate #define R_SPARC_32 3 56*0Sstevel@tonic-gate #define R_SPARC_DISP8 4 57*0Sstevel@tonic-gate #define R_SPARC_DISP16 5 58*0Sstevel@tonic-gate #define R_SPARC_DISP32 6 59*0Sstevel@tonic-gate #define R_SPARC_WDISP30 7 60*0Sstevel@tonic-gate #define R_SPARC_WDISP22 8 61*0Sstevel@tonic-gate #define R_SPARC_HI22 9 62*0Sstevel@tonic-gate #define R_SPARC_22 10 63*0Sstevel@tonic-gate #define R_SPARC_13 11 64*0Sstevel@tonic-gate #define R_SPARC_LO10 12 65*0Sstevel@tonic-gate #define R_SPARC_GOT10 13 66*0Sstevel@tonic-gate #define R_SPARC_GOT13 14 67*0Sstevel@tonic-gate #define R_SPARC_GOT22 15 68*0Sstevel@tonic-gate #define R_SPARC_PC10 16 69*0Sstevel@tonic-gate #define R_SPARC_PC22 17 70*0Sstevel@tonic-gate #define R_SPARC_WPLT30 18 71*0Sstevel@tonic-gate #define R_SPARC_COPY 19 72*0Sstevel@tonic-gate #define R_SPARC_GLOB_DAT 20 73*0Sstevel@tonic-gate #define R_SPARC_JMP_SLOT 21 74*0Sstevel@tonic-gate #define R_SPARC_RELATIVE 22 75*0Sstevel@tonic-gate #define R_SPARC_UA32 23 76*0Sstevel@tonic-gate #define R_SPARC_PLT32 24 77*0Sstevel@tonic-gate #define R_SPARC_HIPLT22 25 78*0Sstevel@tonic-gate #define R_SPARC_LOPLT10 26 79*0Sstevel@tonic-gate #define R_SPARC_PCPLT32 27 80*0Sstevel@tonic-gate #define R_SPARC_PCPLT22 28 81*0Sstevel@tonic-gate #define R_SPARC_PCPLT10 29 82*0Sstevel@tonic-gate #define R_SPARC_10 30 83*0Sstevel@tonic-gate #define R_SPARC_11 31 84*0Sstevel@tonic-gate #define R_SPARC_64 32 85*0Sstevel@tonic-gate #define R_SPARC_OLO10 33 86*0Sstevel@tonic-gate #define R_SPARC_HH22 34 87*0Sstevel@tonic-gate #define R_SPARC_HM10 35 88*0Sstevel@tonic-gate #define R_SPARC_LM22 36 89*0Sstevel@tonic-gate #define R_SPARC_PC_HH22 37 90*0Sstevel@tonic-gate #define R_SPARC_PC_HM10 38 91*0Sstevel@tonic-gate #define R_SPARC_PC_LM22 39 92*0Sstevel@tonic-gate #define R_SPARC_WDISP16 40 93*0Sstevel@tonic-gate #define R_SPARC_WDISP19 41 94*0Sstevel@tonic-gate #define R_SPARC_GLOB_JMP 42 95*0Sstevel@tonic-gate #define R_SPARC_7 43 96*0Sstevel@tonic-gate #define R_SPARC_5 44 97*0Sstevel@tonic-gate #define R_SPARC_6 45 98*0Sstevel@tonic-gate #define R_SPARC_DISP64 46 99*0Sstevel@tonic-gate #define R_SPARC_PLT64 47 100*0Sstevel@tonic-gate #define R_SPARC_HIX22 48 101*0Sstevel@tonic-gate #define R_SPARC_LOX10 49 102*0Sstevel@tonic-gate #define R_SPARC_H44 50 103*0Sstevel@tonic-gate #define R_SPARC_M44 51 104*0Sstevel@tonic-gate #define R_SPARC_L44 52 105*0Sstevel@tonic-gate #define R_SPARC_REGISTER 53 106*0Sstevel@tonic-gate #define R_SPARC_UA64 54 107*0Sstevel@tonic-gate #define R_SPARC_UA16 55 108*0Sstevel@tonic-gate #define R_SPARC_TLS_GD_HI22 56 109*0Sstevel@tonic-gate #define R_SPARC_TLS_GD_LO10 57 110*0Sstevel@tonic-gate #define R_SPARC_TLS_GD_ADD 58 111*0Sstevel@tonic-gate #define R_SPARC_TLS_GD_CALL 59 112*0Sstevel@tonic-gate #define R_SPARC_TLS_LDM_HI22 60 113*0Sstevel@tonic-gate #define R_SPARC_TLS_LDM_LO10 61 114*0Sstevel@tonic-gate #define R_SPARC_TLS_LDM_ADD 62 115*0Sstevel@tonic-gate #define R_SPARC_TLS_LDM_CALL 63 116*0Sstevel@tonic-gate #define R_SPARC_TLS_LDO_HIX22 64 117*0Sstevel@tonic-gate #define R_SPARC_TLS_LDO_LOX10 65 118*0Sstevel@tonic-gate #define R_SPARC_TLS_LDO_ADD 66 119*0Sstevel@tonic-gate #define R_SPARC_TLS_IE_HI22 67 120*0Sstevel@tonic-gate #define R_SPARC_TLS_IE_LO10 68 121*0Sstevel@tonic-gate #define R_SPARC_TLS_IE_LD 69 122*0Sstevel@tonic-gate #define R_SPARC_TLS_IE_LDX 70 123*0Sstevel@tonic-gate #define R_SPARC_TLS_IE_ADD 71 124*0Sstevel@tonic-gate #define R_SPARC_TLS_LE_HIX22 72 125*0Sstevel@tonic-gate #define R_SPARC_TLS_LE_LOX10 73 126*0Sstevel@tonic-gate #define R_SPARC_TLS_DTPMOD32 74 127*0Sstevel@tonic-gate #define R_SPARC_TLS_DTPMOD64 75 128*0Sstevel@tonic-gate #define R_SPARC_TLS_DTPOFF32 76 129*0Sstevel@tonic-gate #define R_SPARC_TLS_DTPOFF64 77 130*0Sstevel@tonic-gate #define R_SPARC_TLS_TPOFF32 78 131*0Sstevel@tonic-gate #define R_SPARC_TLS_TPOFF64 79 132*0Sstevel@tonic-gate #define R_SPARC_GOTDATA_HIX22 80 133*0Sstevel@tonic-gate #define R_SPARC_GOTDATA_LOX10 81 134*0Sstevel@tonic-gate #define R_SPARC_GOTDATA_OP_HIX22 82 135*0Sstevel@tonic-gate #define R_SPARC_GOTDATA_OP_LOX10 83 136*0Sstevel@tonic-gate #define R_SPARC_GOTDATA_OP 84 137*0Sstevel@tonic-gate #define R_SPARC_H34 85 138*0Sstevel@tonic-gate #define R_SPARC_NUM 86 /* must be >last */ 139*0Sstevel@tonic-gate 140*0Sstevel@tonic-gate /* 141*0Sstevel@tonic-gate * Relocation aliases 142*0Sstevel@tonic-gate */ 143*0Sstevel@tonic-gate #define R_SPARC_L34 R_SPARC_L44 /* associated with R_SPARC_H34 */ 144*0Sstevel@tonic-gate /* same calc as R_SPARC_L44 */ 145*0Sstevel@tonic-gate 146*0Sstevel@tonic-gate #define ELF_SPARC_MAXPGSZ 0x10000 /* maximum page size */ 147*0Sstevel@tonic-gate #define ELF_SPARCV9_MAXPGSZ 0x100000 148*0Sstevel@tonic-gate 149*0Sstevel@tonic-gate /* 150*0Sstevel@tonic-gate * Processor specific section types 151*0Sstevel@tonic-gate */ 152*0Sstevel@tonic-gate #define SHT_SPARC_GOTDATA 0x70000000 153*0Sstevel@tonic-gate 154*0Sstevel@tonic-gate #define SHF_ORDERED 0x40000000 155*0Sstevel@tonic-gate #define SHF_EXCLUDE 0x80000000 156*0Sstevel@tonic-gate 157*0Sstevel@tonic-gate #define SHN_BEFORE 0xff00 158*0Sstevel@tonic-gate #define SHN_AFTER 0xff01 159*0Sstevel@tonic-gate 160*0Sstevel@tonic-gate #define STT_SPARC_REGISTER 13 /* register symbol type */ 161*0Sstevel@tonic-gate 162*0Sstevel@tonic-gate #define DT_SPARC_REGISTER 0x70000001 /* identifies register */ 163*0Sstevel@tonic-gate /* symbols */ 164*0Sstevel@tonic-gate 165*0Sstevel@tonic-gate 166*0Sstevel@tonic-gate /* 167*0Sstevel@tonic-gate * Register symbol numbers - to be used in the st_value field 168*0Sstevel@tonic-gate * of register symbols. 169*0Sstevel@tonic-gate */ 170*0Sstevel@tonic-gate #define STO_SPARC_REGISTER_G1 0x1 /* register %g1 */ 171*0Sstevel@tonic-gate #define STO_SPARC_REGISTER_G2 0x2 /* register %g2 */ 172*0Sstevel@tonic-gate #define STO_SPARC_REGISTER_G3 0x3 /* register %g3 */ 173*0Sstevel@tonic-gate #define STO_SPARC_REGISTER_G4 0x4 /* register %g4 */ 174*0Sstevel@tonic-gate #define STO_SPARC_REGISTER_G5 0x5 /* register %g5 */ 175*0Sstevel@tonic-gate #define STO_SPARC_REGISTER_G6 0x6 /* register %g6 */ 176*0Sstevel@tonic-gate #define STO_SPARC_REGISTER_G7 0x7 /* register %g7 */ 177*0Sstevel@tonic-gate 178*0Sstevel@tonic-gate 179*0Sstevel@tonic-gate #ifdef __cplusplus 180*0Sstevel@tonic-gate } 181*0Sstevel@tonic-gate #endif 182*0Sstevel@tonic-gate 183*0Sstevel@tonic-gate #endif /* _SYS_ELF_SPARC_H */ 184