匿名用户
一种选择是通过函数使用指令。在现代Intel CPU上,以任何CPU频率的基本时钟速率滴答,因此您可以通过将计数器除以GHz的基本(而不是升压)CPU频率来将计数器转换为纳秒:#include
#include
#include
#include
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的总线速度来确定。