xref: /freebsd/libexec/rtld-elf/i386/rtld_machdep.h (revision a42a42e9b9cd091de549a3b144e89d7c4b5bc2fd)
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 
32b5393d9fSDoug Rabson struct Struct_Obj_Entry;
33b5393d9fSDoug Rabson 
34d5b537d0SJohn Polstra /* Return the address of the .dynamic section in the dynamic linker. */
35d5b537d0SJohn Polstra #define rtld_dynamic(obj) \
36d5b537d0SJohn Polstra     ((const Elf_Dyn *)((obj)->relocbase + (Elf_Addr)&_DYNAMIC))
37d5b537d0SJohn Polstra 
38962fdc46SJohn Polstra /* Fixup the jump slot at "where" to transfer control to "target". */
39b5393d9fSDoug Rabson static inline Elf_Addr
40b5393d9fSDoug Rabson reloc_jmpslot(Elf_Addr *where, Elf_Addr target,
41a42a42e9SThomas Moestl 	      const struct Struct_Obj_Entry *obj,
42a42a42e9SThomas Moestl 	      const struct Struct_Obj_Entry *refobj, const Elf_Rel *rel)
43b5393d9fSDoug Rabson {
44b5393d9fSDoug Rabson     dbg("reloc_jmpslot: *%p = %p", (void *)(where),
45b5393d9fSDoug Rabson 	(void *)(target));
46b5393d9fSDoug Rabson     (*(Elf_Addr *)(where) = (Elf_Addr)(target));
47b5393d9fSDoug Rabson     return target;
48b5393d9fSDoug Rabson }
49b5393d9fSDoug Rabson 
50b5393d9fSDoug Rabson #define make_function_pointer(def, defobj) \
51b5393d9fSDoug Rabson 	((defobj)->relocbase + (def)->st_value)
52962fdc46SJohn Polstra 
5314a55adfSPeter Wemm #define call_initfini_pointer(obj, target) \
5414a55adfSPeter Wemm 	(((InitFunc)(target))())
5514a55adfSPeter Wemm 
56630df077SJohn Polstra static inline void
57630df077SJohn Polstra atomic_decr_int(volatile int *p)
58630df077SJohn Polstra {
59d1c02bccSJohn Polstra     __asm __volatile ("lock; decl %0" : "+m"(*p) : : "cc");
60630df077SJohn Polstra }
61630df077SJohn Polstra 
62630df077SJohn Polstra static inline void
63630df077SJohn Polstra atomic_incr_int(volatile int *p)
64630df077SJohn Polstra {
65d1c02bccSJohn Polstra     __asm __volatile ("lock; incl %0" : "+m"(*p) : : "cc");
66630df077SJohn Polstra }
67630df077SJohn Polstra 
68630df077SJohn Polstra static inline void
69630df077SJohn Polstra atomic_add_int(volatile int *p, int val)
70630df077SJohn Polstra {
71630df077SJohn Polstra     __asm __volatile ("lock; addl %1, %0"
72d1c02bccSJohn Polstra 	: "+m"(*p)
73d1c02bccSJohn Polstra 	: "ri"(val)
74630df077SJohn Polstra 	: "cc");
75630df077SJohn Polstra }
76630df077SJohn Polstra 
77d5b537d0SJohn Polstra #endif
78