gdb:无法找到新线程:系统更新后的一般错误

dse*_*ert 5 gdb arm pthreads

我在ARM板上运行基于OpenEmbedded的Linux,我的应用程序正在运行.我曾经运行内核2.6.35,gdb 6.8和gcc 4.3.最近我将系统更新到内核2.6.37,gdb 7.4(也试过7.3)和gcc 4.6.

现在,我的应用程序不能再调试(在ARM板上),每当我尝试在gdb中运行它时,我得到错误"gdb:找不到新线程:泛型错误".该应用程序使用pthreads并链接到pthreads(readelf将libpthread.so.0列为依赖项).到目前为止我发现的建议解决方案都建议链接到我已经在做的pthread.我发现的另一个建议是使用LD_PRELOAD =/lib/libpthread.so.0,这对我没有任何影响.

调试应用程序的x86版本没有问题.

编辑:要回答第一个答案中提出的问题,我在目标(ARM)上使用gdb,即没有交叉gdb.我还没有剥离libpthread.so.0(/lib/libpthread-2.9.so:ELF 32位LSB共享对象,ARM,版本1(SYSV),动态链接(使用共享库),用于GNU/Linux 2.6. 16,未剥离).glibc保持在2.9版本,更新包括重新编译整个linux映像

EDIT2:删除/ lib/libthread-db*允许调试(带有后续警告,显然某些功能不起作用)

EDIT3:使用set debug libthread-db 1我得到:

Starting program: /home/root/app
Trying host libthread_db library: libthread_db.so.1.
Host libthread_db.so.1 resolved to: /lib/libthread_db.so.1.
td_ta_new failed: application not linked with libthread
thread_db_load_search returning 0
Trying host libthread_db library: libthread_db.so.1.
Host libthread_db.so.1 resolved to: /lib/libthread_db.so.1.
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib/libthread_db.so.1".
warning: Unable to set global thread event mask: generic error
Warning: find_new_threads_once: find_new_threads_callback: cannot get thread info: generic error
Found 0 new threads in iteration 0.
Warning: find_new_threads_once: find_new_threads_callback: cannot get thread info: generic error
Found 0 new threads in iteration 1.
Warning: find_new_threads_once: find_new_threads_callback: cannot get thread info: generic error
Found 0 new threads in iteration 2.
Warning: find_new_threads_once: find_new_threads_callback: cannot get thread info: generic error
Found 0 new threads in iteration 3.
thread_db_load_search returning 1
Warning: find_new_threads_once: find_new_threads_callback: cannot get thread info: generic error
Found 0 new threads in iteration 0.
Cannot find new threads: generic error
(gdb) Write failed: Broken pipe
Run Code Online (Sandbox Code Playgroud)

Emp*_*ian 6

导致此错误的原因有两个:

  1. libpthread.so.0和之间的不匹配libthread_db.so.1
  2. 你已经剥离了 libpthread.so.0

您的信息并不完全清楚:

  1. 您是否正在使用跨GDB从x86主机调试在ARM上运行的应用程序?
  2. glibc除了更新内核等之外,你有更新(或重建)吗?

如果你剥离了libpthread.so.0,那就不要这样做 - libthread_db需要它被剥离.

如果要进行交叉调试,请确保libthread_db.so.1在主机glibc上重建以匹配目标.

更新:

没有交叉调试
没有剥离libpthread

所以,你的GDB中的某些东西或者glibc似乎已被打破.你可以试着看看它是什么

  1. libthread_db回去,和
  2. (gdb) set debug libthread-db 1
  3. (gdb) run

更新2:

警告:无法设置全局线程事件掩码:泛型错误

这意味着GDB能够td_ta_set_event在libthread_db中查找函数并调用它,但该函数返回了一个错误.这可能发生的一种方式是GDB无法找到__nptl_threads_events功能libpthread.so.0.这个命令产生什么:

nm /lib/libpthread.so.0 | grep __nptl_threads_events
Run Code Online (Sandbox Code Playgroud)

如果该命令产生输出,例如:

000000000021c294 b __nptl_threads_events
Run Code Online (Sandbox Code Playgroud)

然后我不确定还有什么失败.你可能不得不调试GDB本身来弄清楚发生了什么.

另一方面,如果grep上面没有产生输出,那么你的工具链就会出现问题:你必须弄清楚为什么这个变量不会出现在你的重建中libpthread.so.0.