Подтвердить что ты не робот

Как запустить gdb с LD_PRELOAD?

У меня есть программа, использующая LD_PRELOAD. Программа должна запускаться как это "LD_PRELOAD =/путь/в/libfoo.so qemu -U LD_PRELOAD a.out", если без gdb.

Вот что я сделал во время работы gdb.

(gdb) set environment LD_PRELOAD=/nfs_home/chenwj/tools/lib/libdbo.so

(gdb) file /nfs_home/chenwj/tools/bin/qemu-i386

(gdb) r -U LD_PRELOAD bzip2_base.i386-m32-gcc44-annotated input.source 1

Но gdb дал мне ошибку ниже

Starting program: /nfs_home/chenwj/tools/bin/qemu-i386 -U LD_PRELOAD bzip2_base.i386-m32-gcc44-annotated input.source 1

bash: open "/bin/bash" failed: Permission denied

During startup program exited with code 66.

Любое одобрение приветствуется.

С уважением, chenwj

4b9b3361

Ответ 1

GDB не вызывает ваш исполняемый файл напрямую. Вместо этого он выполняет

bash -c '/nfs_home/chenwj/tools/bin/qemu-i386  -U LD_PRELOAD bzip2_base.i386-m32-gcc44-annotated input.source 1'

Это делается так, чтобы bash выполнял перенаправление ввода/вывода (которое вы не используете).

Я предполагаю, что /bin/bash не работает, когда LD_PRELOAD = libdbo.so действует, хотя я не понимаю точный характер сбоя.

Один из способов обойти эту проблему - создать исполняемый файл обертки, выполнив C эквивалент этого:

export LD_PRELOAD=/nfs_home/chenwj/tools/lib/libdbo.so
exec /nfs_home/chenwj/tools/bin/qemu-i386 "[email protected]"

и отлаживать этот исполняемый файл (без установки LD_PRELOAD). Вы увидите дополнительный SIGTRAP, когда обертка execve() обернута qemu-i386, которую вы должны игнорировать и continue.