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