xref: /aosp_15_r20/bionic/libc/include/dlfcn.h (revision 8d67ca893c1523eb926b9080dbe4e2ffd2a27ba1)
1*8d67ca89SAndroid Build Coastguard Worker /*
2*8d67ca89SAndroid Build Coastguard Worker  * Copyright (C) 2008 The Android Open Source Project
3*8d67ca89SAndroid Build Coastguard Worker  * All rights reserved.
4*8d67ca89SAndroid Build Coastguard Worker  *
5*8d67ca89SAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
6*8d67ca89SAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions
7*8d67ca89SAndroid Build Coastguard Worker  * are met:
8*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions of source code must retain the above copyright
9*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer.
10*8d67ca89SAndroid Build Coastguard Worker  *  * Redistributions in binary form must reproduce the above copyright
11*8d67ca89SAndroid Build Coastguard Worker  *    notice, this list of conditions and the following disclaimer in
12*8d67ca89SAndroid Build Coastguard Worker  *    the documentation and/or other materials provided with the
13*8d67ca89SAndroid Build Coastguard Worker  *    distribution.
14*8d67ca89SAndroid Build Coastguard Worker  *
15*8d67ca89SAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16*8d67ca89SAndroid Build Coastguard Worker  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17*8d67ca89SAndroid Build Coastguard Worker  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18*8d67ca89SAndroid Build Coastguard Worker  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19*8d67ca89SAndroid Build Coastguard Worker  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20*8d67ca89SAndroid Build Coastguard Worker  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21*8d67ca89SAndroid Build Coastguard Worker  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22*8d67ca89SAndroid Build Coastguard Worker  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23*8d67ca89SAndroid Build Coastguard Worker  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24*8d67ca89SAndroid Build Coastguard Worker  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25*8d67ca89SAndroid Build Coastguard Worker  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26*8d67ca89SAndroid Build Coastguard Worker  * SUCH DAMAGE.
27*8d67ca89SAndroid Build Coastguard Worker  */
28*8d67ca89SAndroid Build Coastguard Worker 
29*8d67ca89SAndroid Build Coastguard Worker #pragma once
30*8d67ca89SAndroid Build Coastguard Worker 
31*8d67ca89SAndroid Build Coastguard Worker #include <sys/cdefs.h>
32*8d67ca89SAndroid Build Coastguard Worker 
33*8d67ca89SAndroid Build Coastguard Worker #include <stdint.h>
34*8d67ca89SAndroid Build Coastguard Worker 
35*8d67ca89SAndroid Build Coastguard Worker /**
36*8d67ca89SAndroid Build Coastguard Worker  * @addtogroup libdl Dynamic Linker
37*8d67ca89SAndroid Build Coastguard Worker  * @{
38*8d67ca89SAndroid Build Coastguard Worker  */
39*8d67ca89SAndroid Build Coastguard Worker 
40*8d67ca89SAndroid Build Coastguard Worker /**
41*8d67ca89SAndroid Build Coastguard Worker  * \file
42*8d67ca89SAndroid Build Coastguard Worker  * Standard dynamic library support.
43*8d67ca89SAndroid Build Coastguard Worker  * See also the Android-specific functionality in `<android/dlext.h>`.
44*8d67ca89SAndroid Build Coastguard Worker  */
45*8d67ca89SAndroid Build Coastguard Worker 
46*8d67ca89SAndroid Build Coastguard Worker __BEGIN_DECLS
47*8d67ca89SAndroid Build Coastguard Worker 
48*8d67ca89SAndroid Build Coastguard Worker /**
49*8d67ca89SAndroid Build Coastguard Worker  * dladdr() returns information using this structure.
50*8d67ca89SAndroid Build Coastguard Worker  */
51*8d67ca89SAndroid Build Coastguard Worker typedef struct {
52*8d67ca89SAndroid Build Coastguard Worker   /** Pathname of the shared object that contains the given address. */
53*8d67ca89SAndroid Build Coastguard Worker   const char* _Nullable dli_fname;
54*8d67ca89SAndroid Build Coastguard Worker   /** Address at which the shared object is loaded. */
55*8d67ca89SAndroid Build Coastguard Worker   void* _Nullable dli_fbase;
56*8d67ca89SAndroid Build Coastguard Worker   /** Name of the nearest symbol with an address lower than the given address. */
57*8d67ca89SAndroid Build Coastguard Worker   const char* _Nullable dli_sname;
58*8d67ca89SAndroid Build Coastguard Worker   /** Exact address of the symbol named in `dli_sname`. */
59*8d67ca89SAndroid Build Coastguard Worker   void* _Nullable dli_saddr;
60*8d67ca89SAndroid Build Coastguard Worker } Dl_info;
61*8d67ca89SAndroid Build Coastguard Worker 
62*8d67ca89SAndroid Build Coastguard Worker /**
63*8d67ca89SAndroid Build Coastguard Worker  * [dlopen(3)](https://man7.org/linux/man-pages/man3/dlopen.3.html)
64*8d67ca89SAndroid Build Coastguard Worker  * loads the given shared library.
65*8d67ca89SAndroid Build Coastguard Worker  *
66*8d67ca89SAndroid Build Coastguard Worker  * See also android_dlopen_ext().
67*8d67ca89SAndroid Build Coastguard Worker  *
68*8d67ca89SAndroid Build Coastguard Worker  * Returns a pointer to an opaque handle for use with other <dlfcn.h> functions
69*8d67ca89SAndroid Build Coastguard Worker  * on success, and returns NULL on failure, in which case dlerror() can be used
70*8d67ca89SAndroid Build Coastguard Worker  * to retrieve the specific error.
71*8d67ca89SAndroid Build Coastguard Worker  */
72*8d67ca89SAndroid Build Coastguard Worker void* _Nullable dlopen(const char* _Nullable __filename, int __flag);
73*8d67ca89SAndroid Build Coastguard Worker 
74*8d67ca89SAndroid Build Coastguard Worker /**
75*8d67ca89SAndroid Build Coastguard Worker  * [dlclose(3)](https://man7.org/linux/man-pages/man3/dlclose.3.html)
76*8d67ca89SAndroid Build Coastguard Worker  * decrements the reference count for the given shared library (and
77*8d67ca89SAndroid Build Coastguard Worker  * any libraries brought in by that library's DT_NEEDED entries).
78*8d67ca89SAndroid Build Coastguard Worker  *
79*8d67ca89SAndroid Build Coastguard Worker  * If a library's reference count hits zero, it may be unloaded.
80*8d67ca89SAndroid Build Coastguard Worker  * Code that relies on this is not portable, and may not work on
81*8d67ca89SAndroid Build Coastguard Worker  * future versions of Android.
82*8d67ca89SAndroid Build Coastguard Worker  *
83*8d67ca89SAndroid Build Coastguard Worker  * dlclose() is dangerous because function pointers may or may not
84*8d67ca89SAndroid Build Coastguard Worker  * be rendered invalid, global data may or may not be rendered invalid,
85*8d67ca89SAndroid Build Coastguard Worker  * and memory may or may not leak. Code with global constructors is
86*8d67ca89SAndroid Build Coastguard Worker  * especially problematic. Instead of dlclose, prefer to leave the
87*8d67ca89SAndroid Build Coastguard Worker  * library open or, if cleanup is necessary, dlopen() the library in
88*8d67ca89SAndroid Build Coastguard Worker  * a child process which can later be killed by the parent or call
89*8d67ca89SAndroid Build Coastguard Worker  * exit() itself.
90*8d67ca89SAndroid Build Coastguard Worker  *
91*8d67ca89SAndroid Build Coastguard Worker  * Note also that dlclose() interacts badly with thread local variables
92*8d67ca89SAndroid Build Coastguard Worker  * with non-trivial destructors, with the
93*8d67ca89SAndroid Build Coastguard Worker  * (exact behavior varying by API level)[https://android.googlesource.com/platform/bionic/+/main/android-changes-for-ndk-developers.md#dlclose-interacts-badly-with-thread-local-variables-with-non_trivial-destructors].
94*8d67ca89SAndroid Build Coastguard Worker  *
95*8d67ca89SAndroid Build Coastguard Worker  * Returns 0 on success, and returns -1 on failure, in which case
96*8d67ca89SAndroid Build Coastguard Worker  * dlerror() can be used to retrieve the specific error.
97*8d67ca89SAndroid Build Coastguard Worker  */
98*8d67ca89SAndroid Build Coastguard Worker int dlclose(void* _Nonnull __handle);
99*8d67ca89SAndroid Build Coastguard Worker 
100*8d67ca89SAndroid Build Coastguard Worker /**
101*8d67ca89SAndroid Build Coastguard Worker  * [dlerror(3)](https://man7.org/linux/man-pages/man3/dlerror.3.html)
102*8d67ca89SAndroid Build Coastguard Worker  * returns a human-readable error message describing the most recent
103*8d67ca89SAndroid Build Coastguard Worker  * failure from one of the <dlfcn.h> functions on the calling thread.
104*8d67ca89SAndroid Build Coastguard Worker  *
105*8d67ca89SAndroid Build Coastguard Worker  * This function also clears the error, so a second call (or a call
106*8d67ca89SAndroid Build Coastguard Worker  * before any failure) will return NULL.
107*8d67ca89SAndroid Build Coastguard Worker  *
108*8d67ca89SAndroid Build Coastguard Worker  * Returns a pointer to an error on success, and returns NULL if no
109*8d67ca89SAndroid Build Coastguard Worker  * error is pending.
110*8d67ca89SAndroid Build Coastguard Worker  */
111*8d67ca89SAndroid Build Coastguard Worker char* _Nullable dlerror(void);
112*8d67ca89SAndroid Build Coastguard Worker 
113*8d67ca89SAndroid Build Coastguard Worker /**
114*8d67ca89SAndroid Build Coastguard Worker  * [dlsym(3)](https://man7.org/linux/man-pages/man3/dlsym.3.html)
115*8d67ca89SAndroid Build Coastguard Worker  * returns a pointer to the symbol with the given name in the shared
116*8d67ca89SAndroid Build Coastguard Worker  * library represented by the given handle. The handle may have been
117*8d67ca89SAndroid Build Coastguard Worker  * returned from dlopen(), or can be RTLD_DEFAULT or RTLD_NEXT.
118*8d67ca89SAndroid Build Coastguard Worker  *
119*8d67ca89SAndroid Build Coastguard Worker  * Returns the address of the symbol on success, and returns NULL on failure,
120*8d67ca89SAndroid Build Coastguard Worker  * in which case dlerror() can be used to retrieve the specific error.
121*8d67ca89SAndroid Build Coastguard Worker  */
122*8d67ca89SAndroid Build Coastguard Worker void* _Nullable dlsym(void* __BIONIC_COMPLICATED_NULLNESS __handle, const char* _Nullable __symbol);
123*8d67ca89SAndroid Build Coastguard Worker 
124*8d67ca89SAndroid Build Coastguard Worker /**
125*8d67ca89SAndroid Build Coastguard Worker  * [dlvsym(3)](https://man7.org/linux/man-pages/man3/dlvsym.3.html)
126*8d67ca89SAndroid Build Coastguard Worker  * returns a pointer to the symbol with the given name and version in the shared
127*8d67ca89SAndroid Build Coastguard Worker  * library represented by the given handle. The handle may have been
128*8d67ca89SAndroid Build Coastguard Worker  * returned from dlopen(), or can be RTLD_DEFAULT or RTLD_NEXT.
129*8d67ca89SAndroid Build Coastguard Worker  *
130*8d67ca89SAndroid Build Coastguard Worker  * Returns the address of the symbol on success, and returns NULL on failure,
131*8d67ca89SAndroid Build Coastguard Worker  * in which case dlerror() can be used to retrieve the specific error.
132*8d67ca89SAndroid Build Coastguard Worker  */
133*8d67ca89SAndroid Build Coastguard Worker 
134*8d67ca89SAndroid Build Coastguard Worker #if __BIONIC_AVAILABILITY_GUARD(24)
135*8d67ca89SAndroid Build Coastguard Worker void* _Nullable dlvsym(void* __BIONIC_COMPLICATED_NULLNESS __handle, const char* _Nullable __symbol, const char* _Nullable __version) __INTRODUCED_IN(24);
136*8d67ca89SAndroid Build Coastguard Worker #endif /* __BIONIC_AVAILABILITY_GUARD(24) */
137*8d67ca89SAndroid Build Coastguard Worker 
138*8d67ca89SAndroid Build Coastguard Worker 
139*8d67ca89SAndroid Build Coastguard Worker /**
140*8d67ca89SAndroid Build Coastguard Worker  * [dladdr(3)](https://man7.org/linux/man-pages/man3/dladdr.3.html)
141*8d67ca89SAndroid Build Coastguard Worker  * returns information about the symbol at the given address.
142*8d67ca89SAndroid Build Coastguard Worker  *
143*8d67ca89SAndroid Build Coastguard Worker  * Returns non-zero on success, and returns 0 on failure. Note that unlike
144*8d67ca89SAndroid Build Coastguard Worker  * the other <dlfcn.h> functions, in this case dlerror() will _not_ have
145*8d67ca89SAndroid Build Coastguard Worker  * more information.
146*8d67ca89SAndroid Build Coastguard Worker  */
147*8d67ca89SAndroid Build Coastguard Worker int dladdr(const void* _Nonnull __addr, Dl_info* _Nonnull __info);
148*8d67ca89SAndroid Build Coastguard Worker 
149*8d67ca89SAndroid Build Coastguard Worker /**
150*8d67ca89SAndroid Build Coastguard Worker  * A dlsym()/dlvsym() handle that returns the first symbol found in any
151*8d67ca89SAndroid Build Coastguard Worker  * shared library using the default search order.
152*8d67ca89SAndroid Build Coastguard Worker  */
153*8d67ca89SAndroid Build Coastguard Worker #define RTLD_DEFAULT  __BIONIC_CAST(reinterpret_cast, void*, 0)
154*8d67ca89SAndroid Build Coastguard Worker 
155*8d67ca89SAndroid Build Coastguard Worker /**
156*8d67ca89SAndroid Build Coastguard Worker  * A dlsym()/dlvsym() handle that returns the first symbol found in any
157*8d67ca89SAndroid Build Coastguard Worker  * shared library that appears _after_ the object containing the caller.
158*8d67ca89SAndroid Build Coastguard Worker  */
159*8d67ca89SAndroid Build Coastguard Worker #define RTLD_NEXT     __BIONIC_CAST(reinterpret_cast, void*, -1L)
160*8d67ca89SAndroid Build Coastguard Worker 
161*8d67ca89SAndroid Build Coastguard Worker /**
162*8d67ca89SAndroid Build Coastguard Worker  * A dlopen() flag to not make symbols from this library available to later
163*8d67ca89SAndroid Build Coastguard Worker  * libraries. See also RTLD_GLOBAL.
164*8d67ca89SAndroid Build Coastguard Worker  */
165*8d67ca89SAndroid Build Coastguard Worker #define RTLD_LOCAL    0
166*8d67ca89SAndroid Build Coastguard Worker 
167*8d67ca89SAndroid Build Coastguard Worker /**
168*8d67ca89SAndroid Build Coastguard Worker  * Not supported on Android. Android always uses RTLD_NOW for security reasons.
169*8d67ca89SAndroid Build Coastguard Worker  * Resolving all undefined symbols before dlopen() returns means that RELRO
170*8d67ca89SAndroid Build Coastguard Worker  * protections can be applied to the PLT before dlopen() returns.
171*8d67ca89SAndroid Build Coastguard Worker  */
172*8d67ca89SAndroid Build Coastguard Worker #define RTLD_LAZY     0x00001
173*8d67ca89SAndroid Build Coastguard Worker 
174*8d67ca89SAndroid Build Coastguard Worker /** A dlopen() flag to resolve all undefined symbols before dlopen() returns. */
175*8d67ca89SAndroid Build Coastguard Worker #define RTLD_NOW      0x00002
176*8d67ca89SAndroid Build Coastguard Worker 
177*8d67ca89SAndroid Build Coastguard Worker /**
178*8d67ca89SAndroid Build Coastguard Worker  * A dlopen() flag to not actually load the given library;
179*8d67ca89SAndroid Build Coastguard Worker  * used to test whether the library is already loaded.
180*8d67ca89SAndroid Build Coastguard Worker  */
181*8d67ca89SAndroid Build Coastguard Worker #define RTLD_NOLOAD   0x00004
182*8d67ca89SAndroid Build Coastguard Worker 
183*8d67ca89SAndroid Build Coastguard Worker /**
184*8d67ca89SAndroid Build Coastguard Worker  * A dlopen() flag to make symbols from this library available to later
185*8d67ca89SAndroid Build Coastguard Worker  * libraries. See also RTLD_LOCAL.
186*8d67ca89SAndroid Build Coastguard Worker  */
187*8d67ca89SAndroid Build Coastguard Worker #define RTLD_GLOBAL   0x00100
188*8d67ca89SAndroid Build Coastguard Worker 
189*8d67ca89SAndroid Build Coastguard Worker /**
190*8d67ca89SAndroid Build Coastguard Worker  * A dlopen() flag to ignore later dlclose() calls on this library.
191*8d67ca89SAndroid Build Coastguard Worker  */
192*8d67ca89SAndroid Build Coastguard Worker #define RTLD_NODELETE 0x01000
193*8d67ca89SAndroid Build Coastguard Worker 
194*8d67ca89SAndroid Build Coastguard Worker /* LP32 has historical ABI breakage. */
195*8d67ca89SAndroid Build Coastguard Worker #if !defined(__LP64__)
196*8d67ca89SAndroid Build Coastguard Worker #undef RTLD_DEFAULT
197*8d67ca89SAndroid Build Coastguard Worker #define RTLD_DEFAULT  __BIONIC_CAST(reinterpret_cast, void*, 0xffffffff)
198*8d67ca89SAndroid Build Coastguard Worker #undef RTLD_NEXT
199*8d67ca89SAndroid Build Coastguard Worker #define RTLD_NEXT     __BIONIC_CAST(reinterpret_cast, void*, 0xfffffffe)
200*8d67ca89SAndroid Build Coastguard Worker #undef RTLD_NOW
201*8d67ca89SAndroid Build Coastguard Worker #define RTLD_NOW      0x00000
202*8d67ca89SAndroid Build Coastguard Worker #undef RTLD_GLOBAL
203*8d67ca89SAndroid Build Coastguard Worker #define RTLD_GLOBAL   0x00002
204*8d67ca89SAndroid Build Coastguard Worker #endif
205*8d67ca89SAndroid Build Coastguard Worker 
206*8d67ca89SAndroid Build Coastguard Worker __END_DECLS
207*8d67ca89SAndroid Build Coastguard Worker 
208*8d67ca89SAndroid Build Coastguard Worker /** @} */
209