窗口看门狗有一个提前唤醒中断,如果开启这个中断,那么当计数器的值达到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可以知道复位原因,以使系统有更高的稳定性。

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

05-02 06:50