目录
HAL_WWDG_Refresh刷新WWDG计数器,防止看门狗复位。需在窗口期内调用。
HAL_WWDG_SetCounter直接设置计数器值,需确保值在窗口范围内(0x40~0x7F)。
回调函数HAL_WWDG_IRQHandler处理WWDG早期唤醒中断,调用回数。
HAL_WWDG_EarlyWakeupCallback用户实现的回调函数,用于处理早期唤醒事件(如保存数据)。
HAL_WWDG_GetState获取WWDG当前状态(如就绪、忙碌等)。
HAL_WWDG_GetError检查WWDG操作中的错误标志。
WWDG介绍
窗口看门狗用于监测单片机程序运行时效是否精准,主要检测软件异常,一般用于需要精准检测程序运行时间的场合。
窗口看门狗的本质是一个能产生 系统复位信号 和 提前唤醒中断 的 6 位计数器。
产生复位条件:
当递减计数器值从 0x40 减到 0x3F 时复位(即 T6 位跳变到 0 )
计数器的值 大于 W[6:0] 值 时喂狗会复位。
产生中断条件:
当 递减计数器等于 0x40 时可产生提前唤醒中断 (EWI)。
在窗口期内重装载计数器的值,防止复位,也就是所谓的喂狗。
工作原理


WWDG主要寄存器及功能
控制寄存器(WWDG_CR)
- 包含使能位(WDGA)和7位递减计数器(T[6:0])。
- 写入0x7F初始化计数器,使能后计数器从设定值递减,达到0x40时触发复位。
- 示例代码(STM32):
cWWDG->CR = WWDG_CR_WDGA | 0x7F; // 使能并设置初始值配置寄存器(WWDG_CFR)
- 设置窗口值(W[6:0])和预分频器(WDGTB)。
- 窗口机制:仅当计数器值在窗口值(W[6:0])和0x3F之间时允许刷新,否则触发复位。
- 示例配置:
cWWDG->CFR = WWDG_CFR_WDGTB_1 | 0x5F; // 预分频4,窗口值0x5F状态寄存器(WWDG_SR)
- 仅含提前唤醒中断标志位(EWIF)。
- 当计数器减至0x40时置位,需软件清零。
wwdg库函数概述
WWDG(Window Watchdog,窗口看门狗)是STM32微控制器中的一种硬件看门狗,用于监测软件运行状态。通过库函数可以配置WWDG的超时窗口、计数器值等参数。以下是常用WWDG库函数及其功能说明。
相关库函数
初始化与配置函数
HAL_WWDG_Init
初始化WWDG,配置预分频器、窗口值、计数器值及是否启用早期唤醒中断。
参数:
hwwdg:WWDG句柄指针WWDG_InitTypeDef:包含预分频器、窗口值等配置的结构体HAL_WWDG_MspInit
用户实现的底层初始化函数,用于配置NVIC、时钟等硬件相关设置。
计数器操作函数
HAL_WWDG_Refresh
刷新WWDG计数器,防止看门狗复位。需在窗口期内调用。
HAL_WWDG_SetCounter
直接设置计数器值,需确保值在窗口范围内(0x40~0x7F)。
中断处理函数
HAL_WWDG_IRQHandler
处理WWDG早期唤醒中断,调用回数。
HAL_WWDG_EarlyWakeupCallback
用户实现的回调函数,用于处理早期唤醒事件(如保存数据)。
状态与错误处理
HAL_WWDG_GetState
获取WWDG当前状态(如就绪、忙碌等)。
HAL_WWDG_GetError
检查WWDG操作中的错误标志。
使用示例
c
WWDG_HandleTypeDef hwwdg;
hwwdg.Instance = WWDG;
hwwdg.Init.Prescaler = WWDG_PRESCALER_8;
hwwdg.Init.Window = 0x5F;
hwwdg.Init.Counter = 0x7F;
hwwdg.Init.EWIMode = WWDG_EWI_ENABLE;
HAL_WWDG_Init(&hwwdg);
// 主循环中定期刷新计数器
while (1) {
HAL_WWDG_Refresh(&hwwdg);
}
注意事项
- 计数器必须在窗口期内刷新,过早或过晚均会触发复位。
- 窗口值需大于0x40且小于计数器初始值。
- 早期唤醒中断可用于紧急处理,但需快速完成操作。
WWIG溢出时间计算

WWIG配置步骤
