stm32 窗口看门狗学习(二)

窗口看门狗有一个提前唤醒中断,如果开启这个中断,那么当计数器的值达到0x40的时候就会产生这个中断。

上次的代码加一点就可以做这个实验了。

void WWDG_Init(u8 tr,u8 wr,u32 fprer)
{ 
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE);  //   WWDG时钟使能
	
	WWDG_SetPrescaler(fprer);//设置预分频系数

	WWDG_SetWindowValue(wr);//设置窗口上限

	WWDG_Enable(tr);	 //设置计数器初值并且使能看门狗    

	WWDG_ClearFlag(); //清除提前唤醒中断标志

	WWDG_NVIC_Init(); //看门狗NVIC初始化

	WWDG_EnableIT();  //开启窗口看门狗中断	

} 
最后三行是新加的。


void WWDG_NVIC_Init(void)
{
	NVIC_InitTypeDef NVIC_InitStructure;
	NVIC_InitStructure.NVIC_IRQChannel = WWDG_IRQn;    //WWDG中断
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;   
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;	 	
    NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE; 
	NVIC_Init(&NVIC_InitStructure);
}

void WWDG_IRQHandler(void)
{

	WWDG_SetCounter(0x7f);	//在这里也可以喂狗,但是有的网友不建议这么做

	WWDG_ClearFlag();	    //清除提前唤醒中断标志

}

为什么会设计这样的中断呢?

我认为这样设计是为MCU复位之前留下一点时间,能够让程序员根据需要在复位之前保存一些重要的数据,这样在复位后MCU可以知道复位原因,以使系统有更高的稳定性。

有的网友说“在窗口看门狗中断函数中喂狗没有什么意义,程序本来已经不按正常运行了,还在中断函数中喂狗防止复位只会错上加错。”



posted @ 2015-01-28 12:06  漂泊的指针  阅读(631)  评论(0编辑  收藏  举报