关于为什么要使用窗口看门狗的原因

2019-07-20 23:22发布

本帖最后由 STM1928 于 2019-6-30 11:53 编辑

对于一般的看门狗,程序可以在它产生复位前的任意时刻刷新看门狗,但这有一个隐患,有可能程序跑乱了又跑回到正常的地方,或跑乱的程序正好执行了刷新看门狗操作,这样的情况下一般的看门狗就检测不出来了


谁能给解释一下这句到底是什么意思?国内所有论坛包括csdn、cnblog、eeworld全都是翻来覆去复制粘贴这句话
跑乱了又跑回到正常的地方,如果这一过程中看门狗未超时,那么程序跑回正常地方以后立刻喂狗不就行了吗?跑乱的程序正好执行了刷新看门狗操作,跑乱跑飞的程序已经脱离了正常工作区,怎么可能刷新看门狗?这样的情况下一般的看门狗就检测不出来了,检测不出什么来了?

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
2条回答
STM1928
1楼-- · 2019-07-21 02:13
 精彩回答 2  元偷偷看……
edmund1234
2楼-- · 2019-07-21 02:47
本帖最后由 edmund1234 于 2019-6-30 13:18 编辑

看门狗本来就不能百分之百解决检测程序跑飞的问题, 而事实上也没有什么方案能彻底解决, 用它是因为它能解决95%(我的估算)的问题。
跑飞了当然是可能跳到喂狗的点, 比如跳到数据区, 又比如跳到RAM, 数据又正好是一跳指令, 又或者跑飞后改了堆内容,之后又碰上return,等等。。。。 , 这不就发生了么
这不是会不会发生的问题, 而是发生的慨率多大的问题。
那句话说的是个事实, 只不过它没给你说发生的慨率而已, 所以才有你的疑惑。

一周热门 更多>