Сначала вы можете запустить программу и отладить ее с помощью pid. Это решение, конечно, не охватывает все случаи.
Другой подход заключается в использовании возможностей Linux для межпроцессного взаимодействия. Короче говоря, вы перенаправляете вывод ret
в специальный файл FIFO («именованный канал») и затем читаете из этого FIFO через отладчик. Вот как это делается. От bash запустите:
mkfifo foo
Это создаст специальный файл в вашем каталоге, который будет служить именованным каналом . Когда вы пишете текст в этот файл (используя тот же синтаксис echo "Hello" >foo
), программа записи будет блокироваться, пока кто-то не прочитает данные из файла (например, cat <foo
). В нашем случае процесс, управляемый GDB, будет читать из этого файла.
После того, как вы создали fifo, запустите из bash:
ret > foo & # ampersand because it may block as nobody is reading from foo
gdb blah
Затем в командной строке GDB запустите
run <foo
И получите желаемый эффект. Обратите внимание, что вы не можете прочитать данные из fifo (как и из обычного канала) дважды: когда вы прочитаете все данные, процесс blah
умирает, и вы должны повторить команду записи в foo (вы можете сделать это из другого окна оболочки).
Когда вы закончите, удалите fifo с помощью rm foo
(или поместите его в каталог, где он будет автоматически удален при перезапуске системы, например, /tmp
).