xref: /titanic_44/usr/src/cmd/sgs/libld/common/_libld.h (revision 62a24de03df1f2399ceda704cb3874dabc98bbbd)
1 /*
2  * CDDL HEADER START
3  *
4  * The contents of this file are subject to the terms of the
5  * Common Development and Distribution License (the "License").
6  * You may not use this file except in compliance with the License.
7  *
8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9  * or http://www.opensolaris.org/os/licensing.
10  * See the License for the specific language governing permissions
11  * and limitations under the License.
12  *
13  * When distributing Covered Code, include this CDDL HEADER in each
14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15  * If applicable, add the following below this CDDL HEADER, with the
16  * fields enclosed by brackets "[]" replaced with your own identifying
17  * information: Portions Copyright [yyyy] [name of copyright owner]
18  *
19  * CDDL HEADER END
20  */
21 
22 /*
23  *	Copyright (c) 1988 AT&T
24  *	  All Rights Reserved
25  *
26  * Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
27  * Use is subject to license terms.
28  */
29 
30 /*
31  * Local include file for ld library.
32  */
33 
34 #ifndef	_LIBLD_DOT_H
35 #define	_LIBLD_DOT_H
36 
37 #include <libld.h>
38 #include <_libelf.h>
39 #include <debug.h>
40 #include <conv.h>
41 #include <msg.h>
42 #include <reloc_defs.h>
43 
44 #ifdef	__cplusplus
45 extern "C" {
46 #endif
47 
48 /*
49  * In order to allow for cross linking, we need to be able to build
50  * libld with support for multiple targets within a single object.
51  * This is done using a global variable (ld_targ) of type Target to
52  * access target-specific code for the current target via indirection.
53  */
54 
55 /*
56  * Machine information for target
57  */
58 typedef struct {
59 	Half		m_mach;		/* ELF machine code for target */
60 	Half		m_machplus;	/* Alt ELF machine code for target */
61 					/*	Used for EM_SPARC32PLUS */
62 	Word		m_flagsplus;	/* ELF header flags used to identify */
63 					/*	a machplus object */
64 	uchar_t		m_class;	/* Target ELFCLASS */
65 	uchar_t		m_data;		/* Target byte order */
66 
67 	Xword		m_segm_align;	/* segment alignment */
68 	Xword		m_segm_origin;	/* Default 1st segment offset */
69 	Word		m_dataseg_perm;	/* data segment permission mask */
70 	Word		m_word_align;	/* alignment to use for Word sections */
71 	const char	*m_def_interp;	/* Def. interpreter for dyn objects */
72 
73 	/* Relocation type codes */
74 	Word		m_r_arrayaddr;
75 	Word		m_r_copy;
76 	Word		m_r_glob_dat;
77 	Word		m_r_jmp_slot;
78 	Word		m_r_num;
79 	Word		m_r_none;
80 	Word		m_r_relative;
81 	Word		m_r_register;
82 
83 	/* Relocation related constants */
84 	Word		m_rel_dt_count;	/* Either DT_REL or DT_RELA */
85 	Word		m_rel_dt_ent;	/* Either DT_RELENT or DT_RELAENT */
86 	Word		m_rel_dt_size;	/* Either DT_RELSZ or DT_RELASZ */
87 	Word		m_rel_dt_type;	/* Either DT_RELCOUNT or DT_RELACOUNT */
88 	Word		m_rel_sht_type;	/* Either SHT_REL or SHT_RELA */
89 
90 	/* GOT related constants */
91 	Word		m_got_entsize;
92 	Word		m_got_xnumber;	/* reserved # of got ents */
93 
94 	/* PLT related constants */
95 	Word		m_plt_align;
96 	Word		m_plt_entsize;
97 	Word		m_plt_reservsz;
98 	Word		m_plt_shf_flags;
99 
100 	Word		m_dt_register;
101 } Target_mach;
102 
103 
104 /*
105  * Section identifiers, used to order sections in output object
106  */
107 typedef struct {
108 	Word		id_array;
109 	Word		id_bss;
110 	Word		id_cap;
111 	Word		id_data;
112 	Word		id_dynamic;
113 	Word		id_dynsort;
114 	Word		id_dynstr;
115 	Word		id_dynsym;
116 	Word		id_dynsym_ndx;
117 	Word		id_got;
118 	Word		id_gotdata;
119 	Word		id_hash;
120 	Word		id_interp;
121 	Word		id_lbss;
122 	Word		id_ldynsym;
123 	Word		id_note;
124 	Word		id_null;
125 	Word		id_plt;
126 	Word		id_rel;
127 	Word		id_strtab;
128 	Word		id_syminfo;
129 	Word		id_symtab;
130 	Word		id_symtab_ndx;
131 	Word		id_text;
132 	Word		id_tls;
133 	Word		id_tlsbss;
134 	Word		id_unknown;
135 	Word		id_unwind;
136 	Word		id_user;
137 	Word		id_version;
138 } Target_machid;
139 
140 /*
141  * Target_nullfunc supplies machine code for generating a
142  *
143  *	void (*)(void)
144  *
145  * unnamed function. Such a function can be called, and returns
146  * immediately without doing any work. This is used to back FUNC
147  * symbol definitions added with a mapfile.
148  *
149  * The machine instructions are specified as an array of bytes rather
150  * than a larger integer type in order to avoid byte order issues that
151  * can otherwise occur in cross linking.
152  */
153 typedef struct {
154 	const uchar_t	*nf_template;	/* Array of machine inst. bytes */
155 	size_t		nf_size;	/* # bytes in nf_template */
156 } Target_nullfunc;
157 
158 /*
159  * Target_machrel holds pointers to the reloc_table and machrel functions
160  * for a given target machine.
161  *
162  * The following function pointers are allowed to be NULL, if the
163  * underlying target does not require the specified operation. All
164  * other functions must be supplied:
165  *
166  *	mr_assign_got
167  *	mr_reloc_register
168  *	mr_reloc_GOTOP
169  *	mr_allocate_got
170  */
171 typedef struct {
172 	const Rel_entry	*mr_reloc_table;
173 
174 	Word		(* mr_init_rel)(Rel_desc *, void *);
175 	void 		(* mr_mach_eflags)(Ehdr *, Ofl_desc *);
176 	void		(* mr_mach_make_dynamic)(Ofl_desc *, size_t *);
177 	void		(* mr_mach_update_odynamic)(Ofl_desc *, Dyn **);
178 	Xword		(* mr_calc_plt_addr)(Sym_desc *, Ofl_desc *);
179 	uintptr_t	(* mr_perform_outreloc)(Rel_desc *, Ofl_desc *);
180 	uintptr_t	(* mr_do_activerelocs)(Ofl_desc *);
181 	uintptr_t	(* mr_add_outrel)(Word, Rel_desc *, Ofl_desc *);
182 	uintptr_t	(* mr_reloc_register)(Rel_desc *, Is_desc *,
183 			    Ofl_desc *);
184 	uintptr_t	(* mr_reloc_local)(Rel_desc *, Ofl_desc *);
185 	uintptr_t	(* mr_reloc_GOTOP)(Boolean, Rel_desc *, Ofl_desc *);
186 	uintptr_t	(* mr_reloc_TLS)(Boolean, Rel_desc *, Ofl_desc *);
187 	uintptr_t	(* mr_assign_got)(Ofl_desc *, Sym_desc *);
188 
189 	Gotndx		*(* mr_find_gotndx)(List *, Gotref, Ofl_desc *,
190 			    Rel_desc *);
191 	Xword		(* mr_calc_got_offset)(Rel_desc *, Ofl_desc *);
192 	uintptr_t	(* mr_assign_got_ndx)(List *, Gotndx *, Gotref,
193 			    Ofl_desc *, Rel_desc *, Sym_desc *);
194 	void		(* mr_assign_plt_ndx)(Sym_desc *, Ofl_desc *);
195 	uintptr_t	(* mr_allocate_got)(Ofl_desc *);
196 	uintptr_t	(* mr_fillin_gotplt)(Ofl_desc *);
197 } Target_machrel;
198 
199 
200 /*
201  * Target_machsym holds pointers to the machsym functions
202  * for a given target machine.
203  *
204  * These fields are allowed to be NULL for targets that do not require
205  * special handling of register symbols. Register symbols are used by
206  * sparc targets. If any of these fields are non-NULL, all of them are
207  * required to be present (use empty stub routines if necessary).
208  */
209 typedef struct {
210 	int		(* ms_reg_check)(Sym_desc *, Sym *, const char *,
211 			    Ifl_desc *, Ofl_desc *);
212 	int		(* ms_mach_sym_typecheck)(Sym_desc *, Sym *,
213 			    Ifl_desc *, Ofl_desc *);
214 	const char	*(* ms_is_regsym)(Ofl_desc *, Ifl_desc *, Sym *,
215 			    const char *, int, Word, const char *, Word *);
216 	Sym_desc	*(* ms_reg_find)(Sym * sym, Ofl_desc * ofl);
217 	int		(* ms_reg_enter)(Sym_desc *, Ofl_desc *);
218 } Target_machsym;
219 
220 /*
221  * amd64 unwind header support
222  *
223  * These fields are allowed to be NULL for targets that do not support
224  * amd64 unwind headers. If any of these fields are non-NULL, all of them are
225  * required to be present (use empty stub routines if necessary).
226  */
227 typedef struct {
228 	uintptr_t	(* uw_make_unwindhdr)(Ofl_desc *);
229 	uintptr_t	(* uw_populate_unwindhdr)(Ofl_desc *);
230 	uintptr_t	(* uw_append_unwind)(Os_desc *, Ofl_desc *);
231 } Target_unwind;
232 
233 typedef struct {
234 	Target_mach	t_m;
235 	Target_machid	t_id;
236 	Target_nullfunc	t_nf;
237 	Target_machrel	t_mr;
238 	Target_machsym	t_ms;
239 	Target_unwind	t_uw;
240 } Target;
241 
242 
243 /*
244  * Types of bss sections
245  */
246 typedef enum {
247 	MAKE_BSS,
248 	MAKE_LBSS,
249 	MAKE_TLS
250 } Bss_Type;
251 
252 /*
253  * Structure to manage the update of weak symbols from their associated alias.
254  */
255 typedef	struct wk_desc {
256 	Sym		*wk_symtab;	/* the .symtab entry */
257 	Sym		*wk_dynsym;	/* the .dynsym entry */
258 	Sym_desc	*wk_weak;	/* the original weak symbol */
259 	Sym_desc	*wk_alias;	/* the real symbol */
260 } Wk_desc;
261 
262 /*
263  * Structure to manage the support library interfaces.
264  */
265 typedef struct func_list {
266 	const char	*fl_obj;	/* name of support object */
267 					/*	function is from */
268 	void		(*fl_fptr)();	/* function pointer */
269 	uint_t		fl_version;	/* ld_version() level */
270 } Func_list;
271 
272 typedef	struct support_list {
273 	const char	*sup_name;	/* ld_support function name */
274 	List		sup_funcs;	/* list of support functions */
275 } Support_list;
276 
277 /*
278  * Structure to manage a sorted output relocation list.
279  *
280  *	rl_key1		->	pointer to needed ndx
281  *	rl_key2		->	pointer to symbol relocation is against
282  *	rl_key3		->	virtual offset of relocation
283  */
284 typedef struct reloc_list {
285 	Sym_desc	*rl_key2;
286 	Xword		rl_key3;
287 	Rel_desc	*rl_rsp;
288 	Half		rl_key1;
289 } Reloc_list;
290 
291 
292 typedef struct sym_s_list {
293 	Word		sl_hval;
294 	Sym_desc	*sl_sdp;
295 } Sym_s_list;
296 
297 /*
298  * ld heap management structure
299  */
300 typedef struct _ld_heap Ld_heap;
301 struct _ld_heap {
302 	Ld_heap		*lh_next;
303 	void		*lh_free;
304 	void		*lh_end;
305 };
306 
307 #define	HEAPBLOCK	0x68000		/* default allocation block size */
308 #define	HEAPALIGN	0x8		/* heap blocks alignment requirement */
309 
310 /*
311  * Dynamic per-symbol filtee string table descriptor.  This associates filtee
312  * strings that will be created in the .dynstr, with .dynamic entries.
313  */
314 typedef struct {
315 	char		*dft_str;	/* dynstr string */
316 	Word		dft_flag;	/* auxiliary/filtee type */
317 	Half		dft_ndx;	/* eventual ndx into .dynamic */
318 } Dfltr_desc;
319 
320 /*
321  * Per-symbol filtee descriptor.  This associates symbol definitions with
322  * their filtees.
323  */
324 typedef struct {
325 	Sym_desc	*sft_sdp;	/* symbol descriptor */
326 	Aliste		sft_idx;	/* index into dtstr descriptor */
327 } Sfltr_desc;
328 
329 /*
330  * Define Alist initialization sizes.
331  */
332 #define	AL_CNT_IFL_GROUPS	20	/* ifl_groups initial alist count */
333 #define	AL_CNT_OFL_DTSFLTRS	4	/* ofl_dtsfltrs initial alist count */
334 #define	AL_CNT_OFL_SYMFLTRS	20	/* ofl_symfltrs initial alist count */
335 #define	AL_CNT_OS_MSTRISDESCS	10	/* os_mstrisdescs */
336 #define	AL_CNT_OS_COMDATS	20	/* os_comdats */
337 #define	AL_CNT_SG_OSDESC	40	/* sg_osdescs initial alist count */
338 #define	AL_CNT_SG_SECORDER	40	/* sg_secorder initial alist count */
339 #define	AL_CNT_STRMRGREL	500	/* ld_make_strmerge() reloc alist cnt */
340 #define	AL_CNT_STRMRGSYM	20	/* ld_make_strmerge() sym alist cnt */
341 
342 /*
343  * Return codes for {tls|got}_fixups() routines
344  */
345 typedef enum {
346 	FIX_ERROR,	/* fatal error - time to punt */
347 	FIX_DONE,	/* relocation done - no further processing required */
348 	FIX_RELOC	/* do_reloc() relocation processing required */
349 } Fixupret;
350 
351 #ifndef	FILENAME_MAX
352 #define	FILENAME_MAX	BUFSIZ		/* maximum length of a path name */
353 #endif
354 
355 /*
356  * We pad the end of the .dynstr section with a block of DYNSTR_EXTRA_PAD
357  * bytes, and we insert DYNAMIC_EXTRA_ELTS unused items into the
358  * .dynamic section (with value DT_NULL). This provides the resources needed
359  * to add and/or alter string items in the .dynamic section, such as runpath.
360  */
361 #define	DYNSTR_EXTRA_PAD	512
362 #define	DYNAMIC_EXTRA_ELTS	10
363 
364 /*
365  * Relocation buckets are sized based on the number of input relocations and
366  * the following constants.
367  */
368 #define	REL_HAIDESCNO	1000		/* high water mark active buckets */
369 #define	REL_LAIDESCNO	50		/* low water mark active buckets */
370 #define	REL_HOIDESCNO	500		/* high water mark output buckets */
371 #define	REL_LOIDESCNO	10		/* low water mark output buckets */
372 
373 extern char		*Plibpath;
374 extern char		*Llibdir;
375 extern char		*Ulibdir;
376 extern Ld_heap		*ld_heap;
377 extern List		lib_support;
378 extern int		demangle_flag;
379 extern const Msg	reject[];
380 extern int		Verbose;
381 extern const int	ldynsym_symtype[STT_NUM];
382 extern const int	dynsymsort_symtype[STT_NUM];
383 
384 
385 /*
386  * Given a symbol of a type that is allowed within a .SUNW_dynsymsort or
387  * .SUNW_dyntlssort section, examine the symbol attributes to determine
388  * if this particular symbol should be included or not.
389  *
390  * entry:
391  *	The symbol must have an allowed type: Either a type verified by
392  *	dynsymsort_symtype[] or STT_TLS.
393  *
394  *	_sdp - Pointer to symbol descriptor
395  *	_sym - Pointer to symbol referenced by _sdp.
396  *
397  *	_sym is derivable from _sdp: _sdp->sd_sym
398  *	However, most callers assign it to a local variable for efficiency,
399  *	and this macro allows such a variable to be used within. If you
400  *	don't have such a variable, supply _sdp->sd_sym.
401  *
402  * The tests used require some explanation:
403  *
404  *	(_sdp->sd_flags & FLG_SY_DYNSORT)
405  *		Some special symbols are kept even if they don't meet the
406  *		usual requirements. These symbols have the FLG_SY_DYNSORT
407  *		bit set. If this bit isn't set then we look at the other
408  *		attributes.
409  *
410  *	(((_sdp->sd_ref != REF_DYN_NEED) &&
411  *		(_sdp->sd_sym->st_shndx != SHN_UNDEF))
412  *	|| (_sdp->sd_flags & FLG_SY_MVTOCOMM))
413  *		We do not want to include symbols that are not defined within
414  *		the object we are creating. REF_DYN_NEED corresponds to those
415  *		UNDEF items. However, if the symbol is the target of a copy
416  *		relocation, then it effectively becomes defined within the
417  *		object after all. FLG_SY_MVTOCOMM indicates a copy relocation,
418  *		and prevents us from culling those exceptions.
419  *
420  *	(_sym->st_size != 0)
421  *		Symbols with 0 length are labels injected by the compilers
422  *		or the linker for purposes of code generation, and do
423  *		not directly correspond to actual code. In fact, most of the
424  *		symbols we mark with FLG_SY_DYNSORT need that flag set because
425  *		they have size 0. This size test filters out the others.
426  *
427  *	!(_sdp->sd_flags & FLG_SY_NODYNSORT)
428  *		Some symbols are not kept, even though they do meet the usual
429  *		requirements. These symbols have FLG_SY_NODYNSORT set.
430  *		For example, if there are weak and non-weak versions of a given
431  *		symbol, we only want to keep one of them. So, we set
432  *		FLG_SY_NODYNSORT on the one we don't want.
433  */
434 #define	DYNSORT_TEST_ATTR(_sdp, _sym) \
435 	((_sdp->sd_flags & FLG_SY_DYNSORT) || \
436 	((((_sdp->sd_ref != REF_DYN_NEED) && \
437 		(_sdp->sd_sym->st_shndx != SHN_UNDEF)) || \
438 		(_sdp->sd_flags & FLG_SY_MVTOCOMM)) && \
439 	(_sym->st_size != 0) && \
440 	!(_sdp->sd_flags & FLG_SY_NODYNSORT)))
441 
442 /*
443  * We use output section descriptor counters to add up the number of
444  * symbol indexes to put in the .SUNW_dynsort and .SUNW_dyntlssort sections.
445  * Non-TLS symbols are counted by ofl->ofl_dynsymsortcnt, while TLS symbols are
446  * counted by ofl->ofl_dyntlssortcnt. This computation is done inline in
447  * several places. The DYNSORT_COUNT macro allows us to generate this from
448  * a single description.
449  *
450  * entry:
451  *	_sdp, _sym - As per DYNSORT_TEST_ATTR
452  *	_type - Type of symbol (STT_*)
453  *	_inc_or_dec_op - Either ++, or --. This specifies the operation
454  *		to be applied to the counter, and determines whether we
455  *		are adding, or removing, a symbol from .SUNW_dynsymsort.
456  *
457  * Note that _type is derivable from _sym: ELF_ST_TYPE(_sdp->sd_sym->st_info).
458  * Most callers already have it in a variable, so this allows us to use that
459  * variable. If you don't have such a variable, use ELF_ST_TYPE() as shown.
460  */
461 #define	DYNSORT_COUNT(_sdp, _sym, _type, _inc_or_dec_op) \
462 { \
463 	Word *_cnt_var; \
464 	\
465 	if (dynsymsort_symtype[_type]) {	/* Non-TLS counter */ \
466 		_cnt_var = &ofl->ofl_dynsymsortcnt; \
467 	} else if ((_type) == STT_TLS) {	/* TLS counter */ \
468 		_cnt_var = &ofl->ofl_dyntlssortcnt; \
469 	} else {				/* Don't count this symbol */ \
470 		_cnt_var = NULL; \
471 	} \
472 	if ((_cnt_var != NULL) && DYNSORT_TEST_ATTR(_sdp, _sym)) \
473 		(*_cnt_var)_inc_or_dec_op;	/* Increment/Decrement */ \
474 }
475 
476 
477 /*
478  * The OFL_SWAP_RELOC macros are used to determine whether
479  * relocation processing needs to swap the data being relocated.
480  * It is an optimization to ld_swap_reloc_data(), as it avoids
481  * the function call in the case where the linker host and the
482  * target have the same byte order.
483  */
484 
485 #define	OFL_SWAP_RELOC_DATA(_ofl, _rel) \
486 	(((_ofl)->ofl_flags1 & FLG_OF1_ENCDIFF) && \
487 	ld_swap_reloc_data(_ofl, _rel))
488 
489 /*
490  * For backward compatibility provide a /dev/zero file descriptor.
491  */
492 extern int		dz_fd;
493 
494 /*
495  * Local functions.
496  */
497 extern char		*add_string(char *, char *);
498 extern const char	*demangle(const char *);
499 
500 extern void		lds_atexit(Ofl_desc *, int);
501 
502 extern void		libld_free(void *);
503 extern void		*libld_malloc(size_t);
504 extern void		*libld_realloc(void *, size_t);
505 
506 extern Listnode		*list_appendc(List *, const void *);
507 extern Listnode		*list_insertc(List *, const void *, Listnode *);
508 extern Listnode		*list_prependc(List *, const void *);
509 extern Listnode		*list_where(List *, Word num);
510 
511 extern Sdf_desc		*sdf_add(const char *, List *);
512 extern Sdf_desc		*sdf_find(const char *, List *);
513 
514 #if	defined(_ELF64)
515 
516 #define	ld_add_actrel		ld64_add_actrel
517 #define	ld_add_libdir		ld64_add_libdir
518 #define	ld_adj_movereloc	ld64_adj_movereloc
519 #define	ld_am_I_partial		ld64_am_I_partial
520 #define	ld_append_isp		ld64_append_isp
521 #define	ld_ar_member		ld64_ar_member
522 #define	ld_ar_setup		ld64_ar_setup
523 #define	ld_assign_got_TLS	ld64_assign_got_TLS
524 #define	ld_bswap_Word		ld64_bswap_Word
525 #define	ld_bswap_Xword		ld64_bswap_Xword
526 #define	ld_disp_errmsg		ld64_disp_errmsg
527 #define	ld_ent_check		ld64_ent_check
528 #define	ld_exit			ld64_exit
529 #define	ld_find_library		ld64_find_library
530 #define	ld_finish_libs		ld64_finish_libs
531 #define	ld_get_group		ld64_get_group
532 #define	ld_group_process	ld64_group_process
533 #define	ld_lib_setup		ld64_lib_setup
534 #define	ld_init			ld64_init
535 #define	ld_lcm			ld64_lcm
536 #define	ld_make_bss		ld64_make_bss
537 #define	ld_make_data		ld64_make_data
538 #define	ld_make_got		ld64_make_got
539 #define	ld_make_sunwbss		ld64_make_sunwbss
540 #define	ld_make_sunwdata	ld64_make_sunwdata
541 #define	ld_make_sunwmove	ld64_make_sunmove
542 #define	ld_make_text		ld64_make_text
543 #define	ld_map_out		ld64_map_out
544 #define	ld_map_parse		ld64_map_parse
545 #define	ld_open_outfile		ld64_open_outfile
546 #define	ld_place_section	ld64_place_section
547 #define	ld_process_archive	ld64_process_archive
548 #define	ld_process_files	ld64_process_files
549 #define	ld_process_flags	ld64_process_flags
550 #define	ld_process_ifl		ld64_process_ifl
551 #define	ld_process_ordered	ld64_process_ordered
552 #define	ld_process_sym_reloc	ld64_process_sym_reloc
553 #define	ld_reloc_GOT_relative	ld64_reloc_GOT_relative
554 #define	ld_reloc_plt		ld64_reloc_plt
555 #define	ld_reloc_remain_entry	ld64_reloc_remain_entry
556 #define	ld_reloc_targval_get	ld64_reloc_targval_get
557 #define	ld_reloc_targval_set	ld64_reloc_targval_set
558 #define	ld_sec_validate		ld64_sec_validate
559 #define	ld_section_reld_name	ld64_section_reld_name
560 #define	ld_sort_ordered		ld64_sort_ordered
561 #define	ld_sort_seg_list	ld64_sort_seg_list
562 #define	ld_sunw_ldmach		ld64_sunw_ldmach
563 #define	ld_sunwmove_preprocess	ld64_sunwmove_preprocess
564 #define	ld_sup_atexit		ld64_sup_atexit
565 #define	ld_sup_open		ld64_sup_open
566 #define	ld_sup_file		ld64_sup_file
567 #define	ld_sup_loadso		ld64_sup_loadso
568 #define	ld_sup_input_done	ld64_sup_input_done
569 #define	ld_sup_input_section	ld64_sup_input_section
570 #define	ld_sup_section		ld64_sup_section
571 #define	ld_sup_start		ld64_sup_start
572 #define	ld_swap_reloc_data	ld64_swap_reloc_data
573 #define	ld_sym_add_u		ld64_sym_add_u
574 #define	ld_sym_adjust_vis	ld64_sym_adjust_vis
575 #define	ld_sym_avl_comp		ld64_sym_avl_comp
576 #define	ld_sym_copy		ld64_sym_copy
577 #define	ld_sym_enter		ld64_sym_enter
578 #define	ld_sym_find		ld64_sym_find
579 #define	ld_sym_nodirect		ld64_sym_nodirect
580 #define	ld_sym_process		ld64_sym_process
581 #define	ld_sym_resolve		ld64_sym_resolve
582 #define	ld_sym_spec		ld64_sym_spec
583 #define	ld_targ			ld64_targ
584 #define	ld_targ_init_sparc	ld64_targ_init_sparc
585 #define	ld_targ_init_x86	ld64_targ_init_x86
586 #define	ld_vers_base		ld64_vers_base
587 #define	ld_vers_check_defs	ld64_vers_check_defs
588 #define	ld_vers_check_need	ld64_vers_check_need
589 #define	ld_vers_def_process	ld64_vers_def_process
590 #define	ld_vers_desc		ld64_vers_desc
591 #define	ld_vers_find		ld64_vers_find
592 #define	ld_vers_need_process	ld64_vers_need_process
593 #define	ld_vers_promote		ld64_vers_promote
594 #define	ld_vers_sym_process	ld64_vers_sym_process
595 #define	ld_vers_verify		ld64_vers_verify
596 
597 #else
598 
599 #define	ld_add_actrel		ld32_add_actrel
600 #define	ld_add_libdir		ld32_add_libdir
601 #define	ld_adj_movereloc	ld32_adj_movereloc
602 #define	ld_am_I_partial		ld32_am_I_partial
603 #define	ld_append_isp		ld32_append_isp
604 #define	ld_ar_member		ld32_ar_member
605 #define	ld_ar_setup		ld32_ar_setup
606 #define	ld_assign_got_TLS	ld32_assign_got_TLS
607 #define	ld_bswap_Word		ld32_bswap_Word
608 #define	ld_bswap_Xword		ld32_bswap_Xword
609 #define	ld_disp_errmsg		ld32_disp_errmsg
610 #define	ld_ent_check		ld32_ent_check
611 #define	ld_exit			ld32_exit
612 #define	ld_find_library		ld32_find_library
613 #define	ld_finish_libs		ld32_finish_libs
614 #define	ld_section_reld_name	ld32_section_reld_name
615 #define	ld_get_group		ld32_get_group
616 #define	ld_group_process	ld32_group_process
617 #define	ld_lib_setup		ld32_lib_setup
618 #define	ld_init			ld32_init
619 #define	ld_lcm			ld32_lcm
620 #define	ld_make_bss		ld32_make_bss
621 #define	ld_make_data		ld32_make_data
622 #define	ld_make_got		ld32_make_got
623 #define	ld_make_sunwbss		ld32_make_sunwbss
624 #define	ld_make_sunwdata	ld32_make_sunwdata
625 #define	ld_make_sunwmove	ld32_make_sunmove
626 #define	ld_make_text		ld32_make_text
627 #define	ld_map_out		ld32_map_out
628 #define	ld_map_parse		ld32_map_parse
629 #define	ld_open_outfile		ld32_open_outfile
630 #define	ld_place_section	ld32_place_section
631 #define	ld_process_archive	ld32_process_archive
632 #define	ld_process_files	ld32_process_files
633 #define	ld_process_flags	ld32_process_flags
634 #define	ld_process_ifl		ld32_process_ifl
635 #define	ld_process_ordered	ld32_process_ordered
636 #define	ld_process_sym_reloc	ld32_process_sym_reloc
637 #define	ld_reloc_GOT_relative	ld32_reloc_GOT_relative
638 #define	ld_reloc_plt		ld32_reloc_plt
639 #define	ld_reloc_remain_entry	ld32_reloc_remain_entry
640 #define	ld_reloc_targval_get	ld32_reloc_targval_get
641 #define	ld_reloc_targval_set	ld32_reloc_targval_set
642 #define	ld_sec_validate		ld32_sec_validate
643 #define	ld_sort_ordered		ld32_sort_ordered
644 #define	ld_sort_seg_list	ld32_sort_seg_list
645 #define	ld_sunw_ldmach		ld32_sunw_ldmach
646 #define	ld_sunwmove_preprocess	ld32_sunwmove_preprocess
647 #define	ld_sup_atexit		ld32_sup_atexit
648 #define	ld_sup_open		ld32_sup_open
649 #define	ld_sup_file		ld32_sup_file
650 #define	ld_sup_loadso		ld32_sup_loadso
651 #define	ld_sup_input_done	ld32_sup_input_done
652 #define	ld_sup_input_section	ld32_sup_input_section
653 #define	ld_sup_section		ld32_sup_section
654 #define	ld_sup_start		ld32_sup_start
655 #define	ld_swap_reloc_data	ld32_swap_reloc_data
656 #define	ld_sym_add_u		ld32_sym_add_u
657 #define	ld_sym_adjust_vis	ld32_sym_adjust_vis
658 #define	ld_sym_avl_comp		ld32_sym_avl_comp
659 #define	ld_sym_copy		ld32_sym_copy
660 #define	ld_sym_enter		ld32_sym_enter
661 #define	ld_sym_find		ld32_sym_find
662 #define	ld_sym_nodirect		ld32_sym_nodirect
663 #define	ld_sym_process		ld32_sym_process
664 #define	ld_sym_resolve		ld32_sym_resolve
665 #define	ld_sym_spec		ld32_sym_spec
666 #define	ld_targ			ld32_targ
667 #define	ld_targ_init_sparc	ld32_targ_init_sparc
668 #define	ld_targ_init_x86	ld32_targ_init_x86
669 #define	ld_vers_base		ld32_vers_base
670 #define	ld_vers_check_defs	ld32_vers_check_defs
671 #define	ld_vers_check_need	ld32_vers_check_need
672 #define	ld_vers_def_process	ld32_vers_def_process
673 #define	ld_vers_desc		ld32_vers_desc
674 #define	ld_vers_find		ld32_vers_find
675 #define	ld_vers_need_process	ld32_vers_need_process
676 #define	ld_vers_promote		ld32_vers_promote
677 #define	ld_vers_sym_process	ld32_vers_sym_process
678 #define	ld_vers_verify		ld32_vers_verify
679 
680 #endif
681 
682 extern uintptr_t	dbg_setup(const char *, Dbg_desc *, const char **, int);
683 
684 extern uintptr_t	ld_add_actrel(Word, Rel_desc *, Ofl_desc *);
685 extern uintptr_t	ld_add_libdir(Ofl_desc *, const char *);
686 extern void 		ld_adj_movereloc(Ofl_desc *, Rel_desc *);
687 extern Sym_desc * 	ld_am_I_partial(Rel_desc *, Xword);
688 extern int		ld_append_isp(Ofl_desc *, Os_desc *, Is_desc *, int);
689 extern void		ld_ar_member(Ar_desc *, Elf_Arsym *, Ar_aux *,
690 			    Ar_mem *);
691 extern Ar_desc		*ld_ar_setup(const char *, Elf *, Ofl_desc *);
692 extern uintptr_t	ld_assign_got_TLS(Boolean, Rel_desc *, Ofl_desc *,
693 			    Sym_desc *, Gotndx *, Gotref, Word, Word,
694 			    Word, Word);
695 
696 extern Word		ld_bswap_Word(Word);
697 extern Xword		ld_bswap_Xword(Xword);
698 
699 extern void		ld_disp_errmsg(const char *, Rel_desc *, Ofl_desc *);
700 
701 extern void		ld_ent_check(Ofl_desc *);
702 extern int		ld_exit(Ofl_desc *);
703 
704 extern uintptr_t	ld_find_library(const char *, Ofl_desc *);
705 extern uintptr_t	ld_finish_libs(Ofl_desc *);
706 
707 extern const char	*ld_section_reld_name(Sym_desc *, Is_desc *);
708 
709 extern Group_desc	*ld_get_group(Ofl_desc *, Is_desc *);
710 extern uintptr_t	ld_group_process(Is_desc *, Ofl_desc *);
711 
712 extern uintptr_t	ld_lib_setup(Ofl_desc *);
713 
714 extern void		ld_init(Ofl_desc *);
715 
716 extern Xword		ld_lcm(Xword, Xword);
717 
718 extern uintptr_t	ld_make_bss(Ofl_desc *, Xword, Xword, Bss_Type);
719 extern Is_desc		*ld_make_data(Ofl_desc *, size_t);
720 extern uintptr_t	ld_make_got(Ofl_desc *);
721 extern uintptr_t	ld_make_sunwbss(Ofl_desc *, size_t, Xword);
722 extern uintptr_t	ld_make_sunwdata(Ofl_desc *, size_t, Xword);
723 extern uintptr_t	ld_make_sunwmove(Ofl_desc *, int);
724 extern Is_desc		*ld_make_text(Ofl_desc *, size_t);
725 extern void		ld_map_out(Ofl_desc *);
726 extern uintptr_t	ld_map_parse(const char *, Ofl_desc *);
727 
728 extern uintptr_t	ld_open_outfile(Ofl_desc *);
729 
730 extern Os_desc		*ld_place_section(Ofl_desc *, Is_desc *, int, Word);
731 extern uintptr_t	ld_process_archive(const char *, int, Ar_desc *,
732 			    Ofl_desc *);
733 extern uintptr_t	ld_process_files(Ofl_desc *, int, char **);
734 extern uintptr_t	ld_process_flags(Ofl_desc *, int, char **);
735 extern Ifl_desc		*ld_process_ifl(const char *, const char *, int, Elf *,
736 			    Word, Ofl_desc *, Rej_desc *);
737 extern uintptr_t	ld_process_ordered(Ifl_desc *, Ofl_desc *, Word, Word);
738 extern uintptr_t	ld_process_sym_reloc(Ofl_desc *, Rel_desc *, Rel *,
739 			    Is_desc *, const char *);
740 
741 extern uintptr_t	ld_reloc_GOT_relative(Boolean, Rel_desc *, Ofl_desc *);
742 extern uintptr_t	ld_reloc_plt(Rel_desc *, Ofl_desc *);
743 extern void		ld_reloc_remain_entry(Rel_desc *, Os_desc *,
744 			    Ofl_desc *);
745 extern int		ld_reloc_targval_get(Ofl_desc *, Rel_desc *,
746 			    uchar_t *, Xword *);
747 extern int		ld_reloc_targval_set(Ofl_desc *, Rel_desc *,
748 			    uchar_t *, Xword);
749 
750 extern void		ld_sec_validate(Ofl_desc *);
751 extern uintptr_t	ld_sort_ordered(Ofl_desc *);
752 extern uintptr_t	ld_sort_seg_list(Ofl_desc *);
753 extern Half		ld_sunw_ldmach();
754 extern uintptr_t	ld_sunwmove_preprocess(Ofl_desc *);
755 extern void		ld_sup_atexit(Ofl_desc *, int);
756 extern void		ld_sup_open(Ofl_desc *, const char **, const char **,
757 			    int *, int, Elf **, Elf *ref, size_t,
758 			    const Elf_Kind);
759 extern void		ld_sup_file(Ofl_desc *, const char *, const Elf_Kind,
760 			    int flags, Elf *);
761 extern uintptr_t	ld_sup_loadso(Ofl_desc *, const char *);
762 extern void		ld_sup_input_done(Ofl_desc *);
763 extern void		ld_sup_section(Ofl_desc *, const char *, Shdr *, Word,
764 			    Elf_Data *, Elf *);
765 extern uintptr_t	ld_sup_input_section(Ofl_desc*, Ifl_desc *,
766 			    const char *, Shdr **, Word, Elf_Scn *, Elf *);
767 extern void		ld_sup_start(Ofl_desc *, const Half, const char *);
768 extern int		ld_swap_reloc_data(Ofl_desc *, Rel_desc *);
769 extern Sym_desc		*ld_sym_add_u(const char *, Ofl_desc *, Msg);
770 extern void		ld_sym_adjust_vis(Sym_desc *, Ofl_desc *);
771 extern int		ld_sym_avl_comp(const void *, const void *);
772 extern uintptr_t	ld_sym_copy(Sym_desc *);
773 extern Sym_desc		*ld_sym_enter(const char *, Sym *, Word, Ifl_desc *,
774 			    Ofl_desc *, Word, Word, Word, Half, avl_index_t *);
775 extern Sym_desc		*ld_sym_find(const char *, Word, avl_index_t *,
776 			    Ofl_desc *);
777 extern uintptr_t	ld_sym_nodirect(Is_desc *, Ifl_desc *, Ofl_desc *);
778 extern uintptr_t	ld_sym_process(Is_desc *, Ifl_desc *, Ofl_desc *);
779 extern uintptr_t	ld_sym_resolve(Sym_desc *, Sym *, Ifl_desc *,
780 			    Ofl_desc *, int, Word, Word);
781 extern uintptr_t	ld_sym_spec(Ofl_desc *);
782 
783 extern Target		ld_targ;
784 extern const Target	*ld_targ_init_sparc(void);
785 extern const Target	*ld_targ_init_x86(void);
786 
787 extern Ver_desc		*ld_vers_base(Ofl_desc *);
788 extern uintptr_t	ld_vers_check_defs(Ofl_desc *);
789 extern uintptr_t	ld_vers_check_need(Ofl_desc *);
790 extern uintptr_t	ld_vers_def_process(Is_desc *, Ifl_desc *, Ofl_desc *);
791 extern Ver_desc		*ld_vers_desc(const char *, Word, List *);
792 extern Ver_desc		*ld_vers_find(const char *, Word, List *);
793 extern uintptr_t	ld_vers_need_process(Is_desc *, Ifl_desc *, Ofl_desc *);
794 extern void		ld_vers_promote(Sym_desc *, Word, Ifl_desc *,
795 			    Ofl_desc *);
796 extern int		ld_vers_sym_process(Lm_list *, Is_desc *, Ifl_desc *);
797 extern int		ld_vers_verify(Ofl_desc *);
798 
799 extern uintptr_t	add_regsym(Sym_desc *, Ofl_desc *);
800 extern Word		hashbkts(Word);
801 extern Xword		lcm(Xword, Xword);
802 extern Listnode		*list_where(List *, Word);
803 
804 
805 /*
806  * Most platforms have both a 32 and 64-bit variant (e.g. EM_SPARC and
807  * EM_SPARCV9). To support this, there many files in libld that are built
808  * twice, once for ELFCLASS64 (_ELF64), and once for ELFCLASS32. In these
809  * files, we sometimes want to supply one value for the ELFCLASS32 case
810  * and another for ELFCLASS64. The LD_TARG_BYCLASS macro is used to do
811  * this. It is called with both both alternatives, and yields the one
812  * that applies to the current compilation environment.
813  */
814 #ifdef	_ELF64
815 #define	LD_TARG_BYCLASS(_ec32, _ec64) (_ec64)
816 #else
817 #define	LD_TARG_BYCLASS(_ec32, _ec64) (_ec32)
818 #endif
819 
820 
821 #ifdef	__cplusplus
822 }
823 #endif
824 
825 #endif /* _LIBLD_DOT_H */
826