STM32---IWDG笔记

STM32---IWDG独立看门狗的使用

STM32---IWDG独立看门狗的使用

独立看门狗(IWDG)由专用的40kHz的低速时钟驱动,
即使主时钟发生故障它也仍然有效。
窗口看门狗由从APB1时钟分频后得到的时钟驱动,
通过可配置的时间窗口来检测应用程序非正常的过迟或过早的操作。

IWDG最适合应用于那些需要看门狗作为一个在主程序之外,
能够完全独立工作,并且对时间精度要求较低的场合。

WWDG最适合那些要求看门狗在精确计时窗口起作用的应用程序。

IWDG主要性能
 ●自由运行的递减计数器
 ●时钟由独立的RC振荡器提供(可在停止和待机模式下工作)
 ●看门狗被激活后,则在计数器计数至0x000时产生复位

在键寄存器(IWDG_KR)中写入0xCCCC,开始启用独立看门狗;
此时计数器开始从其复位值0xFFF递减计数。
当计数器计数到末尾0x000时,会产生一个复位信号(IWDG_RESET)。
无论何时,只要键寄存器IWDG_KR中被写入0xAAAA,
IWDG_RLR中的值就会被重新加载到计数器中从而避免产生看门狗复位 。


如果用户在选择字节中启用了“硬件看门狗“功能,
在系统上电复位后,看门狗会自动开始运行;
如果在计数器计数结束前,若软件没有向键寄存器写入相应的值,
则系统会产生复位寄存器访问保护


IWDG_PR和IWDG_RLR寄存器具有写保护功能。
要修改这两个寄存器的值,必须先向IWDG_KR寄存器中写入0x5555。
以不同的值写入这个寄存器将会打乱操作顺序,寄存器将重新被保护。
重装载操作(即写入0xAAAA)也会启动写保护功能。
状态寄存器指示预分频值和递减计数器是否正在被更新。

 

//启动独立看门狗
 IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable); //访问之前要首先使能寄存器写

 IWDG_SetPrescaler(IWDG_Prescaler_64);//64分频 一个周期1.6ms
 IWDG_SetReload(800);//最长12位 [0,4096] 800*1.6=1.28S 
 /* Reload IWDG counter */
 IWDG_ReloadCounter();
 IWDG_Enable();// Enable IWDG (the LSI oscillator will be enabled by hardware)

因为独立看门狗使用的是LSI,所以最好程序启动的时候,使时钟源稳定:

/* LSI的启动*/
 RCC_LSICmd(ENABLE);//打开LSI
 while(RCC_GetFlagStatus(RCC_FLAG_LSIRDY)==RESET);//等待直到LSI稳定
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值