stm32 独立看门狗学习

STM32F10xxx内置两个看门狗,提供了更高的安全性、时间的精确性和使用的灵活性。两个看门狗设备(独立看门狗和窗口看门狗)可用来检测和解决由软件错误引起的故障。

独立看门狗(IWDG)由专用的低速时钟(LSI)驱动,即使主时钟发生故障它也仍然有效。IWDG最适合应用于那些需要看门狗作为一个在主程序之外,能够完全独立工作,并且对时间精度要求较低的场合。

我们的实验这样设计,主函数开始的时候,向串口输出“Hello World”,然后启动看门口(溢出时间设定为3秒钟)。在按下按键的时候喂狗,同时串口打印“喂狗”。

预期结果:如果不按按键,则约每三秒重启一次,现象是串口隔三秒就会打印“Hello World”;如果在启动后的3秒内按键,则显示“喂狗”,再在3秒内按键……这样保证不重启。

看一下代码吧。

独立看门狗的初始化:

void IWDG_Init(u8 prer,u16 rlr) 
{	
 	IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);  //使能对寄存器 IWDG_PR 和 IWDG_RLR的写操作
	IWDG_SetPrescaler(prer);  //设置预分频值
	
	IWDG_SetReload(rlr);  //设置重装载值
	
	IWDG_ReloadCounter();  //按照重装载值装载IWDG计数器
	
	IWDG_Enable();  //看门狗使能
}
这个函数有两个参数:prer 和 rlr

stm32 独立看门狗学习_第1张图片
PRER 就是表格中的PR[2:0],取值范围是0-7;

RLR就是表格中的RL[11:0],取值范围是0x000-0xFFF;

注意:这里的时间是粗略计算的,不是那么准确。

溢出时间 = 2^PR*(RL+1)/10  

单位:ms 

如果我们定时3秒钟,那么应该是:

IWDG_Init(4,1874);  // 2^4 * (1874+1) / 10 (ms)= 16*1875/10 (ms)= 3000(ms) = 3s

主函数代码:

int main(void)
{	
	delay_init();	     //延时函数初始化  
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);	
	uart_init(9600);	 //串口初始化
	
	printf("Hello World ! \r\n");
 	
	IWDG_Init(4,1874);    // 看门狗初始化并使能
	
	key_init();   //按键IO初始化
	EXTIX_Init(); // 按键中断初始化
	
	while(1)
	{
		
		;
		
	}
}

喂狗的操作是:

void IWDG_Feed(void)
{   
 	IWDG_ReloadCounter();//reload										   
}

我们在按键中断处理中喂狗:

void EXTI0_IRQHandler(void)
{
	delay_ms(10);    //消除抖动
	if(KEY3==1)	 	 //WK_UP
	{				 
		printf("喂狗......\r\n");
		IWDG_Feed();
	}
	EXTI_ClearITPendingBit(EXTI_Line0); //清除中断标志位
}

实验结果如图。

如果不喂狗,那么大约3秒钟就会重启。

stm32 独立看门狗学习_第2张图片

如果喂狗,效果如下。

stm32 独立看门狗学习_第3张图片



转载于:https://www.cnblogs.com/longintchar/p/5224426.html

你可能感兴趣的:(stm32 独立看门狗学习)