perf-stat-d/sample.out输出为:
Performance counter stats for './sample.out':
0.586266 task-clock (msec) # 0.007 CPUs utilized
2 context-switches # 0.003 M/sec
1 cpu-migrations # 0.002 M/sec
116 page-faults # 0.198 M/sec
7,35,790 cycles # 1.255 GHz [81.06%]
<not counted> stalled-cycles-frontend
<not supported> stalled-cycles-backend
<not counted> instructions
<not counted> branches
<not counted> branch-misses
<not supported> L1-dcache-loads:HG
<not counted> L1-dcache-load-misses:HG
<not counted> LLC-loads:HG
<not supported> LLC-load-misses:HG
0.088013919 seconds time elapsed
我读到为什么会出现在。但我甚至得到了一些基本的计数器,比如说明书、分支等。有人能建议如何让它工作吗?
有趣的是:
sudo perf-stat睡眠3
给出输出:
Performance counter stats for 'sleep 3':
0.598484 task-clock (msec) # 0.000 CPUs utilized
2 context-switches # 0.003 M/sec
0 cpu-migrations # 0.000 K/sec
181 page-faults # 0.302 M/sec
<not counted> cycles
<not counted> stalled-cycles-frontend
<not supported> stalled-cycles-backend
<not counted> instructions
<not counted> branches
<not counted> branch-misses
sudo perf stat-C1睡眠3
Performance counter stats for 'CPU(s) 1':
3002.640578 task-clock (msec) # 1.001 CPUs utilized [100.00%]
425 context-switches # 0.142 K/sec [100.00%]
9 cpu-migrations # 0.003 K/sec [100.00%]
5 page-faults # 0.002 K/sec
7,82,97,019 cycles # 0.026 GHz [33.32%]
9,38,21,585 stalled-cycles-frontend # 119.83% frontend cycles idle [33.32%]
<not supported> stalled-cycles-backend
3,09,81,643 instructions # 0.40 insns per cycle
# 3.03 stalled cycles per insn [33.32%]
70,15,390 branches # 2.336 M/sec [33.32%]
6,38,644 branch-misses # 9.10% of all branches [33.32%]
3.001075650 seconds time elapsed
为什么这是出乎意料的工作。??
感谢
对于非常短的程序,perf stat -d
的典型问题不是统计采样,而是多路复用(方括号中的百分比表示[33%]
-此计数器仅占运行时间的33%左右)。
您要求您的PMU一次监视太多的事件,而perf无法同时映射实际硬件(PMU——CPU的性能监视单元)上所需的所有计数器。典型的PMU可能有4、7或8个独立计数器,但如果启用了一些SMT技术(例如,HT-HyperThreading),则数字可能会除以2。
当您要求perf统计这么多计数器时(您的perf-stat输出中有6个受支持的HW事件),它会将所有计数器分成更小的组。当perf_events有机会更改组时,内核会在某些时间点更改组,例如在任务时钟周期(~3ms)。
您可以通过较小的事件集将您的跑步分成多个-每次跑步任意数量的SW事件和2-4个HW事件:
perf stat -e task-clock,page-faults,cycles,stalled-cycles-frontend
perf stat -e task-clock,page-faults,cycles,instructions
perf stat -e task-clock,page-faults,branches,branch-misses
perf stat -e task-clock,page-faults,L1-dcache-load-misses:HG,LLC-loads:HG
sudo perf stat -C 1 sleep 3
配置了CPU 1上发生的一切、所有进程和内核代码。这就是为什么需要sudo
。这也是任务时钟约为3002ms的原因。
perf stat sleep 3
(不需要sudo
)仅配置sleep(1)
进程本身。任务时钟的CPU时间约为0.6毫秒。
sleep
本身几乎什么都不做;运行的大多数指令都在动态链接器中。正如@osgx的回答所指出的,您缺少计数,因为perf
在您的机器上没有足够的硬件计数器,所以它正在多路复用它们。没有计数的计数器一定是在sleep
睡眠而非运行时录制的。
为了获得良好的结果,将你的微基准标记放在一个至少运行100毫秒的循环中,最好是~1秒,以获得良好的信噪比,这取决于你正在计数的计数器。