From: Rich Felker Date: Sat, 29 Jun 2013 16:46:46 +0000 (-0400) Subject: implement minimal dlinfo function X-Git-Tag: v0.9.11~3 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=780cbbe63ad9e60ef30dbcb2d74271e899dae245;p=oweals%2Fmusl.git implement minimal dlinfo function --- diff --git a/include/dlfcn.h b/include/dlfcn.h index e2f57b53..db26194b 100644 --- a/include/dlfcn.h +++ b/include/dlfcn.h @@ -17,6 +17,8 @@ extern "C" { #define RTLD_NEXT ((void *)-1) #define RTLD_DEFAULT ((void *)0) +#define RTLD_DI_LINKMAP 2 + int dlclose(void *); char *dlerror(void); void *dlopen(const char *, int); @@ -30,6 +32,7 @@ typedef struct { void *dli_saddr; } Dl_info; int dladdr(void *, Dl_info *); +int dlinfo(void *, int, void *); #endif #ifdef __cplusplus diff --git a/src/ldso/dlinfo.c b/src/ldso/dlinfo.c new file mode 100644 index 00000000..4748eaf8 --- /dev/null +++ b/src/ldso/dlinfo.c @@ -0,0 +1,8 @@ +#include + +int __dlinfo(void *, int, void *); + +int dlinfo(void *dso, int req, void *res) +{ + return __dlinfo(dso, req, res); +} diff --git a/src/ldso/dynlink.c b/src/ldso/dynlink.c index ac4b669f..7031d03a 100644 --- a/src/ldso/dynlink.c +++ b/src/ldso/dynlink.c @@ -1273,6 +1273,18 @@ int __dladdr (void *addr, Dl_info *info) } #endif +int __dlinfo(void *dso, int req, void *res) +{ + if (invalid_dso_handle(dso)) return -1; + if (req != RTLD_DI_LINKMAP) { + snprintf(errbuf, sizeof errbuf, "Unsupported request %d", req); + errflag = 1; + return -1; + } + *(struct link_map **)res = dso; + return 0; +} + char *dlerror() { if (!errflag) return 0;