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