曲径通幽论坛

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

读取 TSC 寄存器|rdtsc,rdtscl,rdtscll

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2011-4-14 13:43:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
内核:2.6.24
平台:x86 32位
TSC (时间戳计数器) 是一个 64 位的寄存器,用来记录 CPU 时钟周期,从内核空间和用户空间都可以读取它。rdtsc, rdtscl, rdtscll 定义在 include/asm-x86/msr.h 中,它们用以读取 TSC 计数器,但有所区别。

rdtsc
[C++] 纯文本查看 复制代码
#define rdtsc(low,high) \
     __asm__ __volatile__("rdtsc" : "=a" (low), "=d" (high))

将 TSC 中的 64 位的数值分别读到两个 32 位的变量中。实际上,rdtsc 指令就是用 EDX:EAX 来存放读取到的值,EDX 存放高 32 位,EAX 存放低 32 位。

rdtscl
[C++] 纯文本查看 复制代码
#define rdtscl(low) \
     __asm__ __volatile__ ("rdtsc" : "=a" (low) : : "edx")

该宏只把寄存器的低 32 位读入到 low 变量中。

rdtscll
[C++] 纯文本查看 复制代码
#define rdtscll(val) do { \
     unsigned int __a,__d; \
     __asm__ __volatile__("rdtsc" : "=a" (__a), "=d" (__d)); \
     (val) = ((unsigned long)__a) | (((unsigned long)__d)<<32); \
} while(0)

该宏将 64 位值读入到一个 long long 型的变量中。

一般情况下,只要读取计数器的低 32 位即可达到测量的目的。但随着 CPU 主频的增加,也需要考虑读取 64 位的技术值。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-5-17 03:23 , Processed in 0.065373 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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