STM32的看门狗了解及代码演示

一、介绍:

STM32看门狗分为独立看门狗和窗口看门狗两种,其两者使用调条件如下所示,

IWDG和WWDG两者特点如下图所示:

独立看门狗的手册资料:

串口看门狗的手册资料:

                应当注意:在窗口看门狗中,当递减计数器在窗口外被重新装载,(若看门狗被启动)则产生复位

由于窗口看门狗使用的APB1的PCLK1,时钟最高36MHZ,和RCC_APB2Periph_GPIOx不同,APB1最大就是36MHZ,APB2最大就是72MHZ。

所以串口看门狗需要配置APB1时钟使能,如下语句。

可以从图1-3 窗口看门狗编程说明红看到TWWDG=TPCLK1 x 4096 x 2^WDGTB x (T[5:0]+1)  ; (ms)

WDGTB[1:0]: 时基 (Timer base),也就是设置WDGTB 的值是1/2/4还是8,这在配置寄存器(WWDG_CFR)寄存器的位8:7 中设置,

其预分频器的时基可以设置如下:

00: CK计时器时钟(PCLK1除以4096)除以1

01: CK计时器时钟(PCLK1除以4096)除以2

10: CK计时器时钟(PCLK1除以4096)除以4

11: CK计时器时钟(PCLK1除以4096)除以8

也可以直接用这个函数

1 WWDG_SetPrescaler(WWDG_Prescaler_8); //8预分频,则WWDG时钟频率=(PCK1(36M)/4096)/8=1099Hz(910us)

也可以直接用这个函数

其次是设置窗口值,用来与递减计数器进行比较用的窗口值。通过如下函数即可

1  WWDG_SetWindowValue(80);//设置窗口值为80则WWDG的计数值必须在64~80之间才能喂狗(64是0x40,当再次减1就会T6清零,从而导致复位了,即刷新窗口设置成了80-64,127-80也是不能更新值得否则也会复位)

应当注意:在窗口看门狗中,当递减计数器在窗口外被重新装载,(若看门狗被启动)则产生复位,也即是说在90-64外面使用这个重载函数,会有问题发生

最后我们设置 (T[5:0]+1)的值,这里我们设置最大127,代码如下,以后每次喂狗也可以用这个函数进行重载计数值(喂狗)。

1 WWDG_Enable(127)

因为这是会导致产生复位,所以重载的窗口一定要设置好。

总结就是我们使用串口看门狗应该先配置寄存器(WWDG_CFR),即配置窗口值是多少到x40(我们设置的80-0x40),这个配置会告诉单片机什么时候来与递减计数器进行值比较,如果值小于0x40就产生复位。

当然,如果你在减减计数值还在0x7E-0x50(127-80)之间就重载计数值(喂狗)同样会导致芯片复位。所以窗口的概念一定要理解好,在窗内才可以重载计数值(喂狗),这样才不会莫名被复位。

 二、代码实现

最终的初始化窗口看门狗的配置函数(WWDG)如下:

/*************************************************************
Function : WWDGReste_Init
Description: 窗口看门狗定时器
Input : none
return : none
*************************************************************/
void WWDGReste_Init(void)
{
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE);//WWDG连接在PCLK1(36M)的时钟线上

    WWDG_SetPrescaler(WWDG_Prescaler_8); //8预分频,则WWDG时钟频率=(PCK1(36M)/4096)/8=1099Hz(910us)
    WWDG_SetWindowValue(80);//设置窗口值为80则WWDG的计数值必须在64~80之间才能喂狗(64是0x40,当再次减1就会T6清零,从而导致复位了)
    //设置WWDG计数值为127,超时时间=910us*64=58.25ms,所以
    WWDG_Enable(127);//(0x7F为设置的最小值,0x40为最大的复位值,取值应该在0x40~0x7F之间)刷新窗口为:910us*(127-80)=42.77ms < 刷新窗口 < 910us*64=58.25ms
}

主函数如下:

void mian(void)
{
//初始化
    while(1)
    {
        delay_ms(400)
        WWDG_Enable(127);
      //无需判断直接等待窗口看门狗中断触发
    }
}  

或者这样的留参带使能中断形式:

#include "wdg.h"
#include "stm32f10x_wwdg.h"

static u8 WWDG_CNT=0x7f;     /*保存WWDG计数器的设置值,默认为最大127. */

//========================================================================================
/**
 * 初始化窗口看门狗
 * tr :T[6:0],计数器值
 * wr :W[6:0],窗口值
 * fprer:分频系数(WDGTB),仅最低2位有效
 * Fwwdg=PCLK1/(4096*2^fprer).
 // 计数器值为7f,窗口寄存器为5f,分频数为8
    WWDG_Init(0X7F,0X5F,WWDG_Prescaler_8);
 */
void WWDG_Init(u8 tr,u8 wr,u32 fprer)
{
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_WWDG, ENABLE);    /*WWDG时钟使能*/
    WWDG_SetPrescaler(fprer); /*设置IWDG预分频值*/
    WWDG_SetWindowValue(wr);    /*设置窗口值*/
    WWDG_CNT=tr&WWDG_CNT; /* 初始化WWDG_CNT. */
    WWDG_Enable(WWDG_CNT);    /*使能看门狗 ,    设置 counter . */
    WWDG_ClearFlag();    /*清除提前唤醒中断标志位*/
    WWDG_NVIC_Init();/* 初始化窗口看门狗 NVIC */
    WWDG_EnableIT(); /* 开启窗口看门狗中断 */
}

/**
 * 窗口看门狗中断服务程序
 */
void WWDG_NVIC_Init(void)
{
    NVIC_InitTypeDef NVIC_InitStructure;
    NVIC_InitStructure.NVIC_IRQChannel = WWDG_IRQn;    /*WWDG中断*/
    /* 抢占2,子优先级3 */
    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 2;
    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;
    NVIC_Init(&NVIC_InitStructure);/*    NVIC初始化*/
}

/**
 * 重设置WWDG计数器的值,喂狗
 */
void WWDG_Set_Counter(u8 cnt)
{
    WWDG_Enable(cnt); /*使能看门狗 ,    设置 counter .    */
}

/**
 * 看门狗中断服务程序
 */
void WWDG_IRQHandler(void)
{
    WWDG_Set_Counter(WWDG_CNT);
    WWDG_ClearFlag();    /*清除提前唤醒中断标志位*/
    LED1 = ~LED1;         /*LED状态翻转 */
}

void mian(void)
{
//初始化
    while(1)
    {

    }
}

附录:

独立看门狗(IWDG)的代码:

/**
 * 初始化独立看门狗
 * prer:分频数:0~7(只有低 3 位有效!)
 * 分频因子=4*2^prer.但最大值只能是 256!
 * rlr:重装载寄存器值:低 11 位有效.
 * 时间计算(大概):Tout=((4*2^prer)*rlr)/40 (ms).
 *IWDG_Init(4,625);//初始化独立看门狗,分频数为64,重装载值为625,溢出时间计算为:64*625/40=1000ms=1s
 */
void IWDG_Init(u8 prer,u16 rlr)
{
    IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable); /* 使能对寄存器IWDG_PR和IWDG_RLR的写操作*/
    IWDG_SetPrescaler(prer);    /*设置IWDG预分频值:设置IWDG预分频值*/
    IWDG_SetReload(rlr);     /*设置IWDG重装载值*/
    IWDG_ReloadCounter();    /*按照IWDG重装载寄存器的值重装载IWDG计数器*/
    IWDG_Enable();        /*使能IWDG*/
}

/**
 * 喂独立看门狗
 */
void IWDG_Feed(void)
{
    IWDG_ReloadCounter();    /*reload*/
}

/**
 *main函数
 */
void main(void)
{
  NVIC_Configuration();//优先级配置
  IWDG_Init(4,625);//初始化独立看门狗,分频数为64,重装载值为625,溢出时间计算为:64*625/40=1000ms=1s
 while(1)
  {
    delay_ms(500);//0.5秒喂一次狗
      IWDG_Feed();//喂狗
  }
}

原文地址:https://www.cnblogs.com/pertor/p/9483445.html

时间: 2024-10-07 22:34:41

STM32的看门狗了解及代码演示的相关文章

【转】STM32 独立看门狗简介

STM32 的独立看门狗由内部专门的 40Khz 低速时钟驱动,即使主时钟发生故障,它也仍然有效. 看门狗的原理:单片机系统在外界的干扰下会出现程序跑飞的现象导致出现死循环,看门狗电路就是为了避免这种情况的发生.看门狗的作用就是在一定时间内(通过定时计数器实现)没有接收喂狗信号(表示 MCU 已经挂了),便实现处理器的自动复位重启(发送复位信号) . 在键值寄存器(IWDG_KR)中写入 0xCCCC,开始启用独立看门狗:此时计数器开始从其复位值 0xFFF 递减计数.当计数器计数到末尾 0x0

stm32 独立看门狗IWDG

http://note.youdao.com/noteshare?id=7e77f1eab55fd08573e82e550e186ccf&sub=44D0C7BCB7094D4D92D5C71128CFA0F0 文章在有道云里. 原文地址:https://www.cnblogs.com/coversky/p/8452624.html

STM32的独立看门狗

STM32 内 部自带了 2 个看门狗:独立看门狗(IWDG)和窗口看门狗(WWDG) STM32 的独立看门狗由内部专门的 40Khz 低速时钟驱动,即使主时钟发生故障,它也仍然 有效.这里需要注意独立看门狗的时钟是一个内部 RC 时钟,所以并不是准确的 40Khz,而是 在 30~60Khz 之间的一个可变化的时钟,只是我们在估算的时候,以 40Khz 的频率来计算,看 门狗对时间的要求不是很精确,所以,时钟有些偏差,都是可以接受的. 首先我们得讲解一下看门狗的原理.这个百度百科里面有很详细

STM32的两只看门狗

STM32独立看门狗, 由专门的低速时钟(LSI)驱动,即便是主时钟发生故障它仍能够有效,所以此狗狗可以工作在与主时钟无关的要求下,或者待机模块下等,所以它叫独立看门狗,注意一旦开启此看门狗则只能由MCU复位后才清除,让它不再工作. 它的时钟是一个内部RC时钟,它会在30KHZ到60KHZ之间变化,并非是精确的40KHZ,而只是一般计算时取40KHZ. 独立看门狗需设置四个寄存器如下: 其中, 预分频寄存器(IWDG_PR),最低三位PR[2:0](Prescaler divider)有效,可设

STM32之独立看门狗(IWDG)与窗口看门狗(WWDG)总结

一.独立看门狗 STM32 的独立看门狗由内部专门的 40Khz 低速时钟驱动,即使主时钟发生故障,它也仍然有效. 看门狗的原理:单片机系统在外界的干扰下会出现程序跑飞的现象导致出现死循环,看门狗电路就是为了避免这种情况的发生.看门狗的作用就是在一定时间内(通过定时计数器实现)没有接收喂狗信号(表示 MCU 已经挂了),便实现处理器的自动复位重启(发送复位信号) . 在键值寄存器(IWDG_KR)中写入 0xCCCC,开始启用独立看门狗:此时计数器开始从其复位值 0xFFF 递减计数.当计数器计

一个软件实现的Linux看门狗—soft_wdt

soft_wdt(下面简称本软件)是一个软件实现的Linux看门狗. 本软件是一款开源.免费软件. 下载地址: https://github.com/sunmingbao/soft-wdt/archive/master.zip 本软件和/drivers/watchdog/softdog.c实现的软件看门狗差点儿一样. 基本的不同点是,前者支持一个看门狗.本软件则支持大量的看门狗. soft_wdt代码编译后.生成一个内核模块soft_wdt.ko. 模块载入后,将创建一个设备文件/dev/sof

独立看门狗

Stm32的看门狗有两个,一个是窗口看门狗,还有一个是独立看门狗.这里说的是独立看门狗: 一共有四个寄存器: KR:只写寄存器,写入0x55555555去除PR和PLR的写保护,写入0xAAAAAAAA喂狗,写入0xCCCCCCCC开启看门狗. PR:设置分频系数 PLR:计数器从这个寄存器的值递减,如果KR被写0xAAAAAAAA,这个值会被重新传送到计数器.和PR一起决定两次喂狗之间的间隔. SR:状态寄存器,我没用到... 其使用起来非常简单,使用代码如下: 初始化: 喂狗: 来自为知笔记

5、CC2541芯片中级教程-OSAL操作系统(PWM+看门狗)

本文根据一周CC2541笔记汇总得来—— 适合概览和知识快速索引—— 全部链接: 中级教程-OSAL操作系统\OSAL操作系统-实验01 OSAL初探 [插入]SourceInsight-工程建立方法 中级教程-OSAL操作系统(OSAL系统解基本套路) 中级教程-OSAL操作系统(进一步了解-OLED && 普通按键和5方向按键-中断!!!)这个系统驱动层和应用层不一样~ 中级教程-OSAL操作系统(ADC-光敏电阻) OSAL操作系统-实验16 串口波特率扩展 OSAL操作系统-实验1

STM32之------独立看门狗(IWDG)和窗体看门狗(WWDG)

一     前沿废语: 之前有很风靡的游戏,名字叫<看门狗>.该游戏用了很新的引擎技术,打造出了一个辽阔庞大的世界,内容是玩家Aiden·Pearce(主角)是一名精通黑客技术的高手,当时的世界是处于所有物品都被置了电子设备控制,整个城市都在依赖着他们,主人公决定利用自己的技术为这个世界惩奸除恶.   这个游戏以极高的自由度.出色的游戏质量与丰富的游戏内容被业界公认为开启次世代游戏的大门之作,该游戏被IGN评为年度最佳射击游戏(下载地址:http://down.ali213.net/pcgam