xref: /onnv-gate/usr/src/uts/common/sys/link.h (revision 0:68f95e015346)
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 /*	Copyright (c) 1988 AT&T	*/
23*0Sstevel@tonic-gate /*	  All Rights Reserved  	*/
24*0Sstevel@tonic-gate 
25*0Sstevel@tonic-gate 
26*0Sstevel@tonic-gate /*
27*0Sstevel@tonic-gate  * Copyright 2005 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_LINK_H
32*0Sstevel@tonic-gate #define	_SYS_LINK_H
33*0Sstevel@tonic-gate 
34*0Sstevel@tonic-gate #pragma ident	"%Z%%M%	%I%	%E% SMI"
35*0Sstevel@tonic-gate 
36*0Sstevel@tonic-gate #ifndef	_ASM
37*0Sstevel@tonic-gate #include <sys/types.h>
38*0Sstevel@tonic-gate #include <sys/elftypes.h>
39*0Sstevel@tonic-gate #endif
40*0Sstevel@tonic-gate 
41*0Sstevel@tonic-gate #ifdef	__cplusplus
42*0Sstevel@tonic-gate extern "C" {
43*0Sstevel@tonic-gate #endif
44*0Sstevel@tonic-gate 
45*0Sstevel@tonic-gate /*
46*0Sstevel@tonic-gate  * Communication structures for the runtime linker.
47*0Sstevel@tonic-gate  */
48*0Sstevel@tonic-gate 
49*0Sstevel@tonic-gate /*
50*0Sstevel@tonic-gate  * The following data structure provides a self-identifying union consisting
51*0Sstevel@tonic-gate  * of a tag from a known list and a value.
52*0Sstevel@tonic-gate  */
53*0Sstevel@tonic-gate #ifndef	_ASM
54*0Sstevel@tonic-gate typedef struct {
55*0Sstevel@tonic-gate 	Elf32_Sword d_tag;		/* how to interpret value */
56*0Sstevel@tonic-gate 	union {
57*0Sstevel@tonic-gate 		Elf32_Word	d_val;
58*0Sstevel@tonic-gate 		Elf32_Addr	d_ptr;
59*0Sstevel@tonic-gate 		Elf32_Off	d_off;
60*0Sstevel@tonic-gate 	} d_un;
61*0Sstevel@tonic-gate } Elf32_Dyn;
62*0Sstevel@tonic-gate 
63*0Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE)
64*0Sstevel@tonic-gate typedef struct {
65*0Sstevel@tonic-gate 	Elf64_Xword d_tag;		/* how to interpret value */
66*0Sstevel@tonic-gate 	union {
67*0Sstevel@tonic-gate 		Elf64_Xword	d_val;
68*0Sstevel@tonic-gate 		Elf64_Addr	d_ptr;
69*0Sstevel@tonic-gate 	} d_un;
70*0Sstevel@tonic-gate } Elf64_Dyn;
71*0Sstevel@tonic-gate #endif	/* defined(_LP64) || defined(_LONGLONG_TYPE) */
72*0Sstevel@tonic-gate #endif	/* _ASM */
73*0Sstevel@tonic-gate 
74*0Sstevel@tonic-gate /*
75*0Sstevel@tonic-gate  * Tag values
76*0Sstevel@tonic-gate  */
77*0Sstevel@tonic-gate #define	DT_NULL		0	/* last entry in list */
78*0Sstevel@tonic-gate #define	DT_NEEDED	1	/* a needed object */
79*0Sstevel@tonic-gate #define	DT_PLTRELSZ	2	/* size of relocations for the PLT */
80*0Sstevel@tonic-gate #define	DT_PLTGOT	3	/* addresses used by procedure linkage table */
81*0Sstevel@tonic-gate #define	DT_HASH		4	/* hash table */
82*0Sstevel@tonic-gate #define	DT_STRTAB	5	/* string table */
83*0Sstevel@tonic-gate #define	DT_SYMTAB	6	/* symbol table */
84*0Sstevel@tonic-gate #define	DT_RELA		7	/* addr of relocation entries */
85*0Sstevel@tonic-gate #define	DT_RELASZ	8	/* size of relocation table */
86*0Sstevel@tonic-gate #define	DT_RELAENT	9	/* base size of relocation entry */
87*0Sstevel@tonic-gate #define	DT_STRSZ	10	/* size of string table */
88*0Sstevel@tonic-gate #define	DT_SYMENT	11	/* size of symbol table entry */
89*0Sstevel@tonic-gate #define	DT_INIT		12	/* _init addr */
90*0Sstevel@tonic-gate #define	DT_FINI		13	/* _fini addr */
91*0Sstevel@tonic-gate #define	DT_SONAME	14	/* name of this shared object */
92*0Sstevel@tonic-gate #define	DT_RPATH	15	/* run-time search path */
93*0Sstevel@tonic-gate #define	DT_SYMBOLIC	16	/* shared object linked -Bsymbolic */
94*0Sstevel@tonic-gate #define	DT_REL		17	/* addr of relocation entries */
95*0Sstevel@tonic-gate #define	DT_RELSZ	18	/* size of relocation table */
96*0Sstevel@tonic-gate #define	DT_RELENT	19	/* base size of relocation entry */
97*0Sstevel@tonic-gate #define	DT_PLTREL	20	/* relocation type for PLT entry */
98*0Sstevel@tonic-gate #define	DT_DEBUG	21	/* pointer to r_debug structure */
99*0Sstevel@tonic-gate #define	DT_TEXTREL	22	/* text relocations remain for this object */
100*0Sstevel@tonic-gate #define	DT_JMPREL	23	/* pointer to the PLT relocation entries */
101*0Sstevel@tonic-gate #define	DT_BIND_NOW	24	/* perform all relocations at load of object */
102*0Sstevel@tonic-gate #define	DT_INIT_ARRAY	25	/* pointer to .initarray */
103*0Sstevel@tonic-gate #define	DT_FINI_ARRAY	26	/* pointer to .finiarray */
104*0Sstevel@tonic-gate #define	DT_INIT_ARRAYSZ	27	/* size of .initarray */
105*0Sstevel@tonic-gate #define	DT_FINI_ARRAYSZ	28	/* size of .finiarray */
106*0Sstevel@tonic-gate #define	DT_RUNPATH	29	/* run-time search path */
107*0Sstevel@tonic-gate #define	DT_FLAGS	30	/* state flags - see DF_* */
108*0Sstevel@tonic-gate 
109*0Sstevel@tonic-gate #define	DT_ENCODING		32    /* DT_* encoding rules start after this */
110*0Sstevel@tonic-gate #define	DT_PREINIT_ARRAY	32    /* pointer to .preinitarray segment */
111*0Sstevel@tonic-gate #define	DT_PREINIT_ARRAYSZ	33    /* size of .preinitarray segment */
112*0Sstevel@tonic-gate 
113*0Sstevel@tonic-gate #define	DT_MAXPOSTAGS		34	/* number of positive tags */
114*0Sstevel@tonic-gate 
115*0Sstevel@tonic-gate #define	DT_LOOS			0x6000000d	/* OS specific range */
116*0Sstevel@tonic-gate #define	DT_SUNW_AUXILIARY	0x6000000d	/* symbol auxiliary name */
117*0Sstevel@tonic-gate #define	DT_SUNW_RTLDINF		0x6000000e	/* ld.so.1 info (private) */
118*0Sstevel@tonic-gate #define	DT_SUNW_FILTER		0x6000000f	/* symbol filter name */
119*0Sstevel@tonic-gate #define	DT_SUNW_CAP		0x60000010	/* hardware/software */
120*0Sstevel@tonic-gate 						/*	capabilities */
121*0Sstevel@tonic-gate #define	DT_HIOS			0x6ffff000
122*0Sstevel@tonic-gate 
123*0Sstevel@tonic-gate /*
124*0Sstevel@tonic-gate  * The following values have been deprecated and remain here to allow
125*0Sstevel@tonic-gate  * compatibility with older binaries.
126*0Sstevel@tonic-gate  */
127*0Sstevel@tonic-gate #define	DT_DEPRECATED_SPARC_REGISTER	0x7000001
128*0Sstevel@tonic-gate 
129*0Sstevel@tonic-gate /*
130*0Sstevel@tonic-gate  * DT_* entries which fall between DT_VALRNGHI & DT_VALRNGLO use the
131*0Sstevel@tonic-gate  * Dyn.d_un.d_val field of the Elf*_Dyn structure.
132*0Sstevel@tonic-gate  */
133*0Sstevel@tonic-gate #define	DT_VALRNGLO	0x6ffffd00
134*0Sstevel@tonic-gate #define	DT_CHECKSUM	0x6ffffdf8	/* elf checksum */
135*0Sstevel@tonic-gate #define	DT_PLTPADSZ	0x6ffffdf9	/* pltpadding size */
136*0Sstevel@tonic-gate #define	DT_MOVEENT	0x6ffffdfa	/* move table entry size */
137*0Sstevel@tonic-gate #define	DT_MOVESZ	0x6ffffdfb	/* move table size */
138*0Sstevel@tonic-gate #define	DT_FEATURE_1	0x6ffffdfc	/* feature holder */
139*0Sstevel@tonic-gate #define	DT_POSFLAG_1	0x6ffffdfd	/* flags for DT_* entries, effecting */
140*0Sstevel@tonic-gate 					/*	the following DT_* entry. */
141*0Sstevel@tonic-gate 					/*	See DF_P1_* definitions */
142*0Sstevel@tonic-gate #define	DT_SYMINSZ	0x6ffffdfe	/* syminfo table size (in bytes) */
143*0Sstevel@tonic-gate #define	DT_SYMINENT	0x6ffffdff	/* syminfo entry size (in bytes) */
144*0Sstevel@tonic-gate #define	DT_VALRNGHI	0x6ffffdff
145*0Sstevel@tonic-gate 
146*0Sstevel@tonic-gate /*
147*0Sstevel@tonic-gate  * DT_* entries which fall between DT_ADDRRNGHI & DT_ADDRRNGLO use the
148*0Sstevel@tonic-gate  * Dyn.d_un.d_ptr field of the Elf*_Dyn structure.
149*0Sstevel@tonic-gate  *
150*0Sstevel@tonic-gate  * If any adjustment is made to the ELF object after it has been
151*0Sstevel@tonic-gate  * built, these entries will need to be adjusted.
152*0Sstevel@tonic-gate  */
153*0Sstevel@tonic-gate #define	DT_ADDRRNGLO	0x6ffffe00
154*0Sstevel@tonic-gate #define	DT_CONFIG	0x6ffffefa	/* configuration information */
155*0Sstevel@tonic-gate #define	DT_DEPAUDIT	0x6ffffefb	/* dependency auditing */
156*0Sstevel@tonic-gate #define	DT_AUDIT	0x6ffffefc	/* object auditing */
157*0Sstevel@tonic-gate #define	DT_PLTPAD	0x6ffffefd	/* pltpadding (sparcv9) */
158*0Sstevel@tonic-gate #define	DT_MOVETAB	0x6ffffefe	/* move table */
159*0Sstevel@tonic-gate #define	DT_SYMINFO	0x6ffffeff	/* syminfo table */
160*0Sstevel@tonic-gate #define	DT_ADDRRNGHI	0x6ffffeff
161*0Sstevel@tonic-gate 
162*0Sstevel@tonic-gate /*
163*0Sstevel@tonic-gate  * The following DT_* entries should have been assigned within one of the
164*0Sstevel@tonic-gate  * DT_* ranges, but existed before such ranges had been established.
165*0Sstevel@tonic-gate  */
166*0Sstevel@tonic-gate #define	DT_VERSYM	0x6ffffff0	/* version symbol table - unused */
167*0Sstevel@tonic-gate 
168*0Sstevel@tonic-gate #define	DT_RELACOUNT	0x6ffffff9	/* number of RELATIVE relocations */
169*0Sstevel@tonic-gate #define	DT_RELCOUNT	0x6ffffffa	/* number of RELATIVE relocations */
170*0Sstevel@tonic-gate #define	DT_FLAGS_1	0x6ffffffb	/* state flags - see DF_1_* defs */
171*0Sstevel@tonic-gate #define	DT_VERDEF	0x6ffffffc	/* version definition table and */
172*0Sstevel@tonic-gate #define	DT_VERDEFNUM	0x6ffffffd	/*	associated no. of entries */
173*0Sstevel@tonic-gate #define	DT_VERNEED	0x6ffffffe	/* version needed table and */
174*0Sstevel@tonic-gate #define	DT_VERNEEDNUM	0x6fffffff	/* 	associated no. of entries */
175*0Sstevel@tonic-gate 
176*0Sstevel@tonic-gate /*
177*0Sstevel@tonic-gate  * DT_* entries between DT_HIPROC and DT_LOPROC are reserved for processor
178*0Sstevel@tonic-gate  * specific semantics.
179*0Sstevel@tonic-gate  */
180*0Sstevel@tonic-gate #define	DT_LOPROC	0x70000000	/* processor specific range */
181*0Sstevel@tonic-gate #define	DT_AUXILIARY	0x7ffffffd	/* shared library auxiliary name */
182*0Sstevel@tonic-gate #define	DT_USED		0x7ffffffe	/* ignored - same as needed */
183*0Sstevel@tonic-gate #define	DT_FILTER	0x7fffffff	/* shared library filter name */
184*0Sstevel@tonic-gate #define	DT_HIPROC	0x7fffffff
185*0Sstevel@tonic-gate 
186*0Sstevel@tonic-gate 
187*0Sstevel@tonic-gate /*
188*0Sstevel@tonic-gate  * Values for DT_FLAGS
189*0Sstevel@tonic-gate  */
190*0Sstevel@tonic-gate #define	DF_ORIGIN	0x00000001	/* ORIGIN processing required */
191*0Sstevel@tonic-gate #define	DF_SYMBOLIC	0x00000002	/* symbolic bindings in effect */
192*0Sstevel@tonic-gate #define	DF_TEXTREL	0x00000004	/* text relocations remain */
193*0Sstevel@tonic-gate #define	DF_BIND_NOW	0x00000008	/* process all relocations */
194*0Sstevel@tonic-gate #define	DF_STATIC_TLS	0x00000010	/* obj. contains static TLS refs */
195*0Sstevel@tonic-gate 
196*0Sstevel@tonic-gate /*
197*0Sstevel@tonic-gate  * Values for the DT_POSFLAG_1 .dynamic entry.
198*0Sstevel@tonic-gate  * These values only affect the following DT_* entry.
199*0Sstevel@tonic-gate  */
200*0Sstevel@tonic-gate #define	DF_P1_LAZYLOAD	0x00000001	/* following object is to be */
201*0Sstevel@tonic-gate 					/*	lazy loaded */
202*0Sstevel@tonic-gate #define	DF_P1_GROUPPERM	0x00000002	/* following object's symbols are */
203*0Sstevel@tonic-gate 					/*	not available for general */
204*0Sstevel@tonic-gate 					/*	symbol bindings. */
205*0Sstevel@tonic-gate /*
206*0Sstevel@tonic-gate  * Values for the DT_FLAGS_1 .dynamic entry.
207*0Sstevel@tonic-gate  */
208*0Sstevel@tonic-gate #define	DF_1_NOW	0x00000001	/* set RTLD_NOW for this object */
209*0Sstevel@tonic-gate #define	DF_1_GLOBAL	0x00000002	/* set RTLD_GLOBAL for this object */
210*0Sstevel@tonic-gate #define	DF_1_GROUP	0x00000004	/* set RTLD_GROUP for this object */
211*0Sstevel@tonic-gate #define	DF_1_NODELETE	0x00000008	/* set RTLD_NODELETE for this object */
212*0Sstevel@tonic-gate #define	DF_1_LOADFLTR	0x00000010	/* trigger filtee loading at runtime */
213*0Sstevel@tonic-gate #define	DF_1_INITFIRST	0x00000020	/* set RTLD_INITFIRST for this object */
214*0Sstevel@tonic-gate #define	DF_1_NOOPEN	0x00000040	/* set RTLD_NOOPEN for this object */
215*0Sstevel@tonic-gate #define	DF_1_ORIGIN	0x00000080	/* ORIGIN processing required */
216*0Sstevel@tonic-gate #define	DF_1_DIRECT	0x00000100	/* direct binding enabled */
217*0Sstevel@tonic-gate #define	DF_1_TRANS	0x00000200
218*0Sstevel@tonic-gate #define	DF_1_INTERPOSE	0x00000400	/* object is an 'interposer' */
219*0Sstevel@tonic-gate #define	DF_1_NODEFLIB	0x00000800	/* ignore default library search path */
220*0Sstevel@tonic-gate #define	DF_1_NODUMP	0x00001000	/* object can't be dldump(3x)'ed */
221*0Sstevel@tonic-gate #define	DF_1_CONFALT	0x00002000	/* configuration alternative created */
222*0Sstevel@tonic-gate #define	DF_1_ENDFILTEE	0x00004000	/* filtee terminates filters search */
223*0Sstevel@tonic-gate #define	DF_1_DISPRELDNE	0x00008000	/* disp reloc applied at build time */
224*0Sstevel@tonic-gate #define	DF_1_DISPRELPND	0x00010000	/* disp reloc applied at run-time */
225*0Sstevel@tonic-gate #define	DF_1_NODIRECT	0x00020000	/* object contains symbols that */
226*0Sstevel@tonic-gate 					/*	cannot be directly bound to */
227*0Sstevel@tonic-gate #define	DF_1_IGNMULDEF	0x00040000	/* krtld link should muldef'd syms */
228*0Sstevel@tonic-gate #define	DF_1_NOKSYMS	0x00080000	/* object's symbols should not be */
229*0Sstevel@tonic-gate 					/*	exported via /dev/ksyms */
230*0Sstevel@tonic-gate #define	DF_1_NORELOC	0x00400000
231*0Sstevel@tonic-gate 
232*0Sstevel@tonic-gate /*
233*0Sstevel@tonic-gate  * Values set to DT_FEATURE tag's d_val.
234*0Sstevel@tonic-gate  */
235*0Sstevel@tonic-gate #define	DTF_1_PARINIT	0x00000001	/* partially initialization feature */
236*0Sstevel@tonic-gate #define	DTF_1_CONFEXP	0x00000002	/* configuration file expected */
237*0Sstevel@tonic-gate 
238*0Sstevel@tonic-gate 
239*0Sstevel@tonic-gate /*
240*0Sstevel@tonic-gate  * Version structures.  There are three types of version structure:
241*0Sstevel@tonic-gate  *
242*0Sstevel@tonic-gate  *  o	A definition of the versions within the image itself.
243*0Sstevel@tonic-gate  *	Each version definition is assigned a unique index (starting from
244*0Sstevel@tonic-gate  *	VER_NDX_BGNDEF)	which is used to cross-reference symbols associated to
245*0Sstevel@tonic-gate  *	the version.  Each version can have one or more dependencies on other
246*0Sstevel@tonic-gate  *	version definitions within the image.  The version name, and any
247*0Sstevel@tonic-gate  *	dependency names, are specified in the version definition auxiliary
248*0Sstevel@tonic-gate  *	array.  Version definition entries require a version symbol index table.
249*0Sstevel@tonic-gate  *
250*0Sstevel@tonic-gate  *  o	A version requirement on a needed dependency.  Each needed entry
251*0Sstevel@tonic-gate  *	specifies the shared object dependency (as specified in DT_NEEDED).
252*0Sstevel@tonic-gate  *	One or more versions required from this dependency are specified in the
253*0Sstevel@tonic-gate  *	version needed auxiliary array.
254*0Sstevel@tonic-gate  *
255*0Sstevel@tonic-gate  *  o	A version symbol index table.  Each symbol indexes into this array
256*0Sstevel@tonic-gate  *	to determine its version index.  Index values of VER_NDX_BGNDEF or
257*0Sstevel@tonic-gate  *	greater indicate the version definition to which a symbol is associated.
258*0Sstevel@tonic-gate  *	(the size of a symbol index entry is recorded in the sh_info field).
259*0Sstevel@tonic-gate  */
260*0Sstevel@tonic-gate #ifndef	_ASM
261*0Sstevel@tonic-gate 
262*0Sstevel@tonic-gate typedef struct {			/* Version Definition Structure. */
263*0Sstevel@tonic-gate 	Elf32_Half	vd_version;	/* this structures version revision */
264*0Sstevel@tonic-gate 	Elf32_Half	vd_flags;	/* version information */
265*0Sstevel@tonic-gate 	Elf32_Half	vd_ndx;		/* version index */
266*0Sstevel@tonic-gate 	Elf32_Half	vd_cnt;		/* no. of associated aux entries */
267*0Sstevel@tonic-gate 	Elf32_Word	vd_hash;	/* version name hash value */
268*0Sstevel@tonic-gate 	Elf32_Word	vd_aux;		/* no. of bytes from start of this */
269*0Sstevel@tonic-gate 					/*	verdef to verdaux array */
270*0Sstevel@tonic-gate 	Elf32_Word	vd_next;	/* no. of bytes from start of this */
271*0Sstevel@tonic-gate } Elf32_Verdef;				/*	verdef to next verdef entry */
272*0Sstevel@tonic-gate 
273*0Sstevel@tonic-gate typedef struct {			/* Verdef Auxiliary Structure. */
274*0Sstevel@tonic-gate 	Elf32_Word	vda_name;	/* first element defines the version */
275*0Sstevel@tonic-gate 					/*	name. Additional entries */
276*0Sstevel@tonic-gate 					/*	define dependency names. */
277*0Sstevel@tonic-gate 	Elf32_Word	vda_next;	/* no. of bytes from start of this */
278*0Sstevel@tonic-gate } Elf32_Verdaux;			/*	verdaux to next verdaux entry */
279*0Sstevel@tonic-gate 
280*0Sstevel@tonic-gate 
281*0Sstevel@tonic-gate typedef	struct {			/* Version Requirement Structure. */
282*0Sstevel@tonic-gate 	Elf32_Half	vn_version;	/* this structures version revision */
283*0Sstevel@tonic-gate 	Elf32_Half	vn_cnt;		/* no. of associated aux entries */
284*0Sstevel@tonic-gate 	Elf32_Word	vn_file;	/* name of needed dependency (file) */
285*0Sstevel@tonic-gate 	Elf32_Word	vn_aux;		/* no. of bytes from start of this */
286*0Sstevel@tonic-gate 					/*	verneed to vernaux array */
287*0Sstevel@tonic-gate 	Elf32_Word	vn_next;	/* no. of bytes from start of this */
288*0Sstevel@tonic-gate } Elf32_Verneed;			/*	verneed to next verneed entry */
289*0Sstevel@tonic-gate 
290*0Sstevel@tonic-gate typedef struct {			/* Verneed Auxiliary Structure. */
291*0Sstevel@tonic-gate 	Elf32_Word	vna_hash;	/* version name hash value */
292*0Sstevel@tonic-gate 	Elf32_Half	vna_flags;	/* version information */
293*0Sstevel@tonic-gate 	Elf32_Half	vna_other;
294*0Sstevel@tonic-gate 	Elf32_Word	vna_name;	/* version name */
295*0Sstevel@tonic-gate 	Elf32_Word	vna_next;	/* no. of bytes from start of this */
296*0Sstevel@tonic-gate } Elf32_Vernaux;			/*	vernaux to next vernaux entry */
297*0Sstevel@tonic-gate 
298*0Sstevel@tonic-gate typedef	Elf32_Half 	Elf32_Versym;	/* Version symbol index array */
299*0Sstevel@tonic-gate 
300*0Sstevel@tonic-gate typedef struct {
301*0Sstevel@tonic-gate 	Elf32_Half	si_boundto;	/* direct bindings - symbol bound to */
302*0Sstevel@tonic-gate 	Elf32_Half	si_flags;	/* per symbol flags */
303*0Sstevel@tonic-gate } Elf32_Syminfo;
304*0Sstevel@tonic-gate 
305*0Sstevel@tonic-gate 
306*0Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE)
307*0Sstevel@tonic-gate typedef struct {
308*0Sstevel@tonic-gate 	Elf64_Half	vd_version;	/* this structures version revision */
309*0Sstevel@tonic-gate 	Elf64_Half	vd_flags;	/* version information */
310*0Sstevel@tonic-gate 	Elf64_Half	vd_ndx;		/* version index */
311*0Sstevel@tonic-gate 	Elf64_Half	vd_cnt;		/* no. of associated aux entries */
312*0Sstevel@tonic-gate 	Elf64_Word	vd_hash;	/* version name hash value */
313*0Sstevel@tonic-gate 	Elf64_Word	vd_aux;		/* no. of bytes from start of this */
314*0Sstevel@tonic-gate 					/*	verdef to verdaux array */
315*0Sstevel@tonic-gate 	Elf64_Word	vd_next;	/* no. of bytes from start of this */
316*0Sstevel@tonic-gate } Elf64_Verdef;				/*	verdef to next verdef entry */
317*0Sstevel@tonic-gate 
318*0Sstevel@tonic-gate typedef struct {
319*0Sstevel@tonic-gate 	Elf64_Word	vda_name;	/* first element defines the version */
320*0Sstevel@tonic-gate 					/*	name. Additional entries */
321*0Sstevel@tonic-gate 					/*	define dependency names. */
322*0Sstevel@tonic-gate 	Elf64_Word	vda_next;	/* no. of bytes from start of this */
323*0Sstevel@tonic-gate } Elf64_Verdaux;			/*	verdaux to next verdaux entry */
324*0Sstevel@tonic-gate 
325*0Sstevel@tonic-gate typedef struct {
326*0Sstevel@tonic-gate 	Elf64_Half	vn_version;	/* this structures version revision */
327*0Sstevel@tonic-gate 	Elf64_Half	vn_cnt;		/* no. of associated aux entries */
328*0Sstevel@tonic-gate 	Elf64_Word	vn_file;	/* name of needed dependency (file) */
329*0Sstevel@tonic-gate 	Elf64_Word	vn_aux;		/* no. of bytes from start of this */
330*0Sstevel@tonic-gate 					/*	verneed to vernaux array */
331*0Sstevel@tonic-gate 	Elf64_Word	vn_next;	/* no. of bytes from start of this */
332*0Sstevel@tonic-gate } Elf64_Verneed;			/*	verneed to next verneed entry */
333*0Sstevel@tonic-gate 
334*0Sstevel@tonic-gate typedef struct {
335*0Sstevel@tonic-gate 	Elf64_Word	vna_hash;	/* version name hash value */
336*0Sstevel@tonic-gate 	Elf64_Half	vna_flags;	/* version information */
337*0Sstevel@tonic-gate 	Elf64_Half	vna_other;
338*0Sstevel@tonic-gate 	Elf64_Word	vna_name;	/* version name */
339*0Sstevel@tonic-gate 	Elf64_Word	vna_next;	/* no. of bytes from start of this */
340*0Sstevel@tonic-gate } Elf64_Vernaux;			/*	vernaux to next vernaux entry */
341*0Sstevel@tonic-gate 
342*0Sstevel@tonic-gate typedef	Elf64_Half	Elf64_Versym;
343*0Sstevel@tonic-gate 
344*0Sstevel@tonic-gate typedef struct {
345*0Sstevel@tonic-gate 	Elf64_Half	si_boundto;	/* direct bindings - symbol bound to */
346*0Sstevel@tonic-gate 	Elf64_Half	si_flags;	/* per symbol flags */
347*0Sstevel@tonic-gate } Elf64_Syminfo;
348*0Sstevel@tonic-gate #endif	/* defined(_LP64) || defined(_LONGLONG_TYPE) */
349*0Sstevel@tonic-gate 
350*0Sstevel@tonic-gate #endif	/* _ASM */
351*0Sstevel@tonic-gate 
352*0Sstevel@tonic-gate /*
353*0Sstevel@tonic-gate  * Versym symbol index values.  Values greater than VER_NDX_GLOBAL
354*0Sstevel@tonic-gate  * and less then VER_NDX_LORESERVE associate symbols with user
355*0Sstevel@tonic-gate  * specified version descriptors.
356*0Sstevel@tonic-gate  */
357*0Sstevel@tonic-gate #define	VER_NDX_LOCAL		0	/* symbol is local */
358*0Sstevel@tonic-gate #define	VER_NDX_GLOBAL		1	/* symbol is global and assigned to */
359*0Sstevel@tonic-gate 					/*	the base version */
360*0Sstevel@tonic-gate #define	VER_NDX_LORESERVE	0xff00	/* beginning of RESERVED entries */
361*0Sstevel@tonic-gate #define	VER_NDX_ELIMINATE	0xff01	/* symbol is to be eliminated */
362*0Sstevel@tonic-gate 
363*0Sstevel@tonic-gate /*
364*0Sstevel@tonic-gate  * Verdef and Verneed (via Veraux) flags values.
365*0Sstevel@tonic-gate  */
366*0Sstevel@tonic-gate #define	VER_FLG_BASE		0x1	/* version definition of file itself */
367*0Sstevel@tonic-gate #define	VER_FLG_WEAK		0x2	/* weak version identifier */
368*0Sstevel@tonic-gate 
369*0Sstevel@tonic-gate /*
370*0Sstevel@tonic-gate  * Verdef version values.
371*0Sstevel@tonic-gate  */
372*0Sstevel@tonic-gate #define	VER_DEF_NONE		0	/* Ver_def version */
373*0Sstevel@tonic-gate #define	VER_DEF_CURRENT		1
374*0Sstevel@tonic-gate #define	VER_DEF_NUM		2
375*0Sstevel@tonic-gate 
376*0Sstevel@tonic-gate /*
377*0Sstevel@tonic-gate  * Verneed version values.
378*0Sstevel@tonic-gate  */
379*0Sstevel@tonic-gate #define	VER_NEED_NONE		0	/* Ver_need version */
380*0Sstevel@tonic-gate #define	VER_NEED_CURRENT	1
381*0Sstevel@tonic-gate #define	VER_NEED_NUM		2
382*0Sstevel@tonic-gate 
383*0Sstevel@tonic-gate 
384*0Sstevel@tonic-gate /*
385*0Sstevel@tonic-gate  * Syminfo flag values
386*0Sstevel@tonic-gate  */
387*0Sstevel@tonic-gate #define	SYMINFO_FLG_DIRECT	0x0001	/* symbol ref has direct association */
388*0Sstevel@tonic-gate 					/*	to object containing defn. */
389*0Sstevel@tonic-gate #define	SYMINFO_FLG_PASSTHRU	0x0002	/* ignored - see SYMINFO_FLG_FILTER */
390*0Sstevel@tonic-gate #define	SYMINFO_FLG_COPY	0x0004	/* symbol is a copy-reloc */
391*0Sstevel@tonic-gate #define	SYMINFO_FLG_LAZYLOAD	0x0008	/* object containing defn should be */
392*0Sstevel@tonic-gate 					/*	lazily-loaded */
393*0Sstevel@tonic-gate #define	SYMINFO_FLG_DIRECTBIND	0x0010	/* ref should be bound directly to */
394*0Sstevel@tonic-gate 					/*	object containing defn. */
395*0Sstevel@tonic-gate #define	SYMINFO_FLG_NOEXTDIRECT	0x0020	/* don't let an external reference */
396*0Sstevel@tonic-gate 					/*	directly bind to this symbol */
397*0Sstevel@tonic-gate #define	SYMINFO_FLG_FILTER	0x0002	/* symbol ref is associated to a */
398*0Sstevel@tonic-gate #define	SYMINFO_FLG_AUXILIARY	0x0040	/* 	standard or auxiliary filter */
399*0Sstevel@tonic-gate 
400*0Sstevel@tonic-gate /*
401*0Sstevel@tonic-gate  * Syminfo.si_boundto values.
402*0Sstevel@tonic-gate  */
403*0Sstevel@tonic-gate #define	SYMINFO_BT_SELF		0xffff	/* symbol bound to self */
404*0Sstevel@tonic-gate #define	SYMINFO_BT_PARENT	0xfffe	/* symbol bound to parent */
405*0Sstevel@tonic-gate #define	SYMINFO_BT_NONE		0xfffd	/* no special symbol binding */
406*0Sstevel@tonic-gate #define	SYMINFO_BT_EXTERN	0xfffc	/* symbol defined as external */
407*0Sstevel@tonic-gate #define	SYMINFO_BT_LOWRESERVE	0xff00	/* beginning of reserved entries */
408*0Sstevel@tonic-gate 
409*0Sstevel@tonic-gate /*
410*0Sstevel@tonic-gate  * Syminfo version values.
411*0Sstevel@tonic-gate  */
412*0Sstevel@tonic-gate #define	SYMINFO_NONE		0	/* Syminfo version */
413*0Sstevel@tonic-gate #define	SYMINFO_CURRENT		1
414*0Sstevel@tonic-gate #define	SYMINFO_NUM		2
415*0Sstevel@tonic-gate 
416*0Sstevel@tonic-gate 
417*0Sstevel@tonic-gate /*
418*0Sstevel@tonic-gate  * Public structure defined and maintained within the runtime linker
419*0Sstevel@tonic-gate  */
420*0Sstevel@tonic-gate #ifndef	_ASM
421*0Sstevel@tonic-gate 
422*0Sstevel@tonic-gate typedef struct link_map	Link_map;
423*0Sstevel@tonic-gate 
424*0Sstevel@tonic-gate struct link_map {
425*0Sstevel@tonic-gate 	unsigned long	l_addr;		/* address at which object is mapped */
426*0Sstevel@tonic-gate 	char 		*l_name;	/* full name of loaded object */
427*0Sstevel@tonic-gate #ifdef _LP64
428*0Sstevel@tonic-gate 	Elf64_Dyn	*l_ld;		/* dynamic structure of object */
429*0Sstevel@tonic-gate #else
430*0Sstevel@tonic-gate 	Elf32_Dyn	*l_ld;		/* dynamic structure of object */
431*0Sstevel@tonic-gate #endif
432*0Sstevel@tonic-gate 	Link_map	*l_next;	/* next link object */
433*0Sstevel@tonic-gate 	Link_map	*l_prev;	/* previous link object */
434*0Sstevel@tonic-gate 	char		*l_refname;	/* filters reference name */
435*0Sstevel@tonic-gate };
436*0Sstevel@tonic-gate 
437*0Sstevel@tonic-gate #ifdef _SYSCALL32
438*0Sstevel@tonic-gate typedef struct link_map32 Link_map32;
439*0Sstevel@tonic-gate 
440*0Sstevel@tonic-gate struct link_map32 {
441*0Sstevel@tonic-gate 	Elf32_Word	l_addr;
442*0Sstevel@tonic-gate 	Elf32_Addr	l_name;
443*0Sstevel@tonic-gate 	Elf32_Addr	l_ld;
444*0Sstevel@tonic-gate 	Elf32_Addr	l_next;
445*0Sstevel@tonic-gate 	Elf32_Addr	l_prev;
446*0Sstevel@tonic-gate 	Elf32_Addr	l_refname;
447*0Sstevel@tonic-gate };
448*0Sstevel@tonic-gate #endif
449*0Sstevel@tonic-gate 
450*0Sstevel@tonic-gate typedef enum {
451*0Sstevel@tonic-gate 	RT_CONSISTENT,
452*0Sstevel@tonic-gate 	RT_ADD,
453*0Sstevel@tonic-gate 	RT_DELETE
454*0Sstevel@tonic-gate } r_state_e;
455*0Sstevel@tonic-gate 
456*0Sstevel@tonic-gate typedef enum {
457*0Sstevel@tonic-gate 	RD_FL_NONE = 0,		/* no flags */
458*0Sstevel@tonic-gate 	RD_FL_ODBG = (1<<0),	/* old style debugger present */
459*0Sstevel@tonic-gate 	RD_FL_DBG = (1<<1)	/* debugging enabled */
460*0Sstevel@tonic-gate } rd_flags_e;
461*0Sstevel@tonic-gate 
462*0Sstevel@tonic-gate 
463*0Sstevel@tonic-gate 
464*0Sstevel@tonic-gate /*
465*0Sstevel@tonic-gate  * Debugging events enabled inside of the runtime linker.  To
466*0Sstevel@tonic-gate  * access these events see the librtld_db interface.
467*0Sstevel@tonic-gate  */
468*0Sstevel@tonic-gate typedef enum {
469*0Sstevel@tonic-gate 	RD_NONE = 0,		/* no event */
470*0Sstevel@tonic-gate 	RD_PREINIT,		/* the Initial rendezvous before .init */
471*0Sstevel@tonic-gate 	RD_POSTINIT,		/* the Second rendezvous after .init */
472*0Sstevel@tonic-gate 	RD_DLACTIVITY		/* a dlopen or dlclose has happened */
473*0Sstevel@tonic-gate } rd_event_e;
474*0Sstevel@tonic-gate 
475*0Sstevel@tonic-gate struct r_debug {
476*0Sstevel@tonic-gate 	int		r_version;	/* debugging info version no. */
477*0Sstevel@tonic-gate 	Link_map	*r_map;		/* address of link_map */
478*0Sstevel@tonic-gate 	unsigned long	r_brk;		/* address of update routine */
479*0Sstevel@tonic-gate 	r_state_e	r_state;
480*0Sstevel@tonic-gate 	unsigned long	r_ldbase;	/* base addr of ld.so */
481*0Sstevel@tonic-gate 	Link_map	*r_ldsomap;	/* address of ld.so.1's link map */
482*0Sstevel@tonic-gate 	rd_event_e	r_rdevent;	/* debug event */
483*0Sstevel@tonic-gate 	rd_flags_e	r_flags;	/* misc flags. */
484*0Sstevel@tonic-gate };
485*0Sstevel@tonic-gate 
486*0Sstevel@tonic-gate #ifdef _SYSCALL32
487*0Sstevel@tonic-gate struct r_debug32 {
488*0Sstevel@tonic-gate 	Elf32_Word	r_version;	/* debugging info version no. */
489*0Sstevel@tonic-gate 	Elf32_Addr	r_map;		/* address of link_map */
490*0Sstevel@tonic-gate 	Elf32_Word	r_brk;		/* address of update routine */
491*0Sstevel@tonic-gate 	r_state_e	r_state;
492*0Sstevel@tonic-gate 	Elf32_Word	r_ldbase;	/* base addr of ld.so */
493*0Sstevel@tonic-gate 	Elf32_Addr	r_ldsomap;	/* address of ld.so.1's link map */
494*0Sstevel@tonic-gate 	rd_event_e	r_rdevent;	/* debug event */
495*0Sstevel@tonic-gate 	rd_flags_e	r_flags;	/* misc flags. */
496*0Sstevel@tonic-gate };
497*0Sstevel@tonic-gate #endif
498*0Sstevel@tonic-gate 
499*0Sstevel@tonic-gate 
500*0Sstevel@tonic-gate #define	R_DEBUG_VERSION	2		/* current r_debug version */
501*0Sstevel@tonic-gate #endif	/* _ASM */
502*0Sstevel@tonic-gate 
503*0Sstevel@tonic-gate /*
504*0Sstevel@tonic-gate  * Attribute/value structures used to bootstrap ELF-based dynamic linker.
505*0Sstevel@tonic-gate  */
506*0Sstevel@tonic-gate #ifndef	_ASM
507*0Sstevel@tonic-gate typedef struct {
508*0Sstevel@tonic-gate 	Elf32_Sword eb_tag;		/* what this one is */
509*0Sstevel@tonic-gate 	union {				/* possible values */
510*0Sstevel@tonic-gate 		Elf32_Word eb_val;
511*0Sstevel@tonic-gate 		Elf32_Addr eb_ptr;
512*0Sstevel@tonic-gate 		Elf32_Off  eb_off;
513*0Sstevel@tonic-gate 	} eb_un;
514*0Sstevel@tonic-gate } Elf32_Boot;
515*0Sstevel@tonic-gate 
516*0Sstevel@tonic-gate #if defined(_LP64) || defined(_LONGLONG_TYPE)
517*0Sstevel@tonic-gate typedef struct {
518*0Sstevel@tonic-gate 	Elf64_Xword eb_tag;		/* what this one is */
519*0Sstevel@tonic-gate 	union {				/* possible values */
520*0Sstevel@tonic-gate 		Elf64_Xword eb_val;
521*0Sstevel@tonic-gate 		Elf64_Addr eb_ptr;
522*0Sstevel@tonic-gate 		Elf64_Off eb_off;
523*0Sstevel@tonic-gate 	} eb_un;
524*0Sstevel@tonic-gate } Elf64_Boot;
525*0Sstevel@tonic-gate #endif	/* defined(_LP64) || defined(_LONGLONG_TYPE) */
526*0Sstevel@tonic-gate #endif	/* _ASM */
527*0Sstevel@tonic-gate 
528*0Sstevel@tonic-gate /*
529*0Sstevel@tonic-gate  * Attributes
530*0Sstevel@tonic-gate  */
531*0Sstevel@tonic-gate #define	EB_NULL		0		/* (void) last entry */
532*0Sstevel@tonic-gate #define	EB_DYNAMIC	1		/* (*) dynamic structure of subject */
533*0Sstevel@tonic-gate #define	EB_LDSO_BASE	2		/* (caddr_t) base address of ld.so */
534*0Sstevel@tonic-gate #define	EB_ARGV		3		/* (caddr_t) argument vector */
535*0Sstevel@tonic-gate #define	EB_ENVP		4		/* (char **) environment strings */
536*0Sstevel@tonic-gate #define	EB_AUXV		5		/* (auxv_t *) auxiliary vector */
537*0Sstevel@tonic-gate #define	EB_DEVZERO	6		/* (int) fd for /dev/zero */
538*0Sstevel@tonic-gate #define	EB_PAGESIZE	7		/* (int) page size */
539*0Sstevel@tonic-gate #define	EB_MAX		8		/* number of "EBs" */
540*0Sstevel@tonic-gate #define	EB_MAX_SIZE32	64		/* size in bytes, _ILP32 */
541*0Sstevel@tonic-gate #define	EB_MAX_SIZE64	128		/* size in bytes, _LP64 */
542*0Sstevel@tonic-gate 
543*0Sstevel@tonic-gate 
544*0Sstevel@tonic-gate #ifndef	_ASM
545*0Sstevel@tonic-gate 
546*0Sstevel@tonic-gate #ifdef __STDC__
547*0Sstevel@tonic-gate 
548*0Sstevel@tonic-gate /*
549*0Sstevel@tonic-gate  * Concurrency communication structure for libc callbacks.
550*0Sstevel@tonic-gate  */
551*0Sstevel@tonic-gate extern void	_ld_libc(void *);
552*0Sstevel@tonic-gate #else /* __STDC__ */
553*0Sstevel@tonic-gate extern void	_ld_libc();
554*0Sstevel@tonic-gate #endif /* __STDC__ */
555*0Sstevel@tonic-gate 
556*0Sstevel@tonic-gate #pragma unknown_control_flow(_ld_libc)
557*0Sstevel@tonic-gate #endif /* _ASM */
558*0Sstevel@tonic-gate 
559*0Sstevel@tonic-gate #ifdef	__cplusplus
560*0Sstevel@tonic-gate }
561*0Sstevel@tonic-gate #endif
562*0Sstevel@tonic-gate 
563*0Sstevel@tonic-gate #endif	/* _SYS_LINK_H */
564