Linux中的时钟与时间
日期: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);
相关文档:
1. HCI层协议概述:
HCI提供一套统一的方法来访问Bluetooth底层。如图所示:
从图上可以看出,Host Controller Interface(HCI) 就是用来沟通Host和Module。Host通常就是PC, Module则是以各种物理连接形式(USB,serial,pc-card等)连接到PC上的bluetooth Dongle。
在Host这一端:application,SDP,L2cap等协议 ......
在linux中grep命令是非常有用的,它和管道(|)配合使用,非常强大,用于搜索文本文件.如果想要在几个文本文件中查找一字符串,可以使用
‘grep’命令。‘grep’在文本中搜索指定的字符串。
假设您正在‘/usr/src/linux/Documentation’目录下搜索带字符串‘magic’的文件:
$ gre ......
1.rpc服务需rsh的支持,一般情况下rsh已安装。rpm -qa rsh查看。
2.右键另存为http://heanet.dl.sourceforge.net/sourceforge/rstatd/rpc.rstatd-4.0.1.tar.gz下载rpc.rstatd-4.0.1.tar.gz。
3.执行以下命令解压和安装
tar zxvf rpc.rstatd-4.0.1.tar.gz
cd rpc.rstatd-4.0.1
./configure //配置
make&nb ......
关于Windows启动过程介绍的文章可谓多如牛毛,而对于Linux的介绍却是凤毛麟角。凡是曾经使用过Linux的用户可能都会注意到,当计算机启动时,屏幕上会出现很多信息。一般情况下,这些信息我们可以通过以下的命令看到:
cat /var/log/dmesg | more
这些信息究竟有什么含义?这个问题看起 ......
env setup
linux(ubuntu)下ruby开发环境搭建,包括一些常见问题解决
注意,本文只是我在搭建ruby学习环境时的一些笔记,因为是用gedit编辑的,所以格式化不是很好,另外,只是备忘而已。
2010.1.19
1. install ruby
$ tar xzf ruby-1.8.7-p248.tar.gz
$ mv ruby-1.8.7-p248 ruby187
$ cd ruby187/
$ ./configure
......