【问题标题】:Perf annotate, display only source codeperf 注释,只显示源代码
【发布时间】:2013-09-02 15:44:55
【问题描述】:

我正在使用 Perf 执行一些分析实验。

但是,我想知道特定代码区域的结果,在这种情况下,查看每行源代码(在这种情况下为 C/C++)的结果(百分比)会简化任务。

perf annotate 有一个显示 ASM+Source Code 的视图,还可以选择关闭显示源代码。我想知道如何完成此选项的另一端,即仅显示源代码 + 每行事件的百分比并隐藏 ASM 输出。 perf 可以做到这一点吗?

其他工具的建议吗?我也在使用 Vtune,但是我不想做的分析正在工作。 Valgrind 没有问题,太慢了。

我在运行 Ubuntu 13.04 的 x64 上。

【问题讨论】:

  • rotateright.com/zoom 获取 Zoom 的 30 天免费评估 - 它以一种非常优雅的方式完全满足您的需求。
  • 我很久以前就使用过 Oprofile 但停止了,我不记得确切原因,但我猜是因为它很慢,无论如何它似乎都在做我想做的事。我会试一试。我还将尝试使用 Zoom。
  • vinay hunachyal:当我结束使用 Oprofile 并获得与使用 Perf 相同的结果时,您可以给出答案,我会接受。
  • @JohnTortugo,你是如何设法让 perf annotate 显示源代码的?我只会拆解。我知道这是因为我们不使用 -g 选项进行编译,因为它是一个发布二进制文件,我们希望它快速运行。那么问题来了,使用 -g 编译是获得 perf annotate 以显示源代码的唯一方法吗?

标签: linux performance linux-kernel perf


【解决方案1】:

不幸的是,perf-annotate 在幕后使用了 objdump,这似乎无法仅显示来源(-S 意味着 -d)。

如果您知道使 objdump 正常运行的方法,请参阅 symbol__annotate() tools/perf/util/annotate.c

snprintf(command, sizeof(command),
         "%s %s%s --start-address=0x%016" PRIx64
         " --stop-address=0x%016" PRIx64
         " -d %s %s -C %s|grep -v %s|expand",
         objdump_path ? objdump_path : "objdump",
         disassembler_style ? "-M " : "",
         disassembler_style ? disassembler_style : "",
         map__rip_2objdump(map, sym->start),
         map__rip_2objdump(map, sym->end+1),
         symbol_conf.annotate_asm_raw ? "" : "--no-show-raw",
         symbol_conf.annotate_src ? "-S" : "",
         symfs_filename, filename);

【讨论】:

  • 是的,我就是这么想的!但是我决定使用 Oprofile 会更简单。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2015-01-08
  • 2020-07-27
  • 2016-04-03
  • 2011-05-23
  • 2015-01-09
  • 1970-01-01
  • 2012-07-20
相关资源
最近更新 更多