когда символы объектного файла становятся динамическими символами в исполняемом файле

У меня есть несколько объектных файлов (из C ++), которые выпали из системы сборки. У них есть несколько extern "C"символы связи, которые я хочу использовать в программе и которые доступны через dlopen/dlsym откуда-то еще

При компиляции в исполняемый файл с помощью gcc эти символы не отображаются с помощью nm -D <executable-here> (то есть afaik, они не являются динамическими символами).

Как заставить их стать открытыми как динамические символы в скомпилированном исполняемом файле?

Я могу изменить флаги сборки для объектных файлов и для исполняемого файла, но изменить то, как файлы C ++ попадают в конечный исполняемый файл (т.е. не превращая их в объектные файлы в первую очередь), сложно.

(GCC 4.8, ld 2.24)

РЕДАКТИРОВАТЬ: Я сталкивался с этим вопросом, который может или не может быть то, что я спрашиваю, но я не совсем уверен.
Используйте dlsym в статическом бинарном файле

2

Решение

Вы можете посмотреть на --export-dynamic опция ld:

   -E
--export-dynamic
--no-export-dynamic
When creating a dynamically linked executable, using the -E option
or the --export-dynamic option causes the linker to add all symbols
to the dynamic symbol table.  The dynamic symbol table is the set
of symbols which are visible from dynamic objects at run time.

If you do not use either of these options (or use the
--no-export-dynamic option to restore the default behavior), the
dynamic symbol table will normally contain only those symbols which
are referenced by some dynamic object mentioned in the link.

If you use "dlopen" to load a dynamic object which needs to refer
back to the symbols defined by the program, rather than some other
dynamic object, then you will probably need to use this option when
linking the program itself.

You can also use the dynamic list to control what symbols should be
added to the dynamic symbol table if the output format supports it.
See the description of --dynamic-list.

Note that this option is specific to ELF targeted ports.  PE
targets support a similar function to export all symbols from a DLL
or EXE; see the description of --export-all-symbols below.

Также, если ни один из объектов во время ссылки не ссылается на ваши внешние символы, вы можете поместить их в --dynamic-list чтобы убедиться, что они экспортируются.


Пример:

$ cat test.cc
#include <stdio.h>

int main() {
printf("Hello, world\n");
}

extern "C" void export_this() {
printf("Hello, world from export_this\n");
}

$ g++ -o test -W{all,extra} -Wl,--export-dynamic test.cc

$ ./test
Hello, world

$ nm --dynamic test | grep export_this
00000000004007f5 T export_this # <---- here you go
2

Другие решения


По вопросам рекламы [email protected]