18_独立开门狗试验
目录
独立看门狗概述
独立看门狗功能描述
IWDG独立看门狗操作库函数
独立看门狗操作步骤
实验源码:
实验结果:
独立看门狗概述
在由单片机构成的微型计算机系统中,由于单片机的工作常常会受到来自外界电磁场的干扰,造成程序的跑飞,而陷入死循环,程序的正常运行被打断,由单片机控制的系统无法继续工作,会造成整个系统的陷入停滞状态,发生不可预料的后果,所以出于对单片机运行状态进行实时检测的考虑,便产生了一种专门用于检测单片机程序运行的模块或者芯片,欲称”看门狗”(watchdog)。
看门狗解决的问题是在启动正常运行的时候,系统不能复位。在系统跑飞(程序异常执行)的情况下,系统复位,程序重新执行。
STM32内置两个看门狗,提供了更高的安全性,时间的精确性和使用的灵活性。两个看门狗设备(独立看门狗/窗口看门狗)可以用来检测和解决由软件错误引起的故障。当计数器到给定的超时值时,触发一个中断(仅适合窗口看门狗)或者产生系统复位。
独立看门狗(IWDG)由专用的低速时钟(LSI)驱动,即使主时钟发生故障它任有效,独立看门狗适合应用于需要看门狗作为一个主程序之外能够完全独立工作,并且对时间精度要求低的场合。
窗口看门狗由从APB1时钟分频后得到时钟驱动。通过可配置的时间窗口来检测应用程序非正常的过迟或过早操作。
窗口看门狗最适合那些要求看门狗在精确计时窗口起作用的程序。
独立看门狗功能描述
在键值寄存器(IWDG_KR)中写入0xcccc开始启用独立看门此时计数器开始从其复位值0xFFF递减,当计数器值计数到0x000时会产生一个复位信号(IWDG_RESET)。
无论何时,只要键值寄存器IWDG_KR中写入0xAAAA(通常说的喂狗),自动重装载寄存器IWDG_RLR的值就会重新加载到计数器,从而避免看门狗复位。
如果程序异常,就无法正常喂狗,从而系统复位。
键值寄存器IWDG_KR:0~15位有效
预分频寄存器IWDF_PR:0~2位有效 具有写保护功能,要操作先取消写保护
重装载寄存器IWDG_RLR:0~11位有效 具有写保护功能,要操作先取消写保护
状态寄存器IWDG_SR:0~1位有效
解除写保护写0x5555到KR寄存器
IWDG独立看门狗操作库函数
void IWDG_WriteAccessCmd(uint16_t IWDG_WriteAccess);//取消写保护,0X5555使能void IWDG_SetPrescaler(uint8_t IWDG_Prescaler)//设置预分频系数:写PRvoid IWDG_SetReload(uint16_t Reload)//设置重装载值:写RLRvoid IWDG_ReloadCounter(void)//喂狗:写0XAAAA到KRvoid IWDG_Enable(void)//使能看门狗:写0xCCCC到KRFlagStatus IWDG_GetFlagStatus(uint16_t IWDG_FLAG)//状态:重装载/预分频更新
独立看门狗操作步骤
1.取消寄存器写保护
IWDG_WriteAccessCmd();
2.设置独立看门狗的预分频系数,确定时钟
IWDG_SetPrescaler();
3.设置看门狗重装载值,确定溢出时间
IWDG_SetReload();
4.使能看门狗
IWDG_Enable();
5.应用程序喂狗
IWDG_ReloadCounter();
实验源码:
实验介绍在外部中断在中喂狗,程序加打印1s没有喂狗会复位。
/*!\brief RCC配置\param[in] none\param[out] none\retval none
*/
void Rcc_config(void)
{ /*使能GPIOA时钟*/RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);/*使能GPIOE时钟*/RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOE,ENABLE);/*使能复用外设时钟*/RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);/*使能UART1时钟*/RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);}/*!\brief GPIO初始化函数\param[in] none\param[out] none\retval none
*/
void Gpio_Init(void)
{ /*GPIO结构体*/GPIO_InitTypeDef GPIO_InitTypeDefstruct;/*KEY2结构体配置*/GPIO_InitTypeDefstruct.GPIO_Mode = GPIO_Mode_IPU; //上拉输入 没按下默认是高电平GPIO_InitTypeDefstruct.GPIO_Pin = GPIO_Pin_4; //引脚选择/*初始化GPIOE Pin2 3 4*/ GPIO_Init(GPIOE,&GPIO_InitTypeDefstruct); /*UART1发送引脚配置*/GPIO_InitTypeDefstruct.GPIO_Mode = GPIO_Mode_AF_PP;//推挽复用输出GPIO_InitTypeDefstruct.GPIO_Pin = GPIO_Pin_9;GPIO_InitTypeDefstruct.GPIO_Speed = GPIO_Speed_10MHz;/*写入结构体到GPIOA*/GPIO_Init(GPIOA,&GPIO_InitTypeDefstruct);/*UART1接收引脚配置*/GPIO_InitTypeDefstruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空输入GPIO_InitTypeDefstruct.GPIO_Pin = GPIO_Pin_10;GPIO_InitTypeDefstruct.GPIO_Speed = GPIO_Speed_10MHz;/*写入结构体到GPIOA*/ GPIO_Init(GPIOA,&GPIO_InitTypeDefstruct);}/*!\brief UART1初始化\param[in] none\param[out] none\retval none
*/void Uart1_Init(u32 bound)
{/*UART结构体*/USART_InitTypeDef USART_InitTypeDefstruct;/*NVIC结构体*/NVIC_InitTypeDef NVIC_InitTypeDefstruct;/*UART结构体配置*/USART_InitTypeDefstruct.USART_BaudRate = bound; //波特率USART_InitTypeDefstruct.USART_HardwareFlowControl =USART_HardwareFlowControl_None; //不使用硬件流USART_InitTypeDefstruct.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;//发送接收使能USART_InitTypeDefstruct.USART_Parity = USART_Parity_No; //不使用奇偶校验USART_InitTypeDefstruct.USART_StopBits = USART_StopBits_1; //1个停止位USART_InitTypeDefstruct.USART_WordLength = USART_WordLength_8b; //8个数据位/*写入USART1*/USART_Init(USART1,&USART_InitTypeDefstruct);/*使能串口1*/USART_Cmd(USART1,ENABLE);/*中断配置*/USART_ITConfig(USART1, USART_IT_RXNE, ENABLE); //UART1接收缓冲区非空中断,接收中断NVIC_InitTypeDefstruct.NVIC_IRQChannel= USART1_IRQn; //USART1中断通道NVIC_InitTypeDefstruct.NVIC_IRQChannelCmd = ENABLE; //使能USART1中断NVIC_InitTypeDefstruct.NVIC_IRQChannelPreemptionPriority = 2; //抢占优先级NVIC_InitTypeDefstruct.NVIC_IRQChannelSubPriority = 1;//子优先级/*写入NVIC中*/NVIC_Init(&NVIC_InitTypeDefstruct);
}/*!\brief UART1中断服务函数\param[in] none\param[out] none\retval none
*/void USART1_IRQHandler(void)
{uint8_t Receive;/*接收数据*/Receive = USART_ReceiveData(USART1);printf("UART1中断,值为:%x\r\n",Receive);}/*!\brief EXTI初始化\param[in] none\param[out] none\retval none
*/
void EXTIX_Init(void)
{ /*EXTI结构体*/EXTI_InitTypeDef EXTI_InitStuct;/*NVIC结构体*/NVIC_InitTypeDef NVIC_InitTypeDefstruct;/*映射IO口到EXTI线上*/GPIO_EXTILineConfig(GPIO_PortSourceGPIOE,GPIO_PinSource4);/*触发方式设置*/EXTI_InitStuct.EXTI_Line = EXTI_Line4;//EXTI4EXTI_InitStuct.EXTI_LineCmd = ENABLE; //使能EXTI_InitStuct.EXTI_Mode = EXTI_Mode_Interrupt; //中断模式EXTI_InitStuct.EXTI_Trigger = EXTI_Trigger_Falling; //下降验触发 按键按下是低电平/*触发方式写入*/EXTI_Init(&EXTI_InitStuct);/*中断配置*/NVIC_InitTypeDefstruct.NVIC_IRQChannel= EXTI4_IRQn; //EXTI4中断通道NVIC_InitTypeDefstruct.NVIC_IRQChannelCmd = ENABLE; //使能EXTI4中断NVIC_InitTypeDefstruct.NVIC_IRQChannelPreemptionPriority = 1; //抢占优先级NVIC_InitTypeDefstruct.NVIC_IRQChannelSubPriority = 1;//子优先级/*写入NVIC中*/NVIC_Init(&NVIC_InitTypeDefstruct);}/*!
\brief EXTI4中断服务函数\param[in] none\param[out] none\retval none
*/void EXTI4_IRQHandler(void)
{/*消抖处理*/delay_ms(10);/*读取GPIOE.4电平低是按下*/if(GPIO_ReadInputDataBit(GPIOE,GPIO_Pin_4) == 0){/*喂狗*/IWDG_ReloadCounter();/*提示语句*/printf("喂狗成功\r\n");}/*清除EXTI4中断标志位*/EXTI_ClearITPendingBit(EXTI_Line4);
}/*!\brief 看门狗初始化函数\param[in] prer 预分频系数\param[in] rlr 重装载值 \param[out] none\retval none
*/
void IWDG_Init(uint8_t prer, uint16_t rlr)
{ /*取消写保护写入0x5555*/IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);/*写入预分频系数*/ IWDG_SetPrescaler(prer);/*写入重装载值*/IWDG_SetReload(rlr);/*加载数值到计数器里使能后直接从加载值开始计时*/IWDG_ReloadCounter();/*使能看门狗*/IWDG_Enable();
}/* Typedef 类型----------------------------------------------------------------*/
/* Define 定义----------------------------------------------------------------*/
/* Macro 宏------------------------------------------------------------------*/
/* Variables 变量--------------------------------------------------------------*/
/* Constants 常量--------------------------------------------------------------*/
/* Function 函数--------------------------------------------------------------*/int main(void){ /*延时函数初始化*/delay_init(); /*配置系统中断分组为2位抢占2位响应*/NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);/*Rcc初始化*/ Rcc_config();/*GPIO初始化*/Gpio_Init();/*UART1初始化*/Uart1_Init(9600);/*EXTI初始化*/EXTIX_Init();/*初始化独立看门狗*/IWDG_Init(4, 625); //1000ms=((4*2^prer)*rlr)/40/*提示语句*/printf("程序复位******************\r\n");/*死循环*/ while(1){printf("程序运行\r\n"); delay_ms(100);}}
实验结果:
在没有按下按键的时候一直1s复位
按键按下成功喂狗程序一直跑while里面程序
18_独立开门狗试验相关推荐
- 独立看门狗和窗口看门狗
为什么要开门狗? 在由单片机构成的微型计算机系统中,由于单片机的工作常常会受到来自外界电磁场的干扰,造成程序的跑飞,而陷入死循环,程序的正常运行被打断,由单片机控制的系统无法继续工作,会造成整个系统的 ...
- 看门狗(独立看门狗)与窗口看门狗的区别!
看门狗(独立看门狗)与窗口看门狗的区别 在cortex-M系列芯片上有两个看门狗:看门狗(独立看门狗)和窗口看门狗. 1.相同点 都是为了保证CPU程序跑飞 2.独立看门狗 根据内部看门狗时钟频率,装 ...
- stm32 独立看门狗和窗口看门狗区别
原文地址https://www.cnblogs.com/pertor/p/9483445.html 一.使用调条件 二.特点对比 三.手册介绍 [注]图中的WDGTB为3表示2^3=8,表示8分频,最 ...
- FreeRTOS实验_独立看门狗监视多线程
1.首先随意创建几个线程,如下图: 2.然后就要思考了,怎么样实现如果其中一个线程死掉了,就不喂狗得以让系统重启? 其实,我们可以反过来想一下,什么情况下才喂狗得以让系统正常运行?答案是,所有线程都活 ...
- STM32F103V IWDG 独立看门狗操作
最近编写一个程序,因为需要考虑到可靠性,所以需要在程序了添加看门狗功能.查了下STM32的相关资料,于是利用下库文件来实现IWDG独立看门狗操作.首先需要调用库文件 #include "st ...
- stm32看门狗_「正点原子NANO STM32开发板资料连载」第十一章 独立看门狗实验
1)实验平台:ALIENTEK NANO STM32F411 V1开发板2)摘自<正点原子STM32F4 开发指南(HAL 库版>关注官方微信号公众号,获取更多资料:正点原子 第十一章 独 ...
- proteus里面没有stm32怎么办_学习STM32日志——独立看门狗实验(20.06.23)
继续更新学习STM32的历程,今天学习看门狗. 在单片机构成的微型计算机系统中,单片机的工作时常收到外界电磁场的干扰,导致程序跑飞,陷入死循环.为了解决这个问题,产生了一种用于监测单片机程序运行状态的 ...
- stm32 独立看门狗学习
STM32F10xxx内置两个看门狗,提供了更高的安全性.时间的精确性和使用的灵活性.两个看门狗设备(独立看门狗和窗口看门狗)可用来检测和解决由软件错误引起的故障. 独立看门狗(IWDG)由专用的低速 ...
- STM32F4 HAL库开发 -- 独立看门狗(IWDG)
之前讲过看门狗,参看:STM32开发 – 看门狗详解 一.HAL库配置独立看门狗步骤 1.取消寄存器写保护,设置看门狗预分频系数和重装载值. 首先我们必须取消 IWDG_PR和 IWDG_RLR寄存器 ...
最新文章
- 我的第一份工作是个小公司
- SAP PM 初级系列15 - IW33事务代码界面里查看维修工单对应的维修通知单的几个方法
- Android 自定义viewpager 三张图片在同一屏幕轮播的效果
- nodefs模块的使用demo
- php获取微信uninoid_微信小程序获取openid和unionid方法
- C#不登录电脑启动程序
- Flask开发服务器
- 别人推荐的一首好听的歌
- 编码Ascii;unicode; utf-8;utf-16;utf-32;gb2312;gbk
- Iptables 网络安全
- Jquery(十)jqueryUI常用功能实战
- mac java报内存不足_苹果电脑显示内存不足怎么办_mac提示内存不足的解决方法-系统城...
- 少儿编程软件Scratch下载(Mac、Windows皆可)
- 编译Android系统源码和内核源码
- 从视频中提取光流 UCF-101
- 计算机课word反思,教学反思Word文档
- starrocker关联hive外表
- 二叉树的遍历(前序遍历,中序遍历,后序遍历)
- EZ-CUBE调试设置
- Linux快捷键及服务命令