0

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

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

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

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

所以我该怎么做?

有什么建议吗?

谢谢。

4

1 回答 1

1

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

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

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

但是等等——与此同时,你的主线程已经跳到远处,而你已经失去了对它的控制。您不能在其上设置断点,因为每当遇到任何断点时,gdb 都会暂停您的程序。

简而言之,这是阿森纳的正确痛苦。

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

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

- 编辑 -

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

于 2013-03-16T08:18:33.870 回答