【STM32】WDG看门狗

2024-01-09 23:36
文章标签 看门狗 stm32 wdg

本文主要是介绍【STM32】WDG看门狗,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 WDG简介

WDG(Watchdog)看门狗

看门狗可以监控程序的运行状态,当程序因为设计漏洞、硬件故障、电磁干扰等原因,出现卡死或跑飞现象时,看门狗能及时复位程序,避免程序陷入长时间的罢工状态,保证系统的可靠性和安全性

看门狗本质上是一个定时器,当指定时间范围内,程序没有执行喂狗(重置计数器)操作时,看门狗硬件电路就自动产生复位信号

STM32内置两个看门狗

                独立看门狗(IWDG):独立工作,对时间精度要求较低(独立的时钟)

                窗口看门狗(WWDG):要求看门狗在精确计时窗口起作用(APB1的时钟)

1.1 独立看门狗IWDG

1.1.1 IWDG框图

对比定时器的时基单元来看,时基单元由:预分频器、计数器、重装寄存器组成。

定时器溢出,直接看门狗复位。重装值定时器是在更新事件重装,看门狗则是在自减等于0之前,手动重装。喂狗操作就是重置这个递减计数器。

LSI内部低速时钟,频率是40KHz,之后时钟进入预分频器进行分频,最大分频256,上面的预分频寄存器IWDG_PR可以配置分频系数,PR和定时器的PSC一个意思;经过预分频器分频之后,时钟驱动递减计数器,每来一个时钟,自减一个数,最大值是4095;当自减到0之后,产生IWDG复位;正常运行时,为了避免复位,提前在重装寄存器IWDG_PLR(和定时器的ARR一个意思)写一个值。在键寄存器中写一个特定的数据,控制电路,进行喂狗。这时重装值就会复制到当前的计数器中,这样计数器就会回到重装值,重新自减运行了。状态寄存器IWDG_SR标志电路运行的状态了。

上面这些寄存器位于1.8V供电区,下面主要的工作电路都位于VDD供电区。

1.1.2 IWDG键寄存器

键寄存器本质上是控制寄存器,用于控制硬件电路的工作

在可能存在干扰的情况下,一般通过在整个键寄存器写入特定值来代替控制寄存器写入一位的功能,以降低硬件电路受到干扰的概率

写入键寄存器的值

作用

0xCCCC

启用独立看门狗

0xAAAA

IWDG_RLR中的值重新加载到计数器(喂狗)

0x5555

解除IWDG_PRIWDG_RLR的写保护

0x5555之外的其他值

启用IWDG_PRIWDG_RLR的写保护

1.1.3 IWDG超时时间

LSI是输入时钟:40KHz,FLSI = 40K

对应定时器就是72M/(PSC+1)/(ARR+1)

以第一行为例:

周期TLSI = 1/40K = 0.025ms

最短时间:TIWDG = 0.025ms * 4 * (0 + 1) = 0.1ms

最长时间:TIWDG = 0.025ms * 4 * (4095 + 1) = 409.6ms

1.2 窗口看门狗WWDG

1.2.1 WWDG框图

左下角是时钟源部分PCLK1(PPB1,36MHZ),右边是预分频器(WDGTB),接着上面是6位递减计数器CNT(T5~T0有效,T6是移出标志位,值是1时,计数器没有移出;为0时移出。把T6看作计数器的一部分,就是减到0x40(100 0000)后溢出;把T6看作溢出位,那就是低6位的数据减到0之后溢出),位于控制寄存器WWDG_CR里。窗口看门狗没有重装寄存器,直接在CNT写入数据就是了,最上面是窗口值(WWDG_CFR),也就是喂狗的最早时间界限,最后左边就是输出信号的逻辑了。

复位信号输出部分,WDGA就是窗口看门狗的激活位,也是就是使能。两个来源都可以复位,下面这一路来源于溢出标志位T6,溢出标志位为0,取反为1,或门为1,1&1=1,总的与门出去就是复位(避免T6位为0,避免复位)。

喂狗时间的最早界限由上面实现,首先要计算一个最早界限的计数值,写入到这里的W6~W0中,写入之后是不变的。一旦执行写入WWDG_CR操作时,这个与门就会打开写入CR就是写入计数器,也就是喂狗,在喂狗时,这个比较器开始工作,一旦比较当前计数器的值T6:0>窗口值W6:0,比较结果就是1,这个1通过或门也可以去申请复位,这就是喂狗最早时间窗口的实现流程。

1.2.2 WWDG工作特性

递减计数器T[6:0]的值小于0x40时,WWDG产生复位(包含T6位)

递减计数器T[6:0]在窗口W[6:0]外被重新装载时,WWDG产生复位(不能过早喂狗)

递减计数器T[6:0]等于0x40时可以产生早期唤醒中断(EWI),用于重装载计数器以避免WWDG复位

定期写入WWDG_CR寄存器(喂狗)以避免WWDG复位

1.2.3 WWDG超时时间

超时时间TWWDG就是喂狗的最晚时间;窗口时间TWIN就是喂狗的最早时间。有个固定4096分频。

只有1/2/4/8分频。不包含T6、W6。

以第一行为例:

TWWDG = 1/36M * 4096 * 1 * 1 = 113us;

TWIN = 1/36M * 4096 * 64 = 7.28ms

2倍递增

1.3 IWDG和WWDG对比

IWDG独立看门狗

WWDG窗口看门狗

复位

计数器减到0

计数器T[5:0]减到0后、过早重装计数器

中断

早期唤醒中断

时钟源

LSI40KHz

PCLK136MHz

预分频系数

483264128256

1248

计数器

12

6位(有效计数)

超时时间

0.1ms~26214.4ms

113us~58.25ms

喂狗方式

写入键寄存器,重装固定值RLR

直接写入计数器,写多少重装多少

防误操作

键寄存器和写保护

用途

独立工作,对时间精度要求较低

要求看门狗在精确计时窗口起作用

手册

这篇关于【STM32】WDG看门狗的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/588813

相关文章

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

STM32(十一):ADC数模转换器实验

AD单通道: 1.RCC开启GPIO和ADC时钟。配置ADCCLK分频器。 2.配置GPIO,把GPIO配置成模拟输入的模式。 3.配置多路开关,把左面通道接入到右面规则组列表里。 4.配置ADC转换器, 包括AD转换器和AD数据寄存器。单次转换,连续转换;扫描、非扫描;有几个通道,触发源是什么,数据对齐是左对齐还是右对齐。 5.ADC_CMD 开启ADC。 void RCC_AD

STM32内部闪存FLASH(内部ROM)、IAP

1 FLASH简介  1 利用程序存储器的剩余空间来保存掉电不丢失的用户数据 2 通过在程序中编程(IAP)实现程序的自我更新 (OTA) 3在线编程(ICP把整个程序都更新掉) 1 系统的Bootloader写死了,只能用串口下载到指定的位置,启动方式也不方便需要配置BOOT引脚触发启动  4 IAP(自己写的Bootloader,实现程序升级) 1 比如蓝牙转串口,

FreeRTOS-基本介绍和移植STM32

FreeRTOS-基本介绍和STM32移植 一、裸机开发和操作系统开发介绍二、任务调度和任务状态介绍2.1 任务调度2.1.1 抢占式调度2.1.2 时间片调度 2.2 任务状态 三、FreeRTOS源码和移植STM323.1 FreeRTOS源码3.2 FreeRTOS移植STM323.2.1 代码移植3.2.2 时钟中断配置 一、裸机开发和操作系统开发介绍 裸机:前后台系

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类

STM32 ADC+DMA导致写FLASH失败

最近用STM32G070系列的ADC+DMA采样时,遇到了一些小坑记录一下; 一、ADC+DMA采样时进入死循环; 解决方法:ADC-dma死循环问题_stm32 adc dma死机-CSDN博客 将ADC的DMA中断调整为最高,且增大ADCHAL_ADC_Start_DMA(&hadc1, (uint32_t*)adc_buffer, ADC_Buffer_Size); 的ADC_Bu

基于stm32的河流检测系统-单片机毕业设计

文章目录 前言资料获取设计介绍功能介绍具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机设计精品

STM32的使用方法一

注:我采用的是STM32F103RC芯片、相应的电路图和STM32CubeIDE软件这是在STM32CubeIDE软件定义芯片后,所给的必要的代码逻辑,加上了注释 #include "main.h"/* Private variables ---------------------------------------------------------*//* Private function

STM32 HAL CAN通讯 实操

1、简介 相比于串口通讯,对于刚接触CAN通讯的小白来说,CAN通讯相对复杂,看各种视频、帖子理论,总是一知半解。本次通过傻瓜式操作,先实现CAN通讯的交互,以提高小白的信心,也便于自己复习观看。本次以STM32CubeMX进行初始化配置,通过Keil 5软件进行软件设计,通过CAN盒实现进行数据的交互。该流程实际以STM32F0、F1、F3、F4、F7实测好用(理论上都适用),这三种型号单片机

我在高职教STM32——准备HAL库工程模板(1)

新学期开学在即,又要给学生上 STM32 嵌入式课程了。这课上了多年了,一直用的都是标准库来开发,已经驾轻就熟了。人就是这样,有了自己熟悉的舒适圈,就很难做出改变,老师上课也是如此,排斥新课和不熟悉的内容。显然,STM32 的开发,HAL 库已是主流,自己其实也在使用,只不过更换库就意味着教学内容有很大变化,自己也就迟迟没有迈出调整这一步。现在,是时候做出变化了,笔者计划保持教学项