这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » 看门狗工作原理和电路设计

共19条 1/2 1 2 跳转至

看门狗工作原理和电路设计

高工
2023-02-18 13:42:34     打赏

1.看门狗是什么?


看门狗,又叫watchdog timer,是一个定时器电路,一般有一个输入,叫喂狗(kicking the dog/service the dog),一个输出到MCU的RST端。

MCU正常工作的时候,每隔一段时间输出一个信号到喂狗端,给 WDT清零,如果超过规定的时间不喂狗(一般在程序跑飞时),WDT定时超过,就会给出一个复位信号到MCU,使MCU复位,防止MCU死机。看门狗的作用就是防止程序发生死循环,或者说程序跑飞。

2.硬件和软件看门狗

☀ 硬件看门狗

硬件看门狗是利用了一个定时器,来监控主程序的运行,也就是说在主程序的运行过程中,我们要在定时时间到之前对定时器进行复位。如果出现死循环,或者说PC指针不能回来,那么定时时间到后就会使单片机复位。常用的WDT芯片如MAX813,5045,IMP 813等。

☀ 软件看门狗

而在某些情况下,也会采用纯软件的方法来设置看门狗,如在单片机系统中,利用闲置的定时器/计数器就可以设计一个软件看门狗。具体实现步骤如下:

首先,在初始化程序中设置定时器/计数器的方式以控制寄存器(TMOD) 和定时时间的初值,并且打开中断。

然后,根据定时器的时间,在主程序中按一定的时间间隔插入复位定时器的指令(喂狗), 两条喂狗指令之间的时间间隔可以根据系统时钟与指令周期计算出来,而且该时间周期应该小于定时器的定时时间。

最后,在定时器的中断服务程序中,设置一条无条件转移指令,将程序计数器PC转移到初始化程序的入口。

软件看门狗的优点是无需额外的硬件支持,但当系统存在严重的错误时(例如:中断服务出错),则有可能导致软件看门狗失效。

3.硬件看门狗芯片电路


看门狗芯片与MCU的连接关系如下:其基本的原理就是MCU要在固定的时间内通过IO翻转去控制看门狗芯片的WDI引脚,否则看门狗芯片就会将WDO拉低,进而使CPU复位。

image.png

以SP706为例,看门狗芯片的引脚定义和功能描述如下图:

image.png

这个MR脚是手动复位,挺有用的,原理图设计时注意下

image.png


当J2接上跳线帽时,开启看门狗。反之,看门狗关闭。

芯片参数比较少,关注下最短喂狗时间Twd 即可:


image.png

转贴子网络



专家
2023-02-18 14:54:44     打赏
2楼

参考和学习,写的很实用


专家
2023-02-18 15:57:05     打赏
3楼

感谢分享


高工
2023-02-18 19:35:38     打赏
4楼

感谢分享


专家
2023-02-18 19:43:03     打赏
5楼

感谢分享


高工
2023-02-18 19:46:41     打赏
6楼

感谢分享


高工
2023-02-18 21:36:31     打赏
7楼

感谢分享


院士
2023-02-19 12:32:43     打赏
8楼

谢谢楼主转发的电路分享~!


高工
2023-02-19 12:38:50     打赏
9楼

感谢分享


高工
2023-02-19 13:26:46     打赏
10楼

感谢分享感谢分享


共19条 1/2 1 2 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]