gpt4 book ai didi

gdb:找不到新线程:系统更新后出现一般错误

转载 作者:行者123 更新时间:2023-12-04 18:48:05 26 4
gpt4 key购买 nike

我正在运行我的应用程序的 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

最佳答案

此错误有两个常见原因:

  • 您在 libpthread.so.0 之间不匹配和 libthread_db.so.1
  • 你已经脱光了 libpthread.so.0

  • 您的信息并不完全清楚:
  • 您是否使用跨 GDB 从 x86 主机调试在 ARM 上运行的应用程序?
  • 你更新(或重建)了吗glibc除了更新内核等

  • 如果你脱光了 libpthread.so.0 ,然后不要那样做 -- libthread_db需要它不被剥离。

    如果您是交叉调试,请确保重建 libthread_db.so.1在主机上匹配 glibc估计的正好。

    更新:

    not cross-debugging
    did not strip libpthread



    因此,您的 GDB 或 glibc 中的某些内容似乎已经坏掉了。你可以试着看看那是什么
  • 推杆拆除 libthread_db返回,和
  • (gdb) set debug libthread-db 1
  • (gdb) run

  • 更新 2:

    warning: Unable to set global thread event mask: generic error



    这意味着 GDB 能够查找 td_ta_set_event libthread_db 中的函数,并调用它,但该函数返回错误。发生这种情况的一种方式是 GDB 无法找到 __nptl_threads_events函数在 libpthread.so.0 .此命令产生什么:
    nm /lib/libpthread.so.0 | grep __nptl_threads_events

    如果该命令产生输出,例如:
    000000000021c294 b __nptl_threads_events

    那么我不确定还有什么失败了。您可能需要调试 GDB 本身才能弄清楚发生了什么。

    如果另一方面 grep上面没有产生任何输出,那么这是您的工具链的问题:您必须弄清楚为什么该变量没有出现在您重建的 libpthread.so.0 中。 .

    关于gdb:找不到新线程:系统更新后出现一般错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10840621/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com