gpt4 book ai didi

Linux远程调试线程错误(GDBServer)

转载 作者:太空宇宙 更新时间:2023-11-04 11:24:48 29 4
gpt4 key购买 nike

我有一个 ARM 设备,我想调试它。我的主机是 Linux 12.04,我使用的是 Eclipse。GDBServer 在我的目标设备上运行。

我可以调试单进程应用程序。但是当我想调试包含 pthread 对象的多线程应用程序时,调试失败。我一步一步跑,但当我来到

pthread_create(&timerSettings.timerThread, NULL, &timerThread, NULL);

行调试器给出以下错误“0x40174c84”没有可用的来源。

那我该怎么办呢?

有什么建议吗?

谢谢。

最佳答案

通过逐步运行,您实际上是在要求调试器进入 phread_create() 函数,当然您没有它的源代码。如果我怀疑您预计调试器会将您带到线程的源头,那么我有一些坏消息;它不是那样工作的。

如果您跨过将创建线程的 pthread_create(),如果您在调试器透视图中,该线程应该显示在 Eclipse 的任务列表中。您可以从那里选择您的线程。如果你这样做,源代码 View 将跳转到该线程必须到达的任何地方(更多坏消息即将到来)。请记住,所有这些都需要相对现代的 gdb 版本(我记得是 6 及更高版本)。

现在您的问题真正开始了。在 gdb 中使用线程调试不是很好。当您选择线程时,您可能会发现没有显示源代码。这是因为尽管您已经跨过了 pthread_create(),但这并不意味着线程已经进展到您的第一行源代码。这是因为当 gdb 挂起一个程序时,该程序中的每个线程都被挂起,并且新线程可能还没有脱离标准库的线程初始代码。因此,您必须在线程中源代码的第一行设置一个断点,并允许程序自由运行,直到遇到该断点。

但是等等 - 与此同时,您的主线程已经跳到远处,您已经失去了对它的控制。你不能在上面设置断点,因为只要遇到任何断点,你的程序就会被 gdb 挂起。

简而言之,这是武器库中的痛点。

您可以在 Eclipse 中键入 gdb 命令。这有一点帮助,因为您可以做一些事情,比如设置线程特定的断点,并将 gdb 设置为不间断模式和后台异步模式。这些总比没有好,但根据我的经验,不要完成全部工作。更糟糕的是,Eclipse 似乎完全没有意识到它们(我可能已经过时了),因此您只能手动输入命令。在这种情况下,您最好不要首先在 Eclipse 中运行。

我建议你看看this .一个好的技巧是在所有线程的开头将 sleep 置于循环中,循环条件是一些永远不会改变的变量。这样,当创建线程时,您可以切换到它,设置您想要的任何断点,然后自己更改循环变量的值,这样当您继续线程时,它会退出循环并运行到您的断点。

--编辑--

看来我已经过时了。看看this .看起来 Eclipse 现在知道不间断模式和特定于线程的断点。那些在每个线程中耦合一个启动时捕获的 sleep 循环(也许 Eclipse 现在也可以解决这个问题)将使调试线程变得可以容忍。

关于Linux远程调试线程错误(GDBServer),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15437893/

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