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

时间:2016-09-02 15:41:08

标签: c++ gcc instrumentation gcov gprof

背景

我们有嵌入式GUI产品的测试人员,当测试人员声明"测试失败时,有时我们的开发人员难以重现确切的问题,因为我们没有确切记录发生的事情。

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

问题

我们想要一个解决方案,其中编译器生成额外的检测代码,使我们能够查看事件的确切序列,包括 minimum

  1. 功能进入/退出(已由-finstrument-functions提供)
  2. control-flow语句输入,即输入if / else,我们跳转到
  3. 的case语句

    日志看起来像这样:

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

    一些额外的好处是

    1. 功能输入 AND 退出的参数值(适用于传递引用类型)
    2. 功能返回值
    3. 问题

      是否有任何gcc工具甚至付费工具可以自动执行此工具?

1 个答案:

答案 0 :(得分:1)

你可以使用gdb,你可以自动化(我已经有了工具,你找到它here或者你可以尝试使用gcov。

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