曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 9451|回复: 0
打印 上一主题 下一主题

时间戳计数器 TSC

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2011-2-19 15:16:32 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
TSC 是时间戳计数器的缩写,它是 Pentium 兼容处理器中的一个计数器,它记录自启动以来处理器消耗的时钟周期数。在每个时钟到来时,该计数器自动加一。


因为 TSC 随着处理器周期速率的变化而变化,所以它提供了非常高的精确度。它经常被用来分析和检测代码。TSC 的值可以通过 rdtsc 指令来读取。TSC 的节拍还可以转换为秒,转换方法是将其除以 CPU 的时钟速率(可以从内核变量 cpu_khz 获取)。


在 include/asm-i386/Msr.h (内核版本:2.6.23)里可以看到一个函数:
static inline unsigned long long native_read_tsc(void)
{
    unsigned long long val;
    asm volatile("rdtsc" : "=A" (val));
    return val;
}

这个函数正是使用 rdtsc 指令读取 TSC 的值,并将其存放在 %eax 和 %edx (=A)中,然后再存往 val 变量中。long long 类型为 64 位。


在用户态,也可以利用此函数来打印其值:
#include <stdio.h>

unsigned long long native_read_tsc(void)
{
        unsigned long long val;
        asm volatile("rdtsc" : "=A" (val));
        return val;
}

int main()
{
        unsigned long long val;
        unsigned long long val2;

        val = native_read_tsc();
        sleep(1);
        val2 = native_read_tsc();

        printf ("%lld\n", (val2-val)/1000000);

        return (0);
}

运行输出

$ ./rdtsc
CPU Mhz: 2327

从上面可以看到当前 CPU 的频率是 2.33G 。这个值也可以通过 /proc/cpuinfo 文件看到,比如我这里:
cpu MHz         : 1596.000


为什么这里的 CPU 只有 1.6G 了呢?原因是我的主板在 BIOS 里开启了“英特尔CPU频率动态调节”功能。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2024-4-29 18:21 , Processed in 0.065960 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表