日期:2010-02-04
作者:Steven Yang
邮箱:mqyoung@gmail.com
注:转载请注明出处和作者并保持文档的完整
HZ
内核通过定时器中断来跟踪时间流,时钟中断由系统定时硬件以周期性的间隔产生,这个间隔由内核根据HZ的值设定。
HZ与体系结构有关,定义在<linux/param.h>中或者该文件包含的某个子平台相关的文件中。默认值为50 ~ 1200, X86的默认值为1000。如果想改变系统时钟中断的频率,可以修改HZ值。
jiffies
每次时钟中断产生,内核内部计数器的值加一。jiffies,是一个64的变量。
调用需包含<linux/jiffies.h> 或 <linux/sched.h>
比较两个jiffies快照的函数
int time_after()
int time_before()
int time_after_eq()
int time_before_eq()
diff = (long)t2 - (long)t1
msec = diff * 1000 / HZ (转换为毫秒)
时间表述形式
struct timeval; stuct timespec;
#include <linux/time.h>
unsigned long timespec_to_jiffies()
void jiffies_to_timespec()
unsigned long timeval_to_jiffies()
void jiffies_to_timeval()
对64位jiffies_64的访问
32位CPU上对64位值的访问不是原子的,需要通过这个函数来读取
#include <linux/jiffies.h>
u64 get_jiffies_54();
TSC(timestamp counter)
一个64位的寄存器,记录CPU时钟周期数,通过计算时钟周期来度量时间,从内核共建和用户空间都可以读取它。(X86的Pentium的处理器开始提供该寄存器)
#include <asm/msr.h> (machine-specific registers)
rdtsc(low32,high32);
rdtscl(low32);
rdtscll(var64);
1-GHz 的处理器,计数器的低半部分每4.2秒会溢出。可以根据实际情况来决定是读取低32位呢还是64位。
有一个平台无关的函数可以替代rdtsc,
#include <asm/timex.h> (or linux/timex.h, 它包含前面那个头文件)
cycles_t get_cycles(void);
关于当前时间的获取和转换
1 取jiffies
2 墙钟转换为jiffies的值
#include<linux/time.h>
unsigned long mktime(year, mon, day, hour, min, sec);
3 用秒/微秒填充struct timeval值(和gettimeofday系统调用使用同一变量)
#include<linux/time.h>
void do_gettimeofday(struct timeval *tv);
这里是近似微秒,实际精度依赖平台
4 xtime(struct timespec)
#include<linux/time.h>
struct timespec current_kernel_time(void);