微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 串行实时时钟芯片DS1302程序设计中的问题与对策

串行实时时钟芯片DS1302程序设计中的问题与对策

时间:07-09 来源:互联网 点击:

了测试,测试结果如表1所示=5V。

由此可见,当涓流充电控制寄存器中的DS位为00和11时并不能禁止充电,而是选择了一个二极管充电,这说明参考文献中介绍的有误。若要想禁止充电器充电,应将第6句改为:MOVA,#0101XX00B即TCS≠1010,RS=00,这样,就能双保险地禁止充电。

3受干扰时钟/日历信息出现的错误

笔者将DSl302应用于某产品中,发现系统受到干扰时,有时其时钟停振不能正常工作,此时的时钟/日历信息也被修改。

经分析得知:系统受到干扰程序飞跑,在看门狗复位前,CPU正好执行写程序将写保护寄存器的最高位置0为允许写(实际上,在系统校时程序之后已将其置为1禁止写),修改了时钟/日历信息且使秒寄存器的最高位置1,致使时钟停振出现错误。

为避免此类错误的产生,笔者采用的方法是:在写程序中增加了某一检测条件,此条件为系统中某一口线上的电平,低电平条件满足。只有在实时校时过程中,才通过手动使此口线为低电平,实时校时过程完成后,又通过手动使此口线为高电平。这样只有实时校时过程中,才允许修改时钟/日历信息,因此起到了时钟/日历信息的写保护作用。

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top