annotate usr/src/cmd/sgs/include/sparc/machdep_sparc.h @ 9085:ff7eb0bace56

6813909 generalize eh_frame support to non-amd64 platforms
author Ali Bahrami <Ali.Bahrami@Sun.COM>
date Wed, 18 Mar 2009 13:28:28 -0600
parents 0867fc633d66
children 47013accbd9c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
1 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
2 * CDDL HEADER START
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
3 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
4 * The contents of this file are subject to the terms of the
1618
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
5 * Common Development and Distribution License (the "License").
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
6 * You may not use this file except in compliance with the License.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
7 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
9 * or http://www.opensolaris.org/os/licensing.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
10 * See the License for the specific language governing permissions
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
11 * and limitations under the License.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
12 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
13 * When distributing Covered Code, include this CDDL HEADER in each
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
15 * If applicable, add the following below this CDDL HEADER, with the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
16 * fields enclosed by brackets "[]" replaced with your own identifying
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
17 * information: Portions Copyright [yyyy] [name of copyright owner]
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
18 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
19 * CDDL HEADER END
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
20 */
1618
8c9a4f31d225 6316708 LD_DEBUG should provide a means of identifying/isolating individual
rie
parents: 0
diff changeset
21
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
22 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
23 * Copyright (c) 1988 AT&T
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
24 * All Rights Reserved
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
25 *
8501
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
26 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
27 * Use is subject to license terms.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
28 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
29 * Global include file for all sgs SPARC machine dependent macros, constants
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
30 * and declarations.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
31 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
32
6206
6b0ed502a8e7 PSARC 2008/179 cross link-editor
ab196087
parents: 5152
diff changeset
33 #ifndef _MACHDEP_SPARC_H
6b0ed502a8e7 PSARC 2008/179 cross link-editor
ab196087
parents: 5152
diff changeset
34 #define _MACHDEP_SPARC_H
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
35
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
36 #include <link.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
37 #include <sys/machelf.h>
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
38
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
39 #ifdef __cplusplus
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
40 extern "C" {
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
41 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
42
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
43 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
44 * Elf header information.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
45 */
6206
6b0ed502a8e7 PSARC 2008/179 cross link-editor
ab196087
parents: 5152
diff changeset
46 #define M_MACH_32 EM_SPARC
6b0ed502a8e7 PSARC 2008/179 cross link-editor
ab196087
parents: 5152
diff changeset
47 #define M_MACH_64 EM_SPARCV9
6b0ed502a8e7 PSARC 2008/179 cross link-editor
ab196087
parents: 5152
diff changeset
48
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
49 #ifdef _ELF64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
50 #define M_MACH EM_SPARCV9
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
51 #define M_CLASS ELFCLASS64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
52 #else
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
53 #define M_MACH EM_SPARC
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
54 #define M_CLASS ELFCLASS32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
55 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
56 #define M_MACHPLUS EM_SPARC32PLUS
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
57 #define M_DATA ELFDATA2MSB
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
58 #define M_FLAGSPLUS EF_SPARC_32PLUS
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
59
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
60 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
61 * Page boundary Macros: truncate to previous page boundary and round to
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
62 * next page boundary (refer to generic macros in ../sgs.h also).
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
63 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
64 #define M_PTRUNC(X) ((X) & ~(syspagsz - 1))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
65 #define M_PROUND(X) (((X) + syspagsz - 1) & ~(syspagsz - 1))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
66
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
67 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
68 * Segment boundary macros: truncate to previous segment boundary and round
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
69 * to next page boundary.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
70 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
71 #ifndef M_SEGSIZE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
72 #define M_SEGSIZE ELF_SPARC_MAXPGSZ
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
73 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
74 #define M_STRUNC(X) ((X) & ~(M_SEGSIZE - 1))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
75 #define M_SROUND(X) (((X) + M_SEGSIZE - 1) & ~(M_SEGSIZE - 1))
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
76
8598
0867fc633d66 6686372 ld.so.1 should use mmapobj(2)
Rod Evans <Rod.Evans@Sun.COM>
parents: 8501
diff changeset
77 /*
0867fc633d66 6686372 ld.so.1 should use mmapobj(2)
Rod Evans <Rod.Evans@Sun.COM>
parents: 8501
diff changeset
78 * Relocation type macro.
0867fc633d66 6686372 ld.so.1 should use mmapobj(2)
Rod Evans <Rod.Evans@Sun.COM>
parents: 8501
diff changeset
79 */
0867fc633d66 6686372 ld.so.1 should use mmapobj(2)
Rod Evans <Rod.Evans@Sun.COM>
parents: 8501
diff changeset
80 #define M_RELOC Rela
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
81
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
82 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
83 * TLS static segments must be rounded to the following requirements,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
84 * due to libthread stack allocation.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
85 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
86 #if defined(_ELF64)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
87 #define M_TLSSTATALIGN 0x10
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
88 #else
2647
e440e3da2a6f 6464235 executing the 64-bit ld(1) should be easy
rie
parents: 1618
diff changeset
89 #define M_TLSSTATALIGN 0x08
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
90 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
91
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
92 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
93 * Instruction encodings.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
94 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
95 #define M_SAVESP64 0x9de3bfc0 /* save %sp, -64, %sp */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
96 #define M_CALL 0x40000000
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
97 #define M_JMPL 0x81c06000 /* jmpl %g1 + simm13, %g0 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
98 #define M_SETHIG0 0x01000000 /* sethi %hi(val), %g0 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
99 #define M_SETHIG1 0x03000000 /* sethi %hi(val), %g1 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
100 #define M_STO7G1IM 0xde206000 /* st %o7,[%g1 + %lo(val)] */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
101 #define M_SUBFPSPG1 0x8227800e /* sub %fp,%sp,%g1 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
102 #define M_NOP 0x01000000 /* sethi 0, %o0 (nop) */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
103 #define M_BA_A 0x30800000 /* ba,a */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
104 #define M_BA_A_PT 0x30480000 /* ba,a %icc, <dst> */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
105 #define M_MOVO7TOG1 0x8210000f /* mov %o7, %g1 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
106 #define M_MOVO7TOG5 0x8a10000f /* mov %o7, %g5 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
107 #define M_MOVI7TOG1 0x8210001f /* mov %i7, %g1 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
108 #define M_BA_A_XCC 0x30680000 /* ba,a %xcc */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
109 #define M_JMPL_G5G0 0x81c16000 /* jmpl %g5 + 0, %g0 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
110 #define M_XNOR_G5G1 0x82396000 /* xnor %g5, 0, %g1 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
111
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
112
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
113 #define M_BIND_ADJ 4 /* adjustment for end of */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
114 /* elf_rtbndr() address */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
115
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
116
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
117 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
118 * Plt and Got information; the first few .got and .plt entries are reserved
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
119 * PLT[0] jump to dynamic linker
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
120 * GOT[0] address of _DYNAMIC
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
121 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
122 #define M_PLT_INSSIZE 4 /* single plt instruction size */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
123 #define M_GOT_XDYNAMIC 0 /* got index for _DYNAMIC */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
124 #define M_GOT_XNumber 1 /* reserved no. of got entries */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
125
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
126 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
127 * ELF32 bit PLT constants
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
128 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
129 #define M32_PLT_ENTSIZE 12 /* 32bit plt entry size in bytes */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
130
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
131 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
132 * ELF64 bit PLT constants
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
133 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
134 #define M64_PLT_NEARPLTS 0x8000 /* # of NEAR PLTS we can have */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
135 #define M64_PLT_ENTSIZE 32 /* plt entry size in bytes */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
136 #define M64_PLT_FENTSIZE 24 /* size of far plt is 6 instructions */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
137 /* x 4bytes */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
138 #define M64_PLT_PSIZE 8 /* size of PLTP pointer */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
139 #define M64_PLT_FBLKCNTS 160 /* # of plts in far PLT blocks */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
140 #define M64_PLT_FBLOCKSZ (M64_PLT_FBLKCNTS *\
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
141 M64_PLT_ENTSIZE) /* size of far PLT block */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
142
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
143
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
144 #ifdef _ELF64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
145 #define M_PLT_ENTSIZE M64_PLT_ENTSIZE /* plt entry size in bytes */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
146 #define M_PLT_XNumber 4 /* reserved no. of plt entries */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
147 #define M_PLT_ALIGN 256 /* alignment of .plt section */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
148 #define M_PLT_RESERVSZ (M_PLT_XNumber * \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
149 M_PLT_ENTSIZE) /* first 4 plt's reserved */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
150 #define M_GOT_ENTSIZE 8 /* got entry size in bytes */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
151 #define M_GOT_MAXSMALL 1024 /* maximum no. of small gots */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
152 #else /* Elf32 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
153 #define M_PLT_ENTSIZE M32_PLT_ENTSIZE /* plt entry size in bytes */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
154 #define M_PLT_XNumber 4 /* reserved no. of plt entries */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
155 #define M_PLT_ALIGN M_WORD_ALIGN /* alignment of .plt section */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
156 #define M_PLT_RESERVSZ (M_PLT_XNumber * \
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
157 M_PLT_ENTSIZE) /* first 4 plt's reserved */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
158 #define M_GOT_ENTSIZE 4 /* got entry size in bytes */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
159 #define M_GOT_MAXSMALL 2048 /* maximum no. of small gots */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
160 #endif /* _ELF64 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
161 /* transition flags for got sizing */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
162 #define M_GOT_LARGE (Sword)(-M_GOT_MAXSMALL - 1)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
163 #define M_GOT_SMALL (Sword)(-M_GOT_MAXSMALL - 2)
5152
fa5ab16f3606 5035454 mixing -Kpic and -KPIC may cause SIGSEGV with -xarch=v9
ab196087
parents: 4665
diff changeset
164 #define M_GOT_MIXED (Sword)(-M_GOT_MAXSMALL - 3)
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
165
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
166
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
167 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
168 * Other machine dependent entities
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
169 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
170 #ifdef _ELF64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
171 #define M_SEGM_ALIGN ELF_SPARCV9_MAXPGSZ
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
172 /*
8501
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
173 * Put default 64-bit programs above 4 gigabytes to help insure correctness, so
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
174 * that any 64-bit programs that truncate pointers will fault now instead of
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
175 * corrupting itself and dying mysteriously. 64-bit programs can also be
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
176 * restricted to a 32-bit address space (SF1_SUNW_ADDR32), and these programs
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
177 * provide an alternative origin.
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
178 */
8501
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
179 #define M_SEGM_ORIGIN (Addr)0x100000000ULL /* default 1st segment origin */
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
180 #define M_SEGM_AORIGIN (Addr)0x100000ULL /* alternative 1st segment */
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
181 /* origin */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
182 #define M_WORD_ALIGN 8
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
183 #else
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
184 #define M_SEGM_ALIGN ELF_SPARC_MAXPGSZ
8501
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
185 #define M_SEGM_ORIGIN (Addr)0x10000 /* default 1st segment origin */
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
186 #define M_SEGM_AORIGIN M_SEGM_ORIGIN /* alternative 1st segment */
e544a13d2b41 6789925 64-bit applications with SF1_SUNW_ADDR32 require non-default starting address
Rod Evans <Rod.Evans@Sun.COM>
parents: 7833
diff changeset
187 /* origin */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
188 #define M_WORD_ALIGN 4
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
189 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
190
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
191 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
192 * Make common relocation information transparent to the common code
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
193 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
194 #define M_REL_DT_TYPE DT_RELA /* .dynamic entry */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
195 #define M_REL_DT_SIZE DT_RELASZ /* .dynamic entry */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
196 #define M_REL_DT_ENT DT_RELAENT /* .dynamic entry */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
197 #define M_REL_DT_COUNT DT_RELACOUNT /* .dynamic entry */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
198 #define M_REL_SHT_TYPE SHT_RELA /* section header type */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
199 #define M_REL_ELF_TYPE ELF_T_RELA /* data buffer type */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
200
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
201 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
202 * Make common relocation types transparent to the common code
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
203 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
204 #define M_R_NONE R_SPARC_NONE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
205 #define M_R_GLOB_DAT R_SPARC_GLOB_DAT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
206 #define M_R_COPY R_SPARC_COPY
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
207 #define M_R_RELATIVE R_SPARC_RELATIVE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
208 #define M_R_JMP_SLOT R_SPARC_JMP_SLOT
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
209 #define M_R_REGISTER R_SPARC_REGISTER
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
210 #define M_R_FPTR R_SPARC_NONE
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
211 #define M_R_NUM R_SPARC_NUM
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
212
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
213 #ifdef _ELF64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
214 #define M_R_ARRAYADDR R_SPARC_64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
215 #define M_R_DTPMOD R_SPARC_TLS_DTPMOD64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
216 #define M_R_DTPOFF R_SPARC_TLS_DTPOFF64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
217 #define M_R_TPOFF R_SPARC_TLS_TPOFF64
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
218 #else /* _ELF32 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
219 #define M_R_ARRAYADDR R_SPARC_32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
220 #define M_R_DTPMOD R_SPARC_TLS_DTPMOD32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
221 #define M_R_DTPOFF R_SPARC_TLS_DTPOFF32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
222 #define M_R_TPOFF R_SPARC_TLS_TPOFF32
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
223 #endif /* _ELF64 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
224
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
225
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
226 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
227 * Make register symbols transparent to common code
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
228 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
229 #define M_DT_REGISTER DT_SPARC_REGISTER
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
230
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
231 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
232 * Make plt section information transparent to the common code.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
233 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
234 #define M_PLT_SHF_FLAGS (SHF_ALLOC | SHF_WRITE | SHF_EXECINSTR)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
235
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
236 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
237 * Make data segment information transparent to the common code.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
238 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
239 #define M_DATASEG_PERM (PF_R | PF_W | PF_X)
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
240
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
241 /*
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
242 * Define a set of identifies for special sections. These allow the sections
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
243 * to be ordered within the output file image. These values should be
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
244 * maintained consistently, where appropriate, in each platform specific header
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
245 * file.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
246 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
247 * o null identifies that this section does not need to be added to the
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
248 * output image (ie. shared object sections or sections we're going to
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
249 * recreate (sym tables, string tables, relocations, etc.)).
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
250 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
251 * o any user defined section will be first in the associated segment.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
252 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
253 * o interp and capabilities sections are next, as these are accessed
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
254 * immediately the first page of the image is mapped.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
255 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
256 * o the syminfo, hash, dynsym, dynstr and rel's are grouped together as
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
257 * these will all be accessed first by ld.so.1 to perform relocations.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
258 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
259 * o the got, dynamic, and plt are grouped together as these may also be
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
260 * accessed first by ld.so.1 to perform relocations, fill in DT_DEBUG
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
261 * (executables only), and .plt[0].
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
262 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
263 * o unknown sections (stabs, comments etc.) go at the end.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
264 *
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
265 * Note that .tlsbss/.bss are given the largest identifiers. This insures that
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
266 * if any unknown sections become associated to the same segment as the .bss,
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
267 * the .bss sections are always the last section in the segment.
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
268 */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
269 #define M_ID_NULL 0x00
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
270 #define M_ID_USER 0x01
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
271
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
272 #define M_ID_INTERP 0x02 /* SHF_ALLOC */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
273 #define M_ID_CAP 0x03
9085
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
274 #define M_ID_UNWINDHDR 0x06
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
275 #define M_ID_UNWIND 0x07
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
276
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
277 #define M_ID_SYMINFO 0x08
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
278 #define M_ID_HASH 0x09
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
279 #define M_ID_LDYNSYM 0x0a /* always right before DYNSYM */
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
280 #define M_ID_DYNSYM 0x0b
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
281 #define M_ID_DYNSTR 0x0c
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
282 #define M_ID_VERSION 0x0d
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
283 #define M_ID_DYNSORT 0x0e
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
284 #define M_ID_REL 0x0f
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
285 #define M_ID_TEXT 0x10 /* SHF_ALLOC + SHF_EXECINSTR */
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
286 #define M_ID_DATA 0x20
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
287
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
288 /* M_ID_USER 0x01 dual entry - listed above */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
289 #define M_ID_GOTDATA 0x02 /* SHF_ALLOC + SHF_WRITE */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
290 #define M_ID_GOT 0x03
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
291 #define M_ID_PLT 0x04
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
292 #define M_ID_DYNAMIC 0x05
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
293 #define M_ID_ARRAY 0x06
9085
ff7eb0bace56 6813909 generalize eh_frame support to non-amd64 platforms
Ali Bahrami <Ali.Bahrami@Sun.COM>
parents: 8598
diff changeset
294 /* M_ID_UNWIND 0x07 dual entry - listed above */
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
295
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
296 #define M_ID_UNKNOWN 0xfc /* just before TLS */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
297
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
298 #define M_ID_TLS 0xfd /* just before bss */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
299 #define M_ID_TLSBSS 0xfe
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
300 #define M_ID_BSS 0xff
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
301
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
302 #define M_ID_SYMTAB_NDX 0x02 /* ! SHF_ALLOC */
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
303 #define M_ID_SYMTAB 0x03
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
304 #define M_ID_STRTAB 0x04
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
305 #define M_ID_DYNSYM_NDX 0x05
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
306 #define M_ID_NOTE 0x06
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
307
6206
6b0ed502a8e7 PSARC 2008/179 cross link-editor
ab196087
parents: 5152
diff changeset
308
0
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
309 #ifdef __cplusplus
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
310 }
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
311 #endif
68f95e015346 OpenSolaris Launch
stevel@tonic-gate
parents:
diff changeset
312
6206
6b0ed502a8e7 PSARC 2008/179 cross link-editor
ab196087
parents: 5152
diff changeset
313 #endif /* _MACHDEP_SPARC_H */