取自 这个线程, ,此代码计算在行之间运行代码经过的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
$

如何 rdtsc() 功能工作?

有帮助吗?

解决方案

该函数执行X86指令RTDSC,恰好具有 0x0f, 0x31. 。处理器在内部跟踪时钟周期,这读取了该数字。

当然,这仅适用于X86 Procs,其他处理器将需要不同的说明。

时间邮票计数器是自五个以来的所有X86处理器上都存在的64位寄存器。它计算自重置以来的滴答数。指令RDTSC返回EDX中的TSC:EAX。它的操作码为0f 31. [1]诸如Cyrix 6x86之类的奔腾竞争对手并不总是具有TSC,并且可能认为RDTSC是非法的指导。 Cyrix在他们的MII中包括了一个时邮票计数器。

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

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top