0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

看门狗!守护系统稳定性的关键技术

朱老师物联网大讲堂 2024-06-24 08:10 次阅读

看门狗定时器(Watchdog Timer,WDT)是嵌入式系统中至关重要的组件,用于监控和维护系统的稳定性。主要是用来监测单片机运行状态和解决程序引起的故障的模块。在由单片机构成的微型计算机系统中,由于单片机的工作常常会受到来自外界电磁场的干扰,造成程序的跑飞,而陷入死循环,程序的正常运行被打断,由单片机控制的系统无法继续工作,会造成整个系统的陷入停滞状态,发生不可预料的后果,所以出于对单片机运行状态进行实时监测的考虑,便产生了一种专门用于监测单片机程序运行状态的芯片,俗称“看门狗”(watchdog)。根据功能不同,通常分为独立看门狗和窗口看门狗。因为独立看门狗受工作场合因素的影响会多一点,仅适用于一些对时间精度要求较低的场合;窗口看门狗适用于对时间精度高的场合。

一、独立看门狗

独立看门狗本质上是一个定时器,这个定时器有一个输出端,可以输出复位信号。该定时器是一个 12 位的递减计数器,当计数器的值减到 0 的时候,就会产生一个复位信号。如果在计数没减到 0 之前,重置计数器的值的话,那么就不会产生复位信号,这个动作我们称为喂狗。看门狗功能由 VDD 电压域供电,在停止模式和待机模式下仍然可以工作。

332777de-31be-11ef-a655-92fbcf53809c.png

从 IWDG 框图整体认知可得以下结论:

时钟源:IWDG 的时钟源通常来自一个低速内部振荡器(LSI),独立于主系统时钟,确保在主系统时钟故障时仍能正常运行。

分频器:IWDG 使用分频器来调整计时器的频率。通过配置分频器,可以改变 IWDG 的计时周期,从而灵活控制超时时间。

计数器:计数器是 IWDG 的核心部分,它会根据配置的分频值进行递减计数。系统需要定期重置计数器(即“喂狗”),以防止计数器达到零触发复位。

复位控制逻辑:当计数器达到零时,复位控制逻辑会生成一个复位信号,触发系统复位。

控制寄存器:IWDG 包含一组控制寄存器,用于配置分频值、计数器初始值以及控制 IWDG 的启停状态。

  • 看门狗启动逻辑:该逻辑用于启用和禁用 IWDG。在一些系统中,IWDG 的启动逻辑可能是一次性的,即一旦启动便无法关闭,以增强系统的安全性。

IWDG 的工作流程可以概括为以下几个步骤:

3344f462-31be-11ef-a655-92fbcf53809c.png

时钟源供电:IWDG 通过低速内部振荡器(LSI)提供的时钟信号进行计时,确保即使主系统时钟发生故障,IWDG 仍然可以正常运行。

配置分频器:通过设置控制寄存器中的分频器值,调整 IWDG 的计时频率和超时时间。常见的分频值范围从 4 到 256 倍,以适应不同的应用需求。

初始化计数器:将计数器初始化为一个预设值,开始计时。计数器会根据配置的分频值逐渐递减。

系统定期“喂狗”:在系统正常运行过程中,主程序或定时任务需要定期重置计数器,以防止计数器达到零。如果计数器未在设定时间内重置,IWDG 将认为系统出现了故障。

触发复位:当计数器递减至零时,复位控制逻辑生成复位信号,触发系统复位。系统复位后,重新初始化 IWDG,并进入正常工作状态。

二、 窗口看门狗

窗口看门狗(Window Watchdog,WWDG)是一种高级看门狗定时器,主要用于检测系统在指定时间窗口内的运行情况。相比于传统的看门狗定时器,窗口看门狗通过限制系统“喂狗”的时间窗口,能够更精准地监控系统的运行状态,避免系统过早或过晚重置看门狗。本文将通过框图介绍窗口看门狗的整体结构和功能。

335d20e6-31be-11ef-a655-92fbcf53809c.png

对于一般的看门狗,程序可以在它产生复位前的任意时刻刷新看门狗,但这有一个隐患,有可能程序跑乱了又跑回到正常的地方,或跑乱的程序正好执行了刷新看门狗操作,这样的情况下一般的看门狗就检测不出来了,如果使用窗口看门狗,程序员可以根据程序正常执行的时间设置刷新看门狗的一个时间窗口,保证不会提前刷新看门狗也不会滞后刷新看门狗,这样可以检测出程序没有按照正常的路径运行非正常地跳过了某些程序段的情况。

337601c4-31be-11ef-a655-92fbcf53809c.png

窗口看门狗中有一个7位的递减计数器T[6:0],它会在出现下述2种情况之一时产生看门狗复位:

当喂狗的时候如果计数器的值大于某一设定数值W[6:0]时,此设定数值在WWDG——CFR寄存器定义。(上窗口)

当计数器的数值从0x40见到0x3F时,【T6位跳变到0】。(下窗口)

如果启动了看门狗并且允许中断,当递减计数器等于0x40时,产生早期唤醒中断(EWI),它可以用于喂狗以避免WWDG复位。

三、总结

窗口看门狗作为一种先进的时间监控机制,能够有效提升系统的实时性和安全性。通过合理配置和使用窗口看门狗,开发者可以确保系统在复杂环境中稳定运行,防止系统因时间偏差或异常操作而失控。未来,随着嵌入式系统技术的不断发展,窗口看门狗将在系统安全和稳定性保障方面继续发挥重要作用。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5062

    文章

    18984

    浏览量

    302380
  • 监测
    +关注

    关注

    2

    文章

    3510

    浏览量

    44407
  • 看门狗定时器

    关注

    0

    文章

    38

    浏览量

    16241
收藏 人收藏

    评论

    相关推荐

    AT32单片机看门狗简介

    看门狗通常用来提高系统稳定性。当因为一些特殊的情况导致程序跑飞,或者运行逻辑错误,而没 有及时喂狗时,看门狗会将MCU重新复位,以达到自动从异常中恢复的效果。建议用户在所有应用中都使
    发表于 08-05 09:43 2630次阅读

    STM32中的独立看门狗和窗口看门狗是什么

    在早期的MCU中是没有看门狗这种东西的,所以产品就很容易出现死机,跑飞的情况。为了避免这种情况的出现,后期的MCU都集成了看门狗的功能。但是目前看门狗发展到今天基本上分为两大类:独立看门狗
    的头像 发表于 02-20 17:47 2655次阅读
    STM32中的独立<b class='flag-5'>看门狗</b>和窗口<b class='flag-5'>看门狗</b>是什么

    基于Keil C51的软件看门狗系统设计

    介绍了一种基于Keil C51环境的软件看门狗设计方法。通过设置程序、喂狗程序和中断服务程序的有效配合,解决软件模块的稳定性问题。设置程序在模块开始处对看门狗系统进行初值设定,喂狗程序
    发表于 03-04 14:25

    看门狗芯片MAX708的工作原理及数据保护系统设计

    看门狗芯片MAX708的工作原理及数据保护系统设计 引 言 单片机的程序稳定性
    发表于 08-15 16:13 9283次阅读

    什么是看门狗电路

    看门狗电路 看门狗电路一般有软件看门狗和硬件看门狗两种。软件看门狗不需外接硬件电路,但系统需要
    发表于 10-21 01:40 8114次阅读

    stm32看门狗时间计算 独立看门狗和窗口看门狗的特性是什么

    本文为您讲解STM看门狗时间计算(时限)与频率计算,独立看门狗和窗口看门狗的特性、区别与联系。
    发表于 10-10 10:41 8728次阅读

    什么是stm32看门狗?独立看门狗和窗口看门狗工作原理解析

    stm32有两个看门狗,独立看门狗和窗口看门狗,其实两者的功能是类似的,只是喂狗的限制时间不同。 独立看门狗
    的头像 发表于 11-06 11:48 2.7w次阅读
    什么是stm32<b class='flag-5'>看门狗</b>?独立<b class='flag-5'>看门狗</b>和窗口<b class='flag-5'>看门狗</b>工作原理解析

    STM32看门狗配置(独立看门狗IWDG和窗口看门狗WWDG)

    stm32自带两个看门狗模块,独立看门狗IWDG和窗口看门狗WWDG。看门狗主要作用是可用来检测和解决由软件错误引起的故障;当计数器达到给定的超时值时,触发一个中断(仅适用于窗口型
    发表于 11-09 17:17 8389次阅读
    STM32<b class='flag-5'>看门狗</b>配置(独立<b class='flag-5'>看门狗</b>IWDG和窗口<b class='flag-5'>看门狗</b>WWDG)

    STM32:独立看门狗、窗口看门狗的配置

    STM32单片机的看门狗有独立看门狗和窗口看门狗之分,这两者的工作原理却完全不同。
    发表于 02-08 16:15 18次下载
    STM32:独立<b class='flag-5'>看门狗</b>、窗口<b class='flag-5'>看门狗</b>的配置

    STM32中的独立看门狗和窗口看门狗

    和窗口看门狗。 独立看门狗:使用的是外部时钟,即使主频不工作了,看门狗也能正常工作。只要在到达喂狗时间的上限前喂狗即表示程序是正常的,这点和窗口看门狗是有区别的。另外独立
    的头像 发表于 12-22 16:58 2039次阅读

    STM32中的独立看门狗和窗口看门狗

    在早期的MCU中是没有看门狗这种东西的,所以产品就很容易出现死机,跑飞的情况。为了避免这种情况的出现,后期的MCU都集成了看门狗的功能。但是目前看门狗发展到今天基本上分为两大类:独立看门狗
    的头像 发表于 01-30 14:38 1314次阅读
    STM32中的独立<b class='flag-5'>看门狗</b>和窗口<b class='flag-5'>看门狗</b>

    什么是看门狗,工业路由器看门狗技术的功能优势

    工业路由器大多都会配备看门狗技术,它是保证工业路由器传输过程中连续24小时不宕机的重要保护技术,那么,什么是看门狗呢?▍看门狗功能
    的头像 发表于 03-27 10:16 1753次阅读
    什么是<b class='flag-5'>看门狗</b>,工业路由器<b class='flag-5'>看门狗</b><b class='flag-5'>技术</b>的功能优势

    看门狗芯片具有哪些功能?

    看门狗芯片可以通过多种方式来保证系统稳定性和安全性,从而提高系统的可靠性和可用性。在需要长时间稳定运行的场景中,
    的头像 发表于 07-05 14:37 1834次阅读

    嵌入式看门狗如何提高系统稳定性

    在嵌入式系统设计中,系统稳定性至关重要,它决定了系统的价值及竞争力,而看门狗作为一种重要的稳定性
    的头像 发表于 02-20 16:14 629次阅读

    软件看门狗和硬件看门狗的区别

    软件看门狗和硬件看门狗都是用于监控系统崩溃的工具,它们的作用是在系统出现故障或异常情况时自动恢复系统。  软件
    的头像 发表于 04-16 15:10 908次阅读