cortex_m3_stm32嵌入式学习笔记(五):独立看门狗实验(IWDG)

ARM 290浏览

单片机系统在外界的干扰下会出现程序跑飞的现象导致出现死循环,看门狗电路就是为了避免这种情况的发生。看门狗的作用就是在一定时间内(通过定时计数器实现)没有接收喂狗信号(表示
MCU 已经挂了),便实现处理器的自动复位重启(发送复位信号) 。

感觉是是自动复位功能,就是在一定时间内你应该去喂它而如果程序中途进入了死循环(就是喂不了了)这个MCU就挂了。。但如果没开IWDG ,你不知道它挂没挂(虽然个人认为也是可以手动按复位键的嘛。。)(上面那段话抄自某论坛)

IWDG初始化步骤:

1)取消寄存器写保护(向IWDG_KR写入
0X5555

2)设置独立看门狗的预分频系数和重装载值

3)重载计数值喂狗(向IWDG_KR
写入0XAAAA

4)启动看门狗(IWDG_KR
写入0XCCCC)
。。当然了 还是远离寄存器,库函数大法好

iwdg.c 


#include "iwdg.h"
#include "sys.h"
//初始化独立看门狗
//prer:分频数:0~7(只有低 3 位有效!)
//分频因子=4*2^prer.但最大值只能是 256!
//rlr:重装载寄存器值:低 11 位有效.
//时间计算(大概):Tout=((4*2^prer)*rlr)/40 (ms).
void IWDG_Init(u8 prer,u16 rlr)
{
    //使能对寄存器 IWDG_PR 和 IWDG_RLR 的写操作
	  IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);
	  IWDG_SetPrescaler(prer);//设置 IWDG 预分频值:设置 IWDG 预分频值为 64
	  IWDG_SetReload(rlr); //设置 IWDG 重装载值
    IWDG_ReloadCounter(); //按照 IWDG 重装载寄存器的值重装载 IWDG 计数器
    IWDG_Enable(); //使能 IWDG
}
void IWDG_Feed(void)//喂狗
{
	IWDG->KR=0XAAAA;
}

iwdg.h

#ifndef _IWDG_H
#define _IWDG_H
#include "sys.h"
void IWDG_Init(u8 prer,u16 rlr);
void IWDG_Feed(void);
#endif

主函数部分就是一堆初始化喽。。

#include "led.h"
#include "sys.h"
#include "delay.h"
#include "key.h"
#include "iwdg.h"
#include "usart.h"
void init()
{
	LED_Init();
	KEY_Init();
	delay_init();
	uart_init(9600);
	NVIC_Configuration();
	IWDG_Init(4,625);//溢出时间1s
}
int main(void)
{
	init();
	delay_ms(300);
	LED0=0;
	while(1)
	{
		if(KEY_Scan(0)==KEY0_PRES)IWDG_Feed();
		delay_ms(10);
	}
}

本实验最终效果是:如果你一直不停的按KEY0喂狗,就不会复位,否则就会复位,实际表现是一直按KEY0才能让LED一直亮,否则LED就会闪烁