WinCE系统时间年份不准的原因
2011-07-07 21:14
225 查看
转载自:/article/1897319.html
近来发现一个奇怪问题,我们WinCE设备的系统时间年份不准。具体情况是:过了2010年之后,系统时间每当到了整分的时候,年份会跳变到2016,然后马上又跳回2010。而且更恶劣的是,双击右下角的时间图标,打开“日期/时间属性”对话框查看,是发现不到这个现象的。为此我编写了一段小代码,在代码中获取系统时间,然后将时间显示到一个Static控件上。这样就能够很容易发现这个现象。如果人为的将系统时间2010改为2011年,则现象就变为了2011跳变到2017再跳回2011。这个小小的跳变将导致很多应用程序出错。
后来打开/KERNEL/HAL/ARM下的timer.c文件。出现上述问题的代码段已经被找到:
很容看出为什么会是到了整分的时候才会发生这种怪现象?因为是if ( lpst->wSecond == 0 )这个条件判断的原因。看来这个if语句中执行的代码可能存在问题。其中年份的一句代码:lpst->wYear = (2000 + s2440RTC->rBCDYEAR) ; 更改成:
lpst->wYear = 2000 + FROM_BCD(s2440RTC->rBCDYEAR);问题就好了。
根据别人的指示这个问题解决了。这个BSP包是离职同事在其他BSP包的基础上修改的。还存在一个问题就是SetTimer不准的问题。现在自己还没有能力解决,先记录到这。
近来发现一个奇怪问题,我们WinCE设备的系统时间年份不准。具体情况是:过了2010年之后,系统时间每当到了整分的时候,年份会跳变到2016,然后马上又跳回2010。而且更恶劣的是,双击右下角的时间图标,打开“日期/时间属性”对话框查看,是发现不到这个现象的。为此我编写了一段小代码,在代码中获取系统时间,然后将时间显示到一个Static控件上。这样就能够很容易发现这个现象。如果人为的将系统时间2010改为2011年,则现象就变为了2011跳变到2017再跳回2011。这个小小的跳变将导致很多应用程序出错。
后来打开/KERNEL/HAL/ARM下的timer.c文件。出现上述问题的代码段已经被找到:
lpst->wSecond = FROM_BCD(s2440RTC->rBCDSEC & 0x7f); lpst->wMinute = FROM_BCD(s2440RTC->rBCDMIN & 0x7f); lpst->wHour = FROM_BCD(s2440RTC->rBCDHOUR& 0x3f); lpst->wDayOfWeek = (s2440RTC->rBCDDATE - 1); lpst->wDay = FROM_BCD(s2440RTC->rBCDDAY & 0x3f); lpst->wMonth = FROM_BCD(s2440RTC->rBCDMON & 0x1f); // lpst->wYear = (2000 + s2440RTC->rBCDYEAR) ; lpst->wYear = FROM_BCD(s2440RTC->rBCDYEAR) + 2000 ; if ( lpst->wSecond == 0 ) { lpst->wSecond = FROM_BCD(s2440RTC->rBCDSEC & 0x7f); lpst->wMinute = FROM_BCD(s2440RTC->rBCDMIN & 0x7f); lpst->wHour = FROM_BCD(s2440RTC->rBCDHOUR& 0x3f); lpst->wDayOfWeek = (s2440RTC->rBCDDATE - 1); lpst->wDay = FROM_BCD(s2440RTC->rBCDDAY & 0x3f); lpst->wMonth = FROM_BCD(s2440RTC->rBCDMON & 0x1f); lpst->wYear = (2000 + s2440RTC->rBCDYEAR) ; }
很容看出为什么会是到了整分的时候才会发生这种怪现象?因为是if ( lpst->wSecond == 0 )这个条件判断的原因。看来这个if语句中执行的代码可能存在问题。其中年份的一句代码:lpst->wYear = (2000 + s2440RTC->rBCDYEAR) ; 更改成:
lpst->wYear = 2000 + FROM_BCD(s2440RTC->rBCDYEAR);问题就好了。
根据别人的指示这个问题解决了。这个BSP包是离职同事在其他BSP包的基础上修改的。还存在一个问题就是SetTimer不准的问题。现在自己还没有能力解决,先记录到这。
相关文章推荐
- WinCE系统时间年份不准的问题(记录)
- WinCE系统时间年份不准的问题(记录)
- mips64高精度时钟引起ktime_get时间不准,导致饿狗故障原因分析
- mips64高精度时钟引起ktime_get时间不准,导致饿狗故障原因分析【转】
- ubuntu 系统时间不准的某原因-twistman
- mips64高精度时钟引起ktime_get时间不准,导致饿狗故障原因分析
- 如何获取sql数据中时间的月份、年份(类型date)
- cocos2dx定时器时间不准
- EntityFramework的多种记录日志方式,记录错误并分析执行时间过长原因
- cacti 时间/时区 不准的解决
- SystemTimeToVariantTime时间转换不准,有误差
- 从入职时间长短剖析离职原因
- cookies过期原因,服务器时间和客户端时间不一致
- WCF客户端无法访问服务原因之一:时间不同步问题
- 因时间与工作原因,网站暂停更新一段时间后,9月20日正式关门大吉!
- php 根据给定的年份和月份获取该年份该月份的起始和结束时间
- Java:获取指定时间所在的年份的第一天是周几
- Linux操作系统时间相关函数性能下降原因分析
- 正确解读PHP获取时间错误原因
- 时间是软件测试结束的原因?