注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

学习笔记

正确的方法如同学习书法,开始的时候要临摹,临摹好了然后创造自己的风格。

 
 
 

日志

 
 

[Linux笔记]开发板的时间设置有效,但重启恢复  

2013-09-25 23:19:48|  分类: Linux |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |
       使用开发板时,发现RTC的时间总是被设置为2015年11月30日11时30分,无论如何设置,通过hwclock -w或程序修改RTC芯片,修改之后时间和RTC时间均正确,但是断电重启之后,时间又变为2015年11月30日11时30分。
       通过分析和查找发现/etc/目录下的timestamp比较可疑,其值正是113011302015,于是查找包含它的文件有两个,分别为:/etc/init.d目录下的bootmisc.sh和save-rtc.sh。
       其中,bootmisc.sh中有如下内容:
# Set the system clock from hardware clock
# If the timestamp is 1 day or more recent than the current time,
# use the timestamp instead.
test -x /etc/init.d/hwclock.sh && /etc/init.d/hwclock.sh start
if test -e /etc/timestamp
then
SYSTEMDATE=`date "+%Y%m%d"`
TIMESTAMP=`cat /etc/timestamp | awk '{ print substr($0,9,4) substr($0,1,4);}'`
        NEEDUPDATE=`expr \( $TIMESTAMP \> $SYSTEMDATE \)`
        if [ $NEEDUPDATE -eq 1 ]; then
date `cat /etc/timestamp`
/etc/init.d/hwclock.sh stop
fi
fi
       上面的脚本会判断文件/etc/timestamp存在与否,且将里面的时间戳与当前系统时间进行比较,如果timestamp的时间比系统时间新1天或以上,则会使用timestamp,并将其写入RTC时间中。
       脚本save-rtc.sh中有如下内容:
#! /bin/sh
/etc/init.d/hwclock.sh stop

# Update the timestamp
date +%2m%2d%2H%2M%Y > /etc/timestamp
       上面的脚本会将当前时间写入timestamp中。
       同时,bootmis.sh脚本被链接到rcS.d中的S55bootmis.sh中,在系统启动时执行,而脚本save-rtc.sh则被链接到rc0.d和rc6.d文件夹中,在系统关闭和重启时执行。
       所以要解决上面的问题,只需:
1、修改/etc/timestamp,使其小于或等于当前系统时间。
2、正常关闭或重启系统而不是直接断电。
  评论这张
 
阅读(1609)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017