该代码如何计算经过的CPU周期数?

Laz*_*zer 10 c cpu cpu-cycles

来自该SO螺纹,这块代码计算的CPU周期的数目经过延伸的线之间的代码//1//2.

$ cat cyc.c 
#include<stdio.h>

static __inline__ unsigned long long rdtsc(void)
{
  unsigned long long int x;
     __asm__ volatile (".byte 0x0f, 0x31" : "=A" (x));
     return x;
}

int main() {
    unsigned long long cycles = rdtsc(); //1
    cycles = rdtsc() - cycles;           //2
    printf("Time is %d\n", (unsigned)cycles);
    return 0;
}

$ gcc cyc.c -o cyc
$ ./cyc
Time is 73
$ ./cyc
Time is 74
$ ./cyc
Time is 63
$ ./cyc
Time is 73
$
Run Code Online (Sandbox Code Playgroud)

rdtsc()功能如何运作?

dso*_*ano 11

该函数执行x86指令RTDSC,其恰好具有操作码0x0f, 0x31.处理器在内部跟踪时钟周期,并读取该数字.

当然,这只适用于x86 procs,其他处理器则需要不同的指令.

自Pentium以来,时间戳计数器是所有x86处理器上的64位寄存器.它计算自重置以来的滴答数.指令RDTSC在EDX:EAX中返回TSC.它的操作码是0F 31. [1] 诸如Cyrix 6x86之类的奔腾竞争对手并不总是拥有TSC,并且可能认为RDTSC是非法指令.Cyrix在其MII中包含一个时间戳计数器.

http://en.wikipedia.org/wiki/Time_Stamp_Counter

  • 它在某些molticore AMD处理器上也存在问题,因为它们每个都有自己的计数器不同步,所以如果你在采用时间戳时碰巧在不同的核心上运行,你可能会有惊喜.所以,要求操作系统让这个线程在同一个核心上运行是一个好主意. (2认同)