| | 网站首页 | 技术文章 | 专业论文 | PLC可编程 | 单片机 | 变频器 | 传感器 | 嵌入式系统 | 电源技术 | 运动与伺服 | | 校园招聘 | 留言板 | |
|
![]() |
|
| 您现在的位置: 自动化学习网 >> 技术文章 >> 单片机 >> 文章正文 |
|
||||||||||||||||||||||||||||||
| 串行实时时钟芯片DS1302程序设计中的问题与对策 | ||||||||||||||||||||||||||||||
作者:佚名 文章来源:不详 点击数: 更新时间:2007-5-31 ![]() |
||||||||||||||||||||||||||||||
|
关键词:串行时钟程序设计问题原因解决方法 美国Dallas公司推出的串行接口实时时钟芯片DSl302可对时钟芯片备份电池进行涓流充电。由于该芯片具有体积小、功耗低、接口容易、占用CPUI/O口线少等主要特点,故该芯片可作为实时时钟广泛应用于智能化仪器仪表中。 笔者在调试中发现在对DSl302编程中有几个问题易被疏忽而导致错误,现提供给读者参考。 按照参考文献[2]的读操作程序框图和参考文献[1]、[2]所叙述的可知:单字节读操作每次需16个时钟,地址字节在前8个时钟周期的上升沿输入,而数据字节在后8个时钟周期的下降沿输出。据此结合图1的硬件连接图编制出了如下的单字节读程序: DS_READSETBP1.2;令 CLRP1.1;令SCLK=0。 CLRP1.2;令 LCALLDS_WSUB;写8位地址。 LCALLDS_RSUB;读出8位数据。 RET DS_WSUBMOVR7,#08H WL00PRRCA;A为地址字节。 MOVP1.0,C SETBP1.1;在时钟上升沿 NOP;输入地址字节。 CLRP1.1 DJNZR7WL00P RET DS_RSUBSETBP1.0;为读数据作准备。 MOVR7#08H RL00P:SETBP1.1 NOP CLRP1.1;在第9个正脉冲的下 MOVC,P1.0;降沿开始输出数据。 RRCA;A中为读出的数据。 DJNZR7,RL00P RET 若使用如下程序对DSl302的RAM1其内容为5AH进行读操作 READ:MOVA#11000101B;RAM1单元的读地址。 LCAllDS_READ;调用读子程序。 则程序执行后A中的数据为2DH,显然读出的数据不正确。若再使用一条RLA指令调整后,则A中为5AH,结果才正确。由此说明:使用上述程序读出的RAM1单元中的第0位数据实为第1位数据,读出的第7位数据实为第0位数据。 经笔者仔细研究时序图和多次试验得知,问题的原因在于:对于读操作时序,在SCLK出现第8个正脉冲时,上升沿输入地址字节的最后一位数据,而在此正脉冲的下降沿就要输出数据字节的第0位数据。然而笔者的程序中是在第9个正脉冲的下降沿才误认为输出了数据字节的第0位数据,此位数据事实上是第二个下降沿输出的,故实为数据字节的第1位数据。经笔者实验:只要RST保持为高电平,如果超过8个下降沿,它们将重新从第0位输出数据位,因程序中输出的最后一位数据位,是9个下降沿输出的数据位,故实为数据字节的第0位数据位。 由此可见,单字节读操作的时序图如改为图2所示时序图,则读者较容易理解可避免发生上述编程错误。 DS_RSUBl:SETBP1.0;为读数据作准备 MOVR7,#08H RL00P:CLRP1.1;SCLK第8个正脉冲的 MOVC,P1.0;下降沿开始输出数据。 RAC SETBP1.1 DJNZR7,RL00P RET 2禁止涓流充电出现的错误 涓流充电寄存器(TCR)控制着DSl302的涓流充电特性。据参考文献[1]、[2]介绍,寄存器的位(TCS)4~7决定着是否具备充电性能。仅在1010编码的条件下才具备充电性能,其它编码组合不允许充电。位2和3(DS)则在 SETBP1.2;令 CLRP1.2;令SCLK=0 CLRP1.2;令 MOVA#90H;TCR的写地址 LCALLDS_WSUB MOVA#10100110B;TCR的命令 LCALLDS_WSUB 用万用表串入 MOV A,#01010110B即TCS≠1010 或:MOV A,#10100100B即RS=00则充电被禁止。 由此可见,当涓流充电控制寄存器中的DS位为00和11时并不能禁止充电,而是选择了一个二极管充电,这说明参考文献中介绍的有误。若要想禁止充电器充电,应将第6句改为:MOVA,#0101XX00B即TCS≠1010,RS=00,这样,就能双保险地禁止充电。 3受干扰时钟/日历信息出现的错误 笔者将DSl302应用于某产品中,发现系统受到干扰时,有时其时钟停振不能正常工作,此时的时钟/日历信息也被修改。 经分析得知:系统受到干扰程序飞跑,在看门狗复位前,CPU正好执行写程序将写保护寄存器的最高位置0为允许写(实际上,在系统校时程序之后已将其置为1禁止写),修改了时钟/日历信息且使秒寄存器的最高位置1,致使时钟停振出现错误。 为避免此类错误的产生,笔者采用的方法是:在写程序中增加了某一检测条件,此条件为系统中某一口线上的电平,低电平条件满足。只有在实时校时过程中,才通过手动使此口线为低电平,实时校时过程完成后,又通过手动使此口线为高电平。这样只有实时校时过程中,才允许修改时钟/日历信息,因此起到了时钟/日历信息的写保护作用。
| ||||||||||||||||||||||||||||||