gcc-gprof/gcov/other-如何获取函数调用/出口+控制流语句的序列



背景

我们有嵌入式GUI产品的测试人员,当测试人员宣布"测试失败"时,有时我们开发人员很难重现确切的问题,因为我们没有发生的事情的确切痕迹。

我们目前确实有一个日志框架,但我们的开发人员必须在代码中手动输入这些日志语句,这很好。除了当一个难以重现的错误发生时,我们在"正确"的位置没有日志语句,然后当我们用相同的步骤重新构建、重新运行测试时,我们会得到不同的结果。

问题

我们想要一个解决方案,其中编译器生成额外的指令插入代码,使我们能够看到事件的确切序列,包括最小

  1. 功能进入/退出(已由-finstrument-functions提供(
  2. 控制流语句输入,即输入if/else,我们跳转到哪个case语句

日志如下所示:

int main() entered
if-line 5 entered
else-line 10 entered
void EventLoop() entered
. . .

是一些额外的好东西

  1. 函数入口AND出口上的参数值(用于传递引用类型(
  2. 函数返回值

问题

有没有gcc工具,甚至是付费工具可以自动进行这种检测?

你可以使用gdb来实现这一点,也可以自动化(我已经有了一个工具,你可以在这里找到它,或者你可以尝试使用gcov.

gcov实现是这样的,它在启动程序时加载最新的gcov数据。但是:您可以手动转储和加载数据。如果您调用__gcov_flush,它将转储当前数据并重置当前状态。但是:如果您多次这样做,它将始终合并数据,因此您还需要重命名gcov数据文件。

最新更新