专栏中心

EEPW首页 > 专栏 > MSP430单片机中的WDT研究

MSP430单片机中的WDT研究

发布人:yanqin 时间:2009-04-17 来源:工程师 发布文章
引言
   软件的可靠性一直是一个关键问题。任何使用软件的人都可能会经历计算机死机或程序跑飞的问题,这种情况在嵌入式系统中也同样存在。由于单片机的抗干扰能力有限,在工业现场的仪器仪表中,常会由于电压不稳、电弧干扰等造成死机。在水表、电表等无人看守的情况下,也会因系统遭受干扰而无法重启。为了保证系统在干扰后能自动恢复正常,看门狗定时器(WatchdogTimer)的利用是很有价值的。

1看门狗的作用
   看门狗定时器是一个计数器,基本功能是在发生软件问题和程序跑飞后使系统重新启动。看门狗计数器正常工作时自动计数,程序流程定期将其复位清零,如果系统在某处卡死或跑飞,该定时器将溢出,并将进入中断。在定时器中断中执行一些复位操作,使系统恢复正常的工作状态,即在程序没有正常运行期间,如期复位看门狗以保证所选择的定时溢出归零,使处理器重新启动。

2看门狗问题及相关实验
   现今市面上流行的一些单片机,多嵌有内部WDT,如TI的MSP430系列,Philips的P87XXX和P89XXX系列,Microchip的PIC列,Atmel的AT89SXX系列和Holtek公司的Htxxx系列。但是这些内部看门狗在工作时,多存在一定的误差。一些工程师在设计的过程中,由于忽略了这一点,导致系统出现异常。MSP430系列单片机是美国德州仪器公司(TI)近几年开发的新一代单片机,该系列是一款16位、具有精简指令集、超低功耗的全新概念混合型单片机。在众多单片机系列中,由于它具有极低的功耗、丰富的片内外设和方便灵活的开发手段,已成为一颗耀眼的新星。其内部自带看门狗及复位电路,理论上如果程序跑飞,可用看门狗将其复位。但在实际使用过程中,发现看门狗的作用并非万无一失,以下实验证明了这一点。
实验电路如图1所示。


实验程序清单:
#include<msp430x12x.h>
voidmain(void){
P1DIRl=OxOf;//设置P1.2~P1.O为输出
for(;;){
volatileunsignedinti;
WDTCTL=WDTPW+WDTCNTCL;
//复位WDT计数器
PIOUT==OxOt;//P1.0~P1.2相互异或
i=5000;//延时
d0(i--);
while(i!=O);
}
}
   上述实验启动后,如果程序正常运行,LED会闪烁。缺省时,MSP430的看门狗是允许状态,所运行的程序会不断地访问看门狗。理论上,这个系统是不会发生启动失败的,因为即使启动失败,看门狗也应该在数百毫秒内启动,复位整个系统。基于这种思想,对单片机的复位进行测试。K2断开,用K1连续产生。Reset信号,测试看门狗使系统重启的成功率。K2闭合,则reset端高电平,理论上K1不能有效产生复位脉冲,观察看门狗是否起作用。

3实验结果与分析
   实验结果如下:K2断开,连续开关K1,上电重启系统,平均155次失败1次(LED不闪),即看门狗失效概率0.6%;K2闭合,连续开关K1,平均18次失败1次(LED不闪),且一旦失败,将连续失败下去,看门狗无效率占到了约5.5%。

   另外,当采用同样具有内置看门狗的其他系列单片机替代实验中的MSP430,启动程序段作相应修改时,实验结果仍大致相同,这说明具有内置看门狗的单片机面临的问题是相同的。经分析可能有如下原因:

   ①由于看门狗的时钟不独立,计数时钟与系统为同一分频链路,因此看门狗不能在系统出现问题时有效运作。
   ②由于时钟可用软件设置,启动失败时,开机时钟可能处于空档,没有时钟看门狗不能生效。
   ③有些看门狗需要用软件设置或启动,因此启动失败后,初始化程序没有激活,CPU可能跳转到随机代码,使看门狗被禁止。这样的看门狗是需要有可靠的上电复位作保证的,因此,从理论上讲,原设计存在着不合理性。基于上述分析,采用片外看门狗专用芯片TPS3823由独立的分频振荡电路提供计数脉冲。实验电路如图2所示。


   上述电路中,TPS3823输出定时溢出信号给Reset端。程序段中,CPU要不断地通过I/O口输出喂狗信号,使看门狗计数器清零。在此电路中重复上述试验中K1、K2的相同动作,系统重启成功率达到100%。

结语
   未来的内置看门狗必须有独立可靠的时钟。系统上电后,看门狗即为允许状态,无需软件设置,它只能被外部硬件跳线或内部熔丝(fuse)所禁止。目前,如果要求设计可靠性较高的嵌入式系统,外置看门狗是必须考虑的。内置看门狗的另一问题是系统复位后,程序应判断是由Reset端正常上电复位,还是程序跑飞看门狗所致,由此确定现场数据是否应该保留。这也是在看门狗应用中所应考虑的。


专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们

关键词:

相关推荐

台积电与慕尼黑工业大学共同成立AI芯片研发中心

光耦应用全面介绍.rar

资源下载 2007-12-16

基于SMD封装的高压CoolMOS

视频 2010-06-12

数码管型红外遥控器检测仪.pdf

NCL30000单段式功率因数校正LED驱动器原理及TRIAC调光LED驱动器设计方案(上)

视频 2010-06-12

报告:OpenAI计划在印度建设1GW+数据中心

“突破电气化边界:高精度磁性角度传感器与12V/48V通用驱动平台的完美融合”

用带平均电流限幅功能的半桥式电路拓朴结构提高砖电源模块的功率密度(上)

视频 2010-06-12

采用ADP1043A的数字电源设计实例

视频 2010-06-12

逆变电源的资料.rar

用带平均电流限幅功能的半桥式电路拓朴结构提高砖电源模块的功率密度(下)

视频 2010-06-12

安富利巩固无线充电领导地位,携手ConvenientPower加速亚太地区创新

UPS设计参考.pdf

资源下载 2007-12-16

TDK 推出全新品牌标识与标语“In Everything, Better”

开关电源.rar

没做到就没订单!苹果无预警下最后通牒供应商惨爆

在重大反垄断裁决中,谷歌可以保留 Chrome 和 Android,但仍面临较轻的处罚

台积电否认英伟达CEO8月访问是为了传递特朗普信息

三安宣布 8 英寸 SiC 芯片生产线投产完成

科学家绕过完美芯片要求,量子计算机可能更快到来

更多 培训课堂
更多 焦点
更多 视频

技术专区