网易首页 > 网易号 > 正文 申请入驻

单片机编程:看看这只大狗,如何喂狗的灵魂拷问

0
分享至

单片机编程:看看这只大狗,如何喂狗的灵魂拷问

[导读]单片机程序写辣么多,看门狗狗天天见,你的狗狗养的对么?不停的喂狗,只要狗不叫就完了吗?真是这样么?事实上可能不是你想的辣么简单.....

啥叫看门狗?

看门狗也称为看门狗定时器,本质上是一种定时电路或者软件定时器机制。

工作原理:

看门狗的硬件组件是一个计数器,该计数器设置为某个值,然后递减至零。软件有责任经常将计数设置为其原始值,以确保计数永远不会达到零。如果确实达到零,则认为软件已以某种方式发生故障,并且CPU已复位。

正常工作时,单片机或处理器或者线程,周期性设置看门狗定时器的定时值,通俗讲也称为喂狗。定时器则在后台不断的计数,如果定时时间到了且没有再次喂狗,则狗叫,意味着一些不寻常的事情发生了!此时,狗狗对外发出指令,执行相应的动作。这里所谓的动作究竟是什么?取决于实际系统的设计。常见的看门狗芯片则会发出复位信号给单片机或者处理,对于软件定时器而言,具体会有何种动作,则灵活多变,具体取决于采用何种安全策略。

反言之,一个一直正常工作的系统,其看门狗总是被喂养的很好,不会饿了狂叫。

注:看到有的文章把重置看门狗定时器叫踢狗(kick watchdog),嗯嗯,这不太好,要对狗狗好一点,不要踢,叫喂养吧~~~

看门狗机制在电子系统中作用非常之重要,这里举个极端的栗子,火星车如果程序挂了,就相当于失联,如果没有看门狗电路。你想象一下是什么场景,无法通讯无法唤醒,秒变太空垃圾~~~

能看住哪些错误呢?

·栈或堆溢出,程序跑飞

·某段程序异常无法返回或陷入死循环

·强电磁干扰破坏数据导致系统异常,这你或许不好理解,你就想象一下军事领域,或者航空航天领域很多电子系统,常工作在强电磁干扰环境中

·bug导致的系统宕机,或者死循环

·多任务系统中死锁

原因万万千,憋慌!你还有个好狗狗在帮你,让看门狗来收拾残局吧。在一个复杂的嵌入式系统中,不可能保证没有bug,但是通过使用看门狗,您可以保证没有任何bug会无限期地挂起系统。

狗叫后该咋整?

常见的处理策略有哪些呢?

·系统复位,大多数人都有的体验,系统挂了咋整,重启。不由想起了刘欢的<<重头再来>>~~~

·失效安全,老外常叫fail-safe模式。就是设备即使出现致命故障了,也别造成安全事故。粗鲁点说,就是挂了,也不要影响他人。不易理解,举个例子,一个正在下降的电梯,加入看门狗检测到程序异常了,安全的做法是赶紧停止电机转动,否则自由落体,就要凉凉啦。这在IEC61508功能安全标准,或者医疗安全标准、汽车安全标准中都有体现。

·这一种做法值得推荐,芯片复位后,利用芯片复位状态寄存器值,对由于看门狗复位事件计数,事不过三,如果连续三次此类复位,则保守做法就是将系统切换到安全状态或显示错误消息,这样可以避免无限重新启动。

·....取决于具体的设计策略

如果我们希望系统快速恢复,应该采用看门狗复位后的初始化比正常加电初始化短的策略。也就是说跳过设备的一些自检。当然,在某些系统中最好进行全面自检,因为看门狗超时的根本原因可能是通过此类硬件异常导致的。

该咋喂狗呢?

对于裸机程序而言,我推荐了下面两种处理策略:故障检测式喂狗,故障检测加强式喂狗。

故障检测式喂狗

对于一个裸奔单片机程序而言,可以在喂狗时同时检测一些关键的运行时状态,比如栈深度、缓冲区、关键功能链的硬件(如传感器、执行机构等),如这些状态异常,则记录错误状态,将设备至于功能安全状态。

故障检测加强式喂狗

啥叫序列检测式喂狗呢?IEC61508中有种范式叫sequence check,有点邪乎?看下图,你就马上明了了。

将是将main函数的主体关键功能块,设置一个序列标记,如果如果序列出错就做安全故障处理,正确则继续下一块的执行。在喂狗的时候,看下序列是否正确,正确就喂,否则就做错误处理,或者干脆让狗叫也是一种方式。

对于多任务实时系统而言,有这样一些不一样的需求:

·检测操作系统是否正确运行

·在所有任务中检测是否有死循环

·检测涉及两个或多个任务的死锁

·检测由于高优先级任务占用CPU而导致某些低优先级任务无法运行

母狗带群仔喂狗法

取这个名字有点俗了,哈哈哈。为了方便理解,就这么叫吧,依然上个图了在解释吧:

实现策略描述:

watchdogTask可看成狗窝,里面住了一堆狗,其中硬件看门狗是母狗,子任务软件看门狗为小狗仔。每个子任务须要在每一个loop循环喂一次狗(当然实际实现时也能够加入任务故障检测式喂狗),在watchdogTask每一个循环都对所有软件看门狗递减,假如溢出则软狗叫了,须要做异常处理(复位或进入失效安全模式)。假如所有的软件狗都没有溢出,则喂硬件看门狗(可能是单片机内置或外置芯片)

实际实现时须注意:

watchdogTask应选取最高优先级

每个loop应调用os_delay一定时长,以出让CPU时长给其他task运行。挂起的时长应小于最大硬件看门狗延时时长。

须合理安排各任务的优先级

不要在中断以及其他函数中私自喂狗。

狗多久叫合理呢

过短之痛

看门狗定时器定时时长设置过短,则系统容易误判,可能会导致频繁复位或进入失效安全模式。由于任何一条安全链的好坏取决于它最单薄的一环,假如选择一个太短的超时长隔。固件的循环时长是动态的,尤其外部的异步事件比较多,或者有中断嵌套的情况,则波动会比较大,所以须要考虑最坏情况,系统循环一次要多久。

多长之害

一种方法是选择一个几秒钟长的间隔。当您仅尝试复位一个的确挂起的系统,但不希望对系统的时长进行详细钻研时,能够采用此策略。这是一个健壮的方法。但有些系统须要快捷恢复,这就造成故障诊断过慢的危害了,尤其在一些对安全要求极高的场合,假如核电系统,汽车电子系统、医疗器械系统等等。

所以实际设计时须要兼顾最坏情况下,尽量选择相对较短的定时时长,在两者中寻找一个均衡。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
经济下行时谁在闷声发大财?日本房地产泡沫破裂后这些行业迅速兴起

经济下行时谁在闷声发大财?日本房地产泡沫破裂后这些行业迅速兴起

日本物语
2024-06-16 20:39:24
中央督查组稽查云南:5000万专项治理经费,实际拨付率为0

中央督查组稽查云南:5000万专项治理经费,实际拨付率为0

小鬼头体育
2024-06-16 17:34:59
中国经济巨大成就的背后:有两个痛点,是什么痛点?

中国经济巨大成就的背后:有两个痛点,是什么痛点?

永不出场的戈多
2024-06-15 07:58:52
上海一家三口出动,去香港过周末!刚刚,首趟列车到站:夕发朝至,还供应港式美食

上海一家三口出动,去香港过周末!刚刚,首趟列车到站:夕发朝至,还供应港式美食

上观新闻
2024-06-16 12:11:22
追梦回应克莱取关勇士:我觉得这很好笑 你们都想看有人感到受伤

追梦回应克莱取关勇士:我觉得这很好笑 你们都想看有人感到受伤

罗说NBA
2024-06-16 05:19:26
很突然,以色列彻底陷入了混乱

很突然,以色列彻底陷入了混乱

林林爱天堂
2024-06-15 16:11:37
12秒80!吴艳妮逆天一战,在日本2连冠,再创年度亚洲最佳成绩

12秒80!吴艳妮逆天一战,在日本2连冠,再创年度亚洲最佳成绩

黑色柳丁
2024-05-19 15:09:30
《墨雨云间》中,当丫鬟的造型和女主一样,就很考验女主的颜值了

《墨雨云间》中,当丫鬟的造型和女主一样,就很考验女主的颜值了

大铁猫娱乐
2024-06-16 16:51:06
冷门要来了?詹俊:这届欧洲杯第一个冷门什么时候出现? 今晚么?

冷门要来了?詹俊:这届欧洲杯第一个冷门什么时候出现? 今晚么?

直播吧
2024-06-16 13:10:13
乌兹别克斯坦夫人给韩国夫人上了一堂出访课,这次遇到了强对手!

乌兹别克斯坦夫人给韩国夫人上了一堂出访课,这次遇到了强对手!

小毅讲历史
2024-06-15 19:11:33
热话 | 香港惊现全城狂欢!原来是为了这件事!

热话 | 香港惊现全城狂欢!原来是为了这件事!

港漂圈
2024-06-15 21:25:08
刘亦菲一年的收入,大概是多少钱?

刘亦菲一年的收入,大概是多少钱?

娱记掌门
2024-06-16 16:13:01
澳大利亚口出狂言:月球是人类的共同财产,中国必须把月壤共享

澳大利亚口出狂言:月球是人类的共同财产,中国必须把月壤共享

电动猫
2024-06-15 21:40:18
外媒:以色列面对真主党左右为难

外媒:以色列面对真主党左右为难

参考消息
2024-06-16 09:57:07
中纪委周末再打“虎”:正部级吴英杰被查

中纪委周末再打“虎”:正部级吴英杰被查

澎湃新闻
2024-06-16 11:26:26
闹大了!英媒 美国宇航局必须从国际空间站救出星际客机机组人员

闹大了!英媒 美国宇航局必须从国际空间站救出星际客机机组人员

嘿哥哥科技
2024-06-16 17:18:30
终于明白为啥现在的女生都害怕生孩子了,评论让我破大防

终于明白为啥现在的女生都害怕生孩子了,评论让我破大防

阿康四岁啦
2024-06-16 17:26:26
热议申花1-1成都:两边门将都有国门潜质,申花轮转换位很好

热议申花1-1成都:两边门将都有国门潜质,申花轮转换位很好

懂球帝
2024-06-16 21:49:12
30岁凯恩伤感表态:你们总讽我无冠,我是知道的;欧洲杯一定夺冠

30岁凯恩伤感表态:你们总讽我无冠,我是知道的;欧洲杯一定夺冠

风过乡
2024-06-16 13:15:02
奚梦瑶携儿女为何超欣庆生,姑嫂合照好开心,5岁何广燊长高许多

奚梦瑶携儿女为何超欣庆生,姑嫂合照好开心,5岁何广燊长高许多

笑猫说说
2024-06-15 04:45:19
2024-06-16 22:52:49
大方老师单片机
大方老师单片机
领单片机速学资料,点我头像~
259文章数 1144关注度
往期回顾 全部

科技要闻

iPhone 16会杀死大模型APP吗?

头条要闻

理想车友聚会多车连环追尾 组织者:突遭大雨 车距较近

头条要闻

理想车友聚会多车连环追尾 组织者:突遭大雨 车距较近

体育要闻

没人永远年轻 但青春如此无敌还是离谱了些

娱乐要闻

上影节红毯:倪妮好松弛,娜扎吸睛

财经要闻

打断妻子多根肋骨 上市公司创始人被公诉

汽车要闻

售17.68万-21.68万元 极狐阿尔法S5正式上市

态度原创

房产
本地
数码
健康
公开课

房产要闻

万华对面!海口今年首宗超百亩宅地,重磅挂出!

本地新闻

粽情一夏|海河龙舟赛,竟然成了外国人的大party!

数码要闻

AMD RDNA3.5核显跑分喜人!非常接近RTX 2050

晚餐不吃or吃七分饱,哪种更减肥?

公开课

近视只是视力差?小心并发症

无障碍浏览 进入关怀版