STM32 HAL库 STM32CubeMX -- IWDG(独立看门狗)

STM32 HAL库 STM32CubeMX -- IWDG

  • 一、IWDG简介
  • 二、独立看门狗的工作原理
  • 三、驱动函数
    • 初始化函数HAL IWDG Init()
    • 初始化函数HAL IWDG Init()
    • 其他宏函数
  • 四、超时时间计算
    • 第一种办法
    • 第二种办法(推荐)

一、IWDG简介

看门狗(Watchdog)就是MCU上的一种特殊的定时器,用于监视系统的运行,在发生错误(例如程序出现死循环)时,能触发一个中断或产生系统复位,防止程序跑飞。STM32 有两个看门狗,一个是独立看门狗另外一个是窗口看门狗,独立看门狗号称宠物狗,窗口看门狗号称警犬。

二、独立看门狗的工作原理

独立看门狗(Independent Watchdog,IWDG)是由内部 32kHz 低速时钟 LSI 驱动的自由运行的 12 位递减计数器。LSI在时钟树上的位置如下图所示。
在这里插入图片描述
独立看门狗的内部功能框图如下图所示。
在这里插入图片描述

本节先分析独立看门狗的功能框图和它的应用;

独立看门狗用通俗一点的话来解释就是一个12 位的递减计数器,当计数器的值从某个值一直减到0 的时候,系统就会产生一个复位信号,即IWDG_RESET。如果在计数没减到0 之前,刷新了计数器的值的话,那么就不会产生复位信号,这个动作就是喂狗 。

独立看门狗一般用来检测和解决由程序引起的故障,比如一个程序正常运行的时间是50ms,在运行完这个段程序之后紧接着进行喂狗,我们设置独立看门狗的定时溢出时间为60ms,比我们需要监控的程序50ms 多一点,如果超过60ms 还没有喂狗,那就说明我们监控的程序出故障了,跑飞了,那么就会产生系统复位,让程序重新运行。

看门狗功能由VDD 电压域供电,在停止模式和待机模式下仍能工作。

1、独立看门狗时钟
独立看门狗的时钟由独立的RC 振荡器LSI 提供,即使主时钟发生故障它仍然有效,非常独立。LSI 的频率一般在30~60KHZ 之间,根据温度和工作场合会有一定的漂移,所以独立看门狗的定时时间并不一定非常精确,只适用于对时间精度要求比较低的场合。

2、计数器时钟
递减计数器的时钟由LSI 经过一个8 位的预分频器得到,在预分频器寄存器 IWDG_PR 里,有 PR[2:0]用于设置分频系数,分频系数从 4、8、16 到 256。

3、计数器
独立看门狗的计数器是一个12 位的递减计数器,最大值为0XFFF,当计数器减到0 时,会产生一个复位信号:IWDG_RESET,让程序重新启动运行,如果在计数器减到0 之前刷新了计数器的值的话,就不会产生复位信号,重新刷新计数器值的这个动作我们俗称喂狗。

4、重装载寄存器
重独立看门狗有一个重载寄存器IWDG RLR,可以设置一个 12位的重载值,例如 4000。在看门狗的递减计数器的值变为0之前,将IWDG_RLR 里的值重新载入看门狗计数器,就可以避免产生复位。超时时间Tout = (预分频因子*(重装载值+1))/LSI。关于计算超时时间在下面会详细介绍。

5、键寄存器
独立看门狗还有一个关键字寄存器 IWDG KR,其 KEY[15:0]是一个只可以写的关键字写入不同的关键字有不同的作用。
●写入 0xAAAA 时,重载寄存器 IWDG RLR 中的 12 位值就会被写入计数器,从而使计数器从头开始递减计数,避免系统复位。此操作称为刷新看门狗。
●写入 0x5555 后,才可以修改预分频器寄存器IWDG PR 和重载寄存器 IWDG_RLR 的内容。
●写入 0xCCCC 时,启动独立看门狗。
LSI时钟频率是 32kHz,看门狗最大重载值是4095(对应0xFFF),根据预分频系数可以计算出IWDG 的最长超时(timeout),如下表所示。
在这里插入图片描述

6、状态寄存器
状态寄存器SR 只有位0:PVU 和位1:RVU 有效,这两位只能由硬件操作,软件操作不了。RVU:看门狗计数器重装载值更新,硬件置1 表示重装载值的更新正在进行中,更新完毕之后由硬件清0。PVU: 看门狗预分频值更新,硬件置’1’指示预分频值的更新正在进行中,当更新完成后,由硬件清0。所以只有当RVU/PVU 等于0 的时候才可以更新重装载寄存器/预分频寄存器。

三、驱动函数

独立看门狗的驱动函数比较只有2个常规函数和几个宏函数。独立看门狗没有中断。

初始化函数HAL IWDG Init()

结构体 IWDG HandleTypeDef的定义如下,各成员变量的意义见注释:

typedef struct
{IWDG_TypeDef                 *Instance;  /*!< IWDG寄存器基地    */IWDG_InitTypeDef             Init;       /*!< IWDG 的参数 */
} IWDG_HandleTypeDef;

其中的成员变量 Init 是结构体类型 IWDG_ImitTypeDef,它定义了IWDG的参数,这个结构体定义如下,各成员变量的意义见注释:

typedef struct
{uint32_t Prescaler;  /*!< IWDG 预分频系数,也就是预分频寄存器IWDG_PR里的 PR[2:0] */uint32_t Reload;     /*!< IWDG计数器重载值,也就是重载寄存器IWDG_RLR 的值 */} IWDG_InitTypeDef;

初始化函数HAL IWDG Init()

HAL IWDG Refresh()用于刷新看门狗,就是将重载寄存器IWDG_RLR 的值重新载入看门狗计数器,避免产生系统复位。函数HAL_IWDG _Refresh()的原型定义如下,只需使用IWDC对象指针作为函数参数:
HAL_StatusTypeDef HAL IWDG Refresh(IWDG HandleTypeDef *hiwdg);

其他宏函数

文件 stm32f4xx hal iwdg.h 还有几个主要的宏函数,这些函数的输入参数__HANDLE__是独立看门狗对象指针。
●HAL_IWDGSTART(HANDLE),启动独立看门狗,就是向关键字寄存器IWDG_KR写入 0x0000CCCc。
●HAL_IWDG_RELOADCOUNTER(HANDLE),重置看门狗计数器的值,就是向关键字寄存器 IWDG_KR 写入 0x0000AAAA,这会导致重载寄存器IWDG_RLR中的值载入看门狗计数器。这个宏函数与函数HAL_IWDG_RefreshO的功能相同。
●IWDG_ENABLE_WRITE ACCESS(HANDLE),使预分频寄存器IWDG_PR 和重载存器 IWDG_RLR 变为可写的,其代码就是向关键字寄存器 IWDG_KR 写入 0x00005555。
●IWDG_DISABLE_WRITEACCESS(HANDLE),使预分频寄存器IWDG_PR 和重载寄存器 IWDG_RLR 变为不可写的,其代码就是向关键字寄存器 IWDG KR 写入0x00000000。

四、超时时间计算

在这里插入图片描述
通过查阅多个文档和网上各种资料,有两种计算办法
两种办法大家酌情选择

第一种办法

Tout = ( (4*2^PR) * (RLV+1) )/ LSI;其中PR为上图中预分频系数对应的PR[2:0]位、RLV为重装载值(0 ~ 4095)、LSI为内部低速时钟,也就是驱动IWDG的时钟,F1一般LSI为40kHz ;

示例:
以F1为例,LSI为40kHz、预分频系数为8,PR为1、RLV为04095
最短时间:RLV为0,Tout = ((4*2^PR)*(RLV+1)) / LSI = ((4*2)*(0+1)) / 40000 = 0.0002s = 0.2ms
最长时间:RLV为4095,Tout = ((4*2^PR)*(RLV+1)) / LSI = ((4*2)*(4095+1)) / 40000 = 0.8192s = 8192ms

第二种办法(推荐)

Tout = (预分频系数 * (重装载值+1)) / LSI;其中预分频系数和重装载值为直接设置的,后面结合配置STM32Cube MX会很方便;LSI为内部低速时钟,F1一般为40kHz;

示例:
以F1为例,LSI为40kHz、预分频系数为8,重装载值为04095
最短时间:重装载值为0,Tout = (预分频系数*重装载值) / LSI = (8*1) / 40000 = 0.0002s = 0.2ms
最长时间:重装载值为4095,Tout = (预分频系数*重装载值) / LSI = (8*4096) / 40000 =0.8192s = 8192ms

这两种办法都可以算出上表中的数值,其实仔细分析这两种办法,原理其实都一样,为例方便算一点推荐使用第二种办法。

四、STM32Cube MX 配置
基础STM32Cube MX的配置参考这篇博客:STM32 CubeMx教程 – 基础知识及配置使用教程

配置RCC,使用外部晶振模式
在这里插入图片描述

配置SYS,debug模式选择Serial Wire
在这里插入图片描述

参数设置部分只有两个参数:
配置IWDG,先启用独立看门狗,配置预分频系数为32,重装载值为124;
Tout = (32*(124+1))/ 40000 = 100ms
在这里插入图片描述

使用一个串口用来打印调试信息,设置为异步通信模式
在这里插入图片描述

配置时钟树,从图上可以看到里面默认的LSI RC振荡时钟 40kHz ,LSI时钟配置到了IWDG
在这里插入图片描述

涉及到IWDG(独立看门狗)的函数有两个:

MX_IWDG_Init(); 	//独立看门狗初始化
HAL_IWDG_Refresh(&hiwdg);	//喂狗

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/471062.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

09、全文检索 -- Solr -- SpringBoot 整合 Spring Data Solr (生成DAO组件 和 实现自定义查询方法)

目录 SpringBoot 整合 Spring Data SolrSpring Data Solr的功能&#xff08;生成DAO组件&#xff09;&#xff1a;Spring Data Solr大致包括如下几方面功能&#xff1a;Query查询&#xff08;属于半自动&#xff09;代码演示&#xff1a;1、演示通过dao组件来保存文档1、实体类…

docker (一)-简介

1.什么是docker Docker 是一个开源的应用容器引擎&#xff0c;由于docker影响巨大&#xff0c;今天也用"Docker" 指代容器化技术。 2.docker的优势 一键部署&#xff0c;开箱即用 容器使用基于image镜像的部署模式&#xff0c;image中包含了运行应用程序所需的一…

如何测试两台计算机的TCP通信

如何在Linux上安装Tcpping&#xff1f; 测量到远程主机的网络延迟的一种常用方法是使用ping应用程序。该ping工具依赖ICMP ECHO请求和回复数据包来测量远程主机的往返延迟。 但是&#xff0c;在某些情况下&#xff0c;ICMP流量可能会被防火墙阻止&#xff0c;这使得该ping应用…

关于java的网图下载

关于java的网图下载 我们在上篇文章中&#xff0c;学习到了用Thread类去创建多线程&#xff0c;我们本篇文章来向大家介绍一下网图下载功能&#xff0c;利用多线程同时下载多个图片&#x1f609; 一、下载器 我们下载网络图片的时候&#xff0c;首先需要自己定义一个下载器&…

HTTP基本概念-HTTP缓存技术

大家好我是苏麟 , 今天说说HTTP缓存技术 . 资料来源 : 小林coding 小林官方网站 : 小林coding (xiaolincoding.com) HTTP缓存技术 HTTP 缓存有哪些实现方式? 对于一些具有重复性的 HTTP 请求&#xff0c;比如每次请求得到的数据都一样的&#xff0c;我们可以把这对「请求-响…

算法||实现典型数据结构的查找、添加和删除数据 并分析其时间和空间复杂度

实现典型数据结构的查找、添加和删除数据 并分析其时间和空间复杂度 线性结构&#xff1a; 数组&#xff1a;是一种线性表数据结构&#xff0c;它用一组连续的内存空间&#xff0c;来存储一组具有相同类型的数据。 查找数据 &#xff1a;随机访问 流程图 /** 查询元素下标…

Linux学习(三)shell编程

1.echo指令 用于将后面的字体内容回显到控制台&#xff0c;将后面的字体用单引号或双引号引起来都会忽略引号 2.expr数学运算 3.第一个shell脚本 一般shell脚本以.sh为后缀&#xff0c;通过sh命令来执行shell脚本。 4.shell脚本的命令行参数 $1 $2 $3 $4 $5 $6 $7 $8 $9 $0 &…

【DDD】学习笔记-值对象

值对象通常作为实体的属性而存在&#xff0c;也就是亚里士多德提到的数量、性质、关系、地点、时间与形态等范畴。正如 Eric Evans 所说&#xff1a;“当你只关心某个对象的属性时&#xff0c;该对象便可做为一个值对象。为其添加有意义的属性&#xff0c;并赋予它相应的行为。…

day42 一个极简动画效果(复习相关属性)

<!DOCTYPE html> <html><head><title>动画页面</title><style>body {font-family: Arial, sans-serif;background-color: #f2f2f2;margin: 0;padding: 0;}.container {max-width: 800px;margin: 0 auto;margin-top: 100px;padding: 20px;b…

HCIA-HarmonyOS设备开发认证V2.0-轻量系统内核基础-互斥锁mux

目录 一、互斥锁基本概念二、互斥锁运行机制三、互斥锁开发流程四、互斥锁使用说明五、互斥锁接口六、代码分析&#xff08;待续...&#xff09; 一、互斥锁基本概念 互斥锁又称互斥型信号量&#xff0c;是一种特殊的二值性信号量&#xff0c;用于实现对共享资源的独占式处理。…

17.3.1.2 曝光

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 基本算法&#xff1a;先定义一个阈值&#xff0c;通常取得是128 原图像&#xff1a;颜色值color&#xff08;R&#xff0c;G&#…

读十堂极简人工智能课笔记03_遗传算法与进化

1. 寻找正确答案 1.1. 卡尔西姆斯 1.1.1. 计算机图形艺术家和研究者 1.1.2. 演示过数字进化之创造性和新颖性的先驱 1.1.3. 1994年 1.1.3.1. 创造一批能游泳、走路、跳跃&#xff0c;甚至互相竞争的虚拟动物震惊了整个科学界 1.1.3.2. 它们的人工大脑却是个极其复杂的网络…