精度达到微妙是不可能的,因为计算机本身的时间片10-15ms左右,不管是Linux和windows,因此不可能达到那个精度。
另外系统时间和RTC时间也是不同的概念,当然读RTC时间成本很高,但是准确,可以用汇编或具体的库来读,但是只是一瞬间的参考,按长远来说也是很不稳定的,做多10-15ms精度,当然,你可以自己用代码时间一个时间估计的过程,用算法来弥补,给出误差分析,但这个是数学了。
Linux内核对RTC的编程MC146818RTC芯片(或其他兼容芯片,如DS12887)可以在IRQ8上产生周期性的中断,中断的频率在2HZ~8192HZ之间。与MC146818RTC对应的设备驱动程序实现在include/linux/rtc.h和drivers/char/rtc.c文件中,对应的设备文件是/dev/rtc(major=10,minor=135,只读字符设备)。因此用户进程可以通过对她进行编程以使得当RTC到达某个特定的时间值时激活IRQ8线,从而将RTC当作一个闹钟来用。而Linux内核对RTC的唯一用途就是把RTC用作“离线”或“后台”的时间与日期维护器。当Linux内核启动时,它从RTC中读取时间与日期的基准值。然后再运行期间内核就完全抛开RTC,从而以软件的形式维护系统的当前时间与日期,并在需要时将时间回写到RTC芯片中。Linux在include/linux/mc146818rtc.h和include/asm-i386/mc146818rtc.h头文件中分别定义了mc146818RTC芯片各寄存器的含义以及RTC芯片在i386平台上的I/O端口 *** 作。而通用的RTC接口则声明在include/linux/rtc.h头文件中。7.2.1RTC芯片的I/O端口 *** 作Linux在include/asm-i386/mc146818rtc.h头文件中定义了RTC芯片的I/O端口 *** 作。端口0x70被称为“RTC端口0”,端口0x71被称为“RTC端口1”,如下所示:#ifndefRTC_PORT#defineRTC_PORT(x)(0x70 (x))#defineRTC_ALWAYS_BCD1/*RTCoperatesinbinarymode*/#endif 显然,RTC_PORT(0)就是指端口0x70,RTC_PORT(1)就是指I/O端口0x71。端口0x70被用作RTC芯片内部寄存器的地址索引端口,而端口0x71则被用作RTC芯片内部寄存器的数据端口。再读写一个RTC寄存器之前,必须先把该寄存器在RTC芯片内部的地址索引值写到端口0x70中。根据这一点,读写一个RTC寄存器的宏定义CMOS_READ()和CMOS_WRITE()如下:
#defineCMOS_READ(addr)({\outb_p((addr),RTC_PORT(0))\inb_p(RTC_PORT(1))\})#defineCMOS_WRITE(val,addr)({\outb_p((addr),RTC_PORT(0))\outb_p((val),RTC_PORT(1))\})#defineRTC_IRQ8 在上述宏定义中,参数addr是RTC寄存器在芯片内部的地址值,取值范围是0x00~0x3F,参数val是待写入寄存器的值。宏RTC_IRQ是指RTC芯片所连接的中断请求输入线号,通常是8
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)