您知道在用户空间中,Linux的高分辨率时钟(最小微秒)的任何C/C++实现(即使它是不可移植的)吗?
目标是测量一些低延迟操作所经过的时间间隔。我测量了内核空间时钟会导致一些时间,延迟尖峰。
根据我对Red Hat7.2的研究:
谢了。
一种选择是通过
#include <regex>
#include <string>
#include <fstream>
#include <iostream>
double cpu_base_frequency() {
std::regex re("model name\\s*:[^@]+@\\s*([0-9.]+)\\s*GHz");
std::ifstream cpuinfo("/proc/cpuinfo");
std::smatch m;
for(std::string line; getline(cpuinfo, line);) {
regex_match(line, m, re);
if(m.size() == 2)
return std::stod(m[1]);
}
return 1; // Couldn't determine the CPU base frequency. Just count TSC ticks.
}
double const CPU_GHZ_INV = 1 / cpu_base_frequency();
int main() {
auto t0 = __builtin_ia32_rdtsc();
auto t1 = __builtin_ia32_rdtsc();
std::cout << (t1 - t0) * CPU_GHZ_INV << "nsec\n";
}
来自Intel文档的更多信息:
恒定的TSC行为确保每个时钟节拍的持续时间是均匀的,并且即使处理器内核改变频率,也支持将TSC用作挂钟定时器。这是向前发展的架构行为。
不变TSC将在所有ACPI P,C和T状态下以恒定速率运行。这是向前发展的架构行为。在具有不变TSC支持的处理器上,OS可以将TSC用于挂钟定时器服务(而不是ACPI或HPET定时器)。TSC读取效率要高得多,并且不会引起与环转换或访问平台资源相关的开销。
不变TSC基于不变计时硬件(称为始终运行定时器或ART,以内核晶振时钟频率运行)。
可缩放总线频率在位域MSR_PLATFORM_INFO15:8]中编码,标称TSC频率可通过将该数字乘以100 MHz的总线速度来确定。
Boost::Timer有一些有趣的功能。我特别喜欢自动计时器。它以微秒为单位显示计时。不知道它能不能比这个低。