Linux系统--时间戳计数器TSC

本文介绍了TSC(时间戳计数器)的概念及其在Pentium兼容处理器中的作用,详细解释了如何通过rdtsc指令读取TSC值,并提供了一个用户态下实现读取TSC值的例子。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    TSC 是时间戳计数器的缩写,它是 Pentium 兼容处理器中的一个计数器,它记录自启动以来处理器消耗的时钟周期数。在每个时钟到来时,该计数器自动加一。
    因为 TSC 随着处理器周期速率的变化而变化,所以它提供了非常高的精确度。它经常被用来分析和检测代码。TSC 的值可以通过 rdtsc 指令来读取。TSC 的节拍还可以转换为秒,转换方法是将其除以 CPU 的时钟速率(可以从内核变量 cpu_khz 获取)。

    在 include/asm-i386/Msr.h (内核版本:2.6.23)里可以看到一个函数:
staticinline unsigned longlong native_read_tsc(void)
{
    unsigned long longval;
    asm volatile("rdtsc": "=A" (val));
    return val;
}
    这个函数正是使用 rdtsc 指令读取 TSC 的值,并将其存放在 %eax 和 %edx (=A)中,然后再存往 val 变量中。long long 类型为 64 位。

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

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

int main()
{
        unsigned long longval;
        unsigned long longval2;

        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频率动态调节”功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值