xref: /freebsd/libexec/rtld-elf/i386/rtld_machdep.h (revision 4352999e0e6cd2d971642274202f03e50ef9c4c2)
1d5b537d0SJohn Polstra /*-
2630df077SJohn Polstra  * Copyright (c) 1999, 2000 John D. Polstra.
3d5b537d0SJohn Polstra  * All rights reserved.
4d5b537d0SJohn Polstra  *
5d5b537d0SJohn Polstra  * Redistribution and use in source and binary forms, with or without
6d5b537d0SJohn Polstra  * modification, are permitted provided that the following conditions
7d5b537d0SJohn Polstra  * are met:
8d5b537d0SJohn Polstra  * 1. Redistributions of source code must retain the above copyright
9d5b537d0SJohn Polstra  *    notice, this list of conditions and the following disclaimer.
10d5b537d0SJohn Polstra  * 2. Redistributions in binary form must reproduce the above copyright
11d5b537d0SJohn Polstra  *    notice, this list of conditions and the following disclaimer in the
12d5b537d0SJohn Polstra  *    documentation and/or other materials provided with the distribution.
13d5b537d0SJohn Polstra  *
14d5b537d0SJohn Polstra  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15d5b537d0SJohn Polstra  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16d5b537d0SJohn Polstra  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17d5b537d0SJohn Polstra  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18d5b537d0SJohn Polstra  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19d5b537d0SJohn Polstra  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20d5b537d0SJohn Polstra  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21d5b537d0SJohn Polstra  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22d5b537d0SJohn Polstra  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23d5b537d0SJohn Polstra  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24d5b537d0SJohn Polstra  * SUCH DAMAGE.
25d5b537d0SJohn Polstra  *
267f3dea24SPeter Wemm  * $FreeBSD$
27d5b537d0SJohn Polstra  */
28d5b537d0SJohn Polstra 
29d5b537d0SJohn Polstra #ifndef RTLD_MACHDEP_H
30d5b537d0SJohn Polstra #define RTLD_MACHDEP_H	1
31d5b537d0SJohn Polstra 
326d5d786fSAlexander Kabaev #include <sys/types.h>
336d5d786fSAlexander Kabaev #include <machine/atomic.h>
346d5d786fSAlexander Kabaev 
35b5393d9fSDoug Rabson struct Struct_Obj_Entry;
36b5393d9fSDoug Rabson 
37d5b537d0SJohn Polstra /* Return the address of the .dynamic section in the dynamic linker. */
38d5b537d0SJohn Polstra #define rtld_dynamic(obj) \
39d5b537d0SJohn Polstra     ((const Elf_Dyn *)((obj)->relocbase + (Elf_Addr)&_DYNAMIC))
40d5b537d0SJohn Polstra 
41962fdc46SJohn Polstra /* Fixup the jump slot at "where" to transfer control to "target". */
42b5393d9fSDoug Rabson static inline Elf_Addr
43b5393d9fSDoug Rabson reloc_jmpslot(Elf_Addr *where, Elf_Addr target,
44a42a42e9SThomas Moestl 	      const struct Struct_Obj_Entry *obj,
45a42a42e9SThomas Moestl 	      const struct Struct_Obj_Entry *refobj, const Elf_Rel *rel)
46b5393d9fSDoug Rabson {
47370e5ea4SDag-Erling Smørgrav #ifdef dbg
48b5393d9fSDoug Rabson     dbg("reloc_jmpslot: *%p = %p", (void *)(where),
49b5393d9fSDoug Rabson 	(void *)(target));
50370e5ea4SDag-Erling Smørgrav #endif
51b5393d9fSDoug Rabson     (*(Elf_Addr *)(where) = (Elf_Addr)(target));
52b5393d9fSDoug Rabson     return target;
53b5393d9fSDoug Rabson }
54b5393d9fSDoug Rabson 
55b5393d9fSDoug Rabson #define make_function_pointer(def, defobj) \
56b5393d9fSDoug Rabson 	((defobj)->relocbase + (def)->st_value)
57962fdc46SJohn Polstra 
5814a55adfSPeter Wemm #define call_initfini_pointer(obj, target) \
5914a55adfSPeter Wemm 	(((InitFunc)(target))())
6014a55adfSPeter Wemm 
6183aa9cc0SKonstantin Belousov #define call_init_pointer(obj, target) \
6283aa9cc0SKonstantin Belousov 	(((InitArrFunc)(target))(main_argc, main_argv, environ))
6383aa9cc0SKonstantin Belousov 
64*4352999eSKonstantin Belousov extern uint32_t cpu_feature;
65*4352999eSKonstantin Belousov extern uint32_t cpu_feature2;
66*4352999eSKonstantin Belousov extern uint32_t cpu_stdext_feature;
67*4352999eSKonstantin Belousov extern uint32_t cpu_stdext_feature2;
68*4352999eSKonstantin Belousov #define	call_ifunc_resolver(ptr) \
69*4352999eSKonstantin Belousov 	(((Elf_Addr (*)(uint32_t, uint32_t, uint32_t, uint32_t))ptr)( \
70*4352999eSKonstantin Belousov 	    cpu_feature, cpu_feature2, cpu_stdext_feature, cpu_stdext_feature2))
71*4352999eSKonstantin Belousov 
72017246d0SDoug Rabson #define round(size, align) \
73017246d0SDoug Rabson 	(((size) + (align) - 1) & ~((align) - 1))
74017246d0SDoug Rabson #define calculate_first_tls_offset(size, align) \
75017246d0SDoug Rabson 	round(size, align)
76017246d0SDoug Rabson #define calculate_tls_offset(prev_offset, prev_size, size, align) \
77017246d0SDoug Rabson 	round((prev_offset) + (size), align)
78017246d0SDoug Rabson #define calculate_tls_end(off, size) 	(off)
79017246d0SDoug Rabson 
80017246d0SDoug Rabson typedef struct {
81017246d0SDoug Rabson     unsigned long ti_module;
82017246d0SDoug Rabson     unsigned long ti_offset;
83017246d0SDoug Rabson } tls_index;
84017246d0SDoug Rabson 
850c4f9ecdSKonstantin Belousov void *___tls_get_addr(tls_index *ti) __attribute__((__regparm__(1))) __exported;
860c4f9ecdSKonstantin Belousov void *__tls_get_addr(tls_index *ti) __exported;
87017246d0SDoug Rabson 
88cb38d494SKonstantin Belousov #define	RTLD_DEFAULT_STACK_PF_EXEC	PF_X
89cb38d494SKonstantin Belousov #define	RTLD_DEFAULT_STACK_EXEC		PROT_EXEC
90cb38d494SKonstantin Belousov 
918fd53f45SWarner Losh #define md_abi_variant_hook(x)
928fd53f45SWarner Losh 
93d5b537d0SJohn Polstra #endif
94