GDB-скрипт для изоляции потока на основе значения переменной - PullRequest
1 голос
/ 13 июня 2019

У меня есть программа, имеющая более 300 потоков, к которым я подключил GDB.Мне нужно идентифицировать один конкретный поток, чей стек вызовов имеет фрейм, содержащий переменную, значение которой я хочу использовать для сопоставления.Могу ли я написать сценарий в gdb?

(gdb) thread 3
[Switching to thread 3 (Thread 0x7f16c1eeb700 (LWP 18833))]
#4  0x00007f17f3a3bdd5 in start_thread () from /lib64/libpthread.so.0
(gdb) backtrace
#0  0x00007f17f3a3fd12 in pthread_cond_timedwait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
#1  0x00007f17e72838be in __afr_shd_healer_wait (healer=healer@entry=0x7f17e05203d0) at afr-self-heald.c:101
#2  0x00007f17e728392d in afr_shd_healer_wait (healer=healer@entry=0x7f17e05203d0) at afr-self-heald.c:125
#3  0x00007f17e72848e8 in afr_shd_index_healer (data=0x7f17e05203d0) at afr-self-heald.c:572
#4  0x00007f17f3a3bdd5 in start_thread () from /lib64/libpthread.so.0
#5  0x00007f17f3302ead in clone () from /lib64/libc.so.6
(gdb) frame 3
#3  0x00007f17e72848e8 in afr_shd_index_healer (data=0x7f17e05203d0) at afr-self-heald.c:572
572                     afr_shd_healer_wait (healer);
(gdb) p this->name
$6 = 0x7f17e031b910 "testvol-replicate-0"

Например, можно ли запустить макрос для циклического прохождения каждого потока, перейти к кадру 3 в каждом из них, проверить переменную this->name и вывести номер theadтолько если значение соответствует testvol-replicate-0?

1 Ответ

0 голосов
/ 09 июля 2019

Возможно интегрировать Python в GDB. Затем, с помощью Python GDB API, вы можете перебирать потоки и искать совпадения. Ниже приведены два примера отладочных потоков с помощью GDB и Python.

https://www.linuxjournal.com/article/11027
https://fy.blackhats.net.au/blog/html/2017/08/04/so_you_want_to_script_gdb_with_python.html

...