7

我正在使用 valgrind 工具 - callgrind 和 kcachegrind 来分析一个大型项目,并且想知道是否有一种方法可以让 callgrind 报告所有函数(不仅仅是最昂贵的函数)的统计信息。

具体来说 - 当我在 kcachegrind 中可视化调用图时,它只包含那些非常昂贵的函数,但我想知道是否有办法将项目中的所有函数都包含在调用图中。用于生成分析信息的命令如下:

valgrind --dsymutil=yes --tool=callgrind $EXE 

我不确定是否必须为 valgrind 提供任何选项,或者可能以不同的优化方式编译应用程序。这可能是微不足道的,但我找不到解决方案。对此高度赞赏的任何指针。

谢谢 !

4

3 回答 3

7

我正在使用的命令是 valgrind --tool=callgrind --dump-instr=yes --collect-jumps=yes $EXE,据我所知,它包括调用图中的所有函数。

希望能帮助到你。

于 2016-02-25T16:17:34.803 回答
7

在此处输入图像描述

昨天我突然想到了。如图所示,我在kcachegrind的调用图中发现,有一个右键菜单,在里面可以设置节点可视化的阈值。

还有一个选项“无最小值”,但不能选择。我想可能是因为,如果每个函数,无论它多么微不足道,都占用一个节点,那么图可能太大而无法处理。

我刚刚发现脚本gprof2dot可以处理这个问题。
该脚本可以将 callgrind 的输出转换为点,可以将其可视化为图形。该脚本有两个相关参数:

  • -n PERCENTAGE, --node-thres=PERCENTAGE消除低于此阈值的节点 [默认值:0.5]。为了可视化图中的所有节点,您可以将参数设置为-n0
  • -e PERCENTAGE--edge-thres=PERCENTAGE以消除低于此阈值的边缘 [默认值:0.1]。为了可视化图中的所有边,您可以设置参数,如-e0

为了生成完整的调用图,您将使用两个选项 (-n0-e0)。

我试过这个,但是,由于生成的图形太大,点软件警告我“图形对于 cairo-renderer 位图来说太大了。按 0.328976 缩放以适应。”但是您可以将输出格式设置为 eps可以处理这个。您还可以更改参数以适应您的目标。

例子

假设您有一个 callgrind 输出文件,名为callgrind.out.1992. 要生成完整的调用图,您将使用:

gprof2dot.py -n0 -e0 ./callgrind.out.1992 -f callgrind

要生成PNG图形的输出图像,您可以运行以下命令:

gprof2dot -n0 -e0 ./callgrind.out.1992 -f callgrind > out.dot

dot -Tpng out.dot -o out.png

现在你有了一张out.png完整的图表。

请注意使用-f参数指定配置文件格式(callgrind在我们的例子中)。

于 2017-05-10T12:14:58.540 回答
1

我将使用允许您生成完整调用图的信息来完成 rengar 的答案,并提供完整过程的示例。

您可以使用gprof2dot在调用图中显示所有函数。该脚本可以将 callgrind 的输出转换为dot,可以将其可视化为图形。该脚本有两个相关参数:

  • -n PERCENTAGE--node-thres=PERCENTAGE以消除低于此阈值的节点 [默认值:0.5]。为了可视化图中的所有节点,您应该将此参数设置为-n0
  • -e PERCENTAGE--edge-thres=PERCENTAGE以消除低于此阈值的边缘 [默认值:0.1]。为了可视化图中的所有边,您应该将此参数设置为-e0

为了生成完整的调用图,您将使用以下两个选项:-n0-e0.

例子

假设您有一个 callgrind 输出文件,名为callgrind.out.1992. 要生成完整的调用图,您将使用:

gprof2dot -n0 -e0 ./callgrind.out.1992 -f callgrind

要生成图形的 PNG 输出图像,您可以运行以下命令:

gprof2dot -n0 -e0 ./callgrind.out.1992 -f callgrind > out.dot

dot -Tpng out.dot -o out.png

现在你有了一张out.png完整的图表。

请注意使用-f参数指定配置文件格式(callgrind在我们的例子中)。

于 2018-03-19T18:31:51.613 回答