Performance Counter Monitor(PCM)是一个由英特尔开发的,也是基于PMU(performance monitoring unit)一个性能检测工具。
它是运行在msr 内核模块(perf是内核系统调用吧?)上的,提供了C++ API。
相关的源码可以从git上查看
https://github.com/erikarn/intel-pcm/blob/ecc0cf608dfd9366f4d2d9fa48dc821af1c26f33/src/cpucounters.cpp
这里主要记录下PCM在程序中的简单使用
使用性能计数器之前,应首先对它们进行初始化。完成初始化后,可在相关代码段之前和之后,也就是两个时间点捕获计数器状态。
不同例程会捕获面向内核、插槽或整个系统的计数器,并将它们的状态存储于相应的数据结构中。其它例程则可基于这些状态计算性能指标。
下方代码片段展示了一个具体的使用示例:
PCM * m = Monitor::getInstance();
if (m->program() != PCM::Success) // program counters
return -1; // error occured during programming
SystemCounterState before_sstate = getSystemCounterState();
<i>[run your code here] </i>
SystemCounterState after_sstate =