blob: 0425031c810bae159922df8589a74715233295b6 [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
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 Hughes5470c182016-07-22 11:36:17 -070028
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080029#ifndef __DLFCN_H__
30#define __DLFCN_H__
31
Evgenii Stepanov0a3637d2016-07-06 13:20:59 -070032#include <stdint.h>
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080033#include <sys/cdefs.h>
34
35__BEGIN_DECLS
36
Matt Fischere2a8b1f2009-12-31 12:17:40 -060037typedef struct {
Elliott Hughes5470c182016-07-22 11:36:17 -070038 /* Pathname of shared object that contains address. */
zijunzhao447c3462023-03-01 01:32:08 +000039 const char* _Nullable dli_fname;
Elliott Hughes5470c182016-07-22 11:36:17 -070040 /* Address at which shared object is loaded. */
zijunzhao447c3462023-03-01 01:32:08 +000041 void* _Nullable dli_fbase;
Elliott Hughes5470c182016-07-22 11:36:17 -070042 /* Name of nearest symbol with address lower than addr. */
zijunzhao447c3462023-03-01 01:32:08 +000043 const char* _Nullable dli_sname;
Elliott Hughes5470c182016-07-22 11:36:17 -070044 /* Exact address of symbol named in dli_sname. */
zijunzhao447c3462023-03-01 01:32:08 +000045 void* _Nullable dli_saddr;
Matt Fischere2a8b1f2009-12-31 12:17:40 -060046} Dl_info;
47
zijunzhao447c3462023-03-01 01:32:08 +000048void* _Nullable dlopen(const char* _Nullable __filename, int __flag);
Steven Morelandf61b2b12023-11-01 00:16:31 +000049
50/**
51 * [dlclose(3)](http://man7.org/linux/man-pages/man3/dlclose.3.html)
52 * decrements the reference count for the given shared library (and
53 * any libraries brought in by that library's DT_NEEDED entries).
54 *
55 * If a library's reference count hits zero, it may be unloaded.
56 * Code that relies on this is not portable, and may not work on
57 * future versions of Android.
58 *
59 * dlclose() is dangerous because function pointers may or may not
60 * be rendered invalid, global data may or may not be rendered invalid,
61 * and memory may or may not leak. Code with global constructors is
62 * especially problematic. Instead of dlclose, prefer to leave the
63 * library open or, if cleanup is necessary, dlopen() the library in
64 * a child process which can later be killed by the parent or call
65 * exit() itself.
66 *
67 * Returns 0 on success, and returns -1 on failure, in which case
68 * dlerror() can be used to retrieve the specific error.
69 */
zijunzhao447c3462023-03-01 01:32:08 +000070int dlclose(void* _Nonnull __handle);
Steven Morelandf61b2b12023-11-01 00:16:31 +000071
zijunzhao447c3462023-03-01 01:32:08 +000072char* _Nullable dlerror(void);
Steven Morelandf61b2b12023-11-01 00:16:31 +000073
zijunzhao447c3462023-03-01 01:32:08 +000074/* (RTLD_DEFAULT is null for LP64, but -1 for LP32) */
75void* _Nullable dlsym(void* __BIONIC_COMPLICATED_NULLNESS __handle, const char* _Nullable __symbol);
76/* (RTLD_DEFAULT is null for LP64, but -1 for LP32) */
77void* _Nullable dlvsym(void* __BIONIC_COMPLICATED_NULLNESS __handle, const char* _Nullable __symbol, const char* _Nullable __version) __INTRODUCED_IN(24);
78int dladdr(const void* _Nonnull __addr, Dl_info* _Nonnull __info);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080079
Elliott Hughes8ad40932017-06-15 15:12:29 -070080#define RTLD_LOCAL 0
81#define RTLD_LAZY 0x00001
82#define RTLD_NOW 0x00002
83#define RTLD_NOLOAD 0x00004
84#define RTLD_GLOBAL 0x00100
85#define RTLD_NODELETE 0x01000
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080086
Elliott Hughes8ad40932017-06-15 15:12:29 -070087#if !defined(__LP64__)
88/* LP32 is broken for historical reasons. */
89#undef RTLD_NOW
90#define RTLD_NOW 0x00000
91#undef RTLD_GLOBAL
92#define RTLD_GLOBAL 0x00002
Dmitriy Ivanovb648a8a2014-05-19 15:06:58 -070093#endif
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080094
Dmitriy Ivanovb648a8a2014-05-19 15:06:58 -070095#if defined (__LP64__)
Elliott Hughes5470c182016-07-22 11:36:17 -070096#define RTLD_DEFAULT __BIONIC_CAST(reinterpret_cast, void*, 0)
97#define RTLD_NEXT __BIONIC_CAST(reinterpret_cast, void*, -1L)
Dmitriy Ivanovb648a8a2014-05-19 15:06:58 -070098#else
Elliott Hughes5470c182016-07-22 11:36:17 -070099#define RTLD_DEFAULT __BIONIC_CAST(reinterpret_cast, void*, 0xffffffff)
100#define RTLD_NEXT __BIONIC_CAST(reinterpret_cast, void*, 0xfffffffe)
101#endif
102
The Android Open Source Project1dc9e472009-03-03 19:28:35 -0800103__END_DECLS
104
Elliott Hughesff26a162017-08-17 22:34:21 +0000105#endif