
RTC时间 *** 作:
1.rtc时间是由rtc硬件控制的,所以在linux中想要修改和获取rtc时间就只能通过驱动的接口来获取和修改。
intrtc_test(void)
{
structrtc_timertc
intfd=-1
intret=-1
fd=open("/dev/rtc0",O_RDWR)
if(fd<0){
return-1
}
ret=ioctl(fd,RTC_RD_TIME,&rtc)
if(ret<0){
return-1
}
printf("\nCurrentRTCdata/timeis%d-%d-%d,%02d:%02d:%02d.\n",rtc.tm_mday,rtc.tm_mon+1,
rtc.tm_year+1900,rtc.tm_hour,rtc.tm_min,rtc.tm_sec)
ret=ioctl(fd,RTC_SET_TIME,&rtc)
if(ret<0){
return-1
}
return0
}
2.除了上面这种方式 *** 作rtc时间以外,linux中也有一个命令可以简化rtc时间 *** 作,hwclock,比如,可以通过system("hwclock-w")系统调用来把xtime设置到rtc硬件。
墙上时间(realtime、xtime):
linux系统中主要使用的就是xtime,它是系统运行的基础,很多程序都是依赖于xtime来运行的,接下来将介绍将如何 *** 作xtime。
1.获取、设置微秒级别的时间:
#include
#include
structtimeval
{
inttv_sec
inttv_usec
}
intgettimeofday(structtimeval*tv,structtimezone*tz)
intsettimeofday(conststructtimeval*tv,conststructtimezone*gz)
功能描述:
gettimeofday()获取当前时间,有tv指向的结构体返回。
settimeofday()把当前时间设成由tv指向的结构体数据。当前地区信息则设成tz指向的结构体数据。
2.获取秒级别的时间
typedeflongtime_t
time_ttime(time_t*t)
如果t是non-null,它将会把时间值填入t中
3.内核2.6版本后新增的clockapi接口
获取纳秒级别的时间
structtimespec{
time_ttv_sec/*秒s*/
longtv_nsec/*纳秒ns*/
}
intclock_getres(clockid_tclk_id,structtimespec*res)
intclock_gettime(clockid_tclk_id,structtimespec*tp)
intclock_settime(clockid_tclk_id、conststructtimespec*tp)
编译连接时采用-lrt才能编译通过。
clk_id可选参数:
CLOCK_REALTIME
系统全局的实时时钟.设置此时钟需要合适的权限.
CLOCK_MONOTONIC
只能被读取,无法被设置,表示monotonic时间起点.
CLOCK_PROCESS_CPUTIME_ID
从cpu每进程的高分辨率计时器.
CLOCK_THREAD_CPUTIME_ID
线程的特定cpu时间时钟.
系统启动时,会首先从rtc中读取rtc时间,并设置给xtime,而当ntp对系统时间进行更新时,首先设置xtime,然后调用hwclock设置到rtc硬件中。xtime根据需要的精度,可以通过上面几个接口来选择使用。
系统时间一般是保存在时钟寄存器中的,由于绝对时间值比较大,所以寄存器中都是放一个相对时间值,即系统时间(日期+时间)减去一个固定的值(多数是1900年,也有的用1970年)后的秒数。取系统时间时会再把这个值加回来,从而得到真正的系统时间。uboot中取时间的函数是将时钟寄存器中的值取出后,加上那个固定值(如1900年),直接返回,如果时间寄存器中放的是12年的秒数,在u-boot中就会显示是1912年。
linux kernel计算日期中有点不同,在算出年号后(加上1900年),接着判断,年号<=1969,再加上100,所以同样时间寄存器值将会校正为2012了。
你的系统显示不一致,可能原因是u-boot和kernel源代码移植不完整,u-boot和kernel实时时钟的存储和计算策略不一致。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)