В моей программе есть код, подобный следующему
/* libname may be a relative path */
void loadLib(char const *libname) {
void *handle = dlopen(libname);
/* ... */
dlclose(handle);
}
В /* .. */
мне нужно прочитать файл карты памяти /proc/self/maps
, чтобы найти адрес виртуальной памяти, на который отображается libname
, а также мне нужно открыть библиотеку, чтобы найти в ней определенные разделы. Для этого мне нужно абсолютное имя, найденное dlopen
при поиске в различных местах (например, в файле кэша ldconfig
). Как я могу получить это имя файла?
Это то, к чему я наконец пришел ( да, это код C ++, тем не менее, тег C имеет смысл для этого вопроса, поскольку dlopen
используется как с C ++, так и с C, и мой вопрос подходит как для POSIX определяет его для C. ).
boost::shared_ptr<void> dl;
if(void *handle = dlopen(libfile, RTLD_LAZY)) {
dl.reset(handle, &dlclose);
} else {
printdlerr();
return -1;
}
/* update sofile to be an absolute file name */
{
struct link_map *map;
dlinfo(dl.get(), RTLD_DI_LINKMAP, &map);
if(!map) {
return -1;
}
char *real = realpath(map->l_name, NULL);
if(!real)
return -1;
sofile.reset(real, &free);
}
libfile
- относительное / простое имя файла. Карта даст непростое имя файла (т.е. не foo.so
, но может быть ./foo.so
). После этого я использовал realpath
, чтобы получить окончательный абсолютный путь. Работает хорошо!