У меня есть система "fsimage.so", которая требует mkdirp, который, как оказалось, живет в libgen.so.Но fsimage.so не знает этого.Например:
# ldd /usr/lib/python2.4/vendor-packages/fsimage.so
libfsimage.so.1.0 => /usr/lib/libfsimage.so.1.0
libxml2.so.2 => /lib/libxml2.so.2
libgcc_s.so.1 => /usr/sfw/lib/libgcc_s.so.1
libpthread.so.1 => /lib/libpthread.so.1
libz.so.1 => /lib/libz.so.1
libm.so.2 => /lib/libm.so.2
libsocket.so.1 => /lib/libsocket.so.1
libnsl.so.1 => /lib/libnsl.so.1
libc.so.1 => /lib/libc.so.1
libmp.so.2 => /lib/libmp.so.2
libmd.so.1 => /lib/libmd.so.1
# ./test
Traceback (most recent call last):
File "./test", line 26, in ?
import fsimage
ImportError: ld.so.1: isapython2.4: fatal: relocation error: file /usr/lib/python2.4/vendor-packages/fsimage.so: symbol mkdirp: referenced symbol not found
# LD_PRELOAD=/usr/lib/libgen.so ./test
Usage: ./test
Естественно, если бы у меня были источники и т. Д., Я мог бы просто связать его снова и добавить «-lgen», и он добавит libgen.so в качестве зависимости.
Но, как упражнение в хакерстве, скажем, у меня нет источников, и я просто хотел добавить, что fsimage.so должен также загрузить libgen.so.Использование elfedit / objcopy и т. Д. Разве это невозможно?Я не думаю, что я могу использовать «ld» для использования .so в качестве входных данных и написать новый .so с дополнительной библиотекой?
# elfdump /usr/lib/python2.4/vendor-packages/fsimage.so|grep NEEDED
[0] NEEDED 0x5187 libfsimage.so.1.0
[1] NEEDED 0x5152 libxml2.so.2
[2] NEEDED 0x5171 libgcc_s.so.1
Первая попытка переполнения стека, легко для меня :)*