历史上的今天
返回首页

历史上的今天

今天是:2024年09月05日(星期四)

正在发生

2018年09月05日 | STM32的IWDG(独立看门狗)详细用法

2018-09-05 来源:eefocus

1、IWDG简介:

  STM32 有两个看门狗,一个是独立看门狗另外一个是窗口看门狗,独立看门狗号称宠物狗,窗口看门狗号称警犬,本章我们主要分析独立看门狗的功能框图和它的应用。独立看门狗用通俗一点的话来解释就是一个 12 位的递减计数器,当计数器的值从某个值一直减到 0 的时候,系统就会产生一个复位信号,即 IWDG_RESET。如果在计数没减到 0 之前,刷新了计数器的值的话,那么就不会产生复位信号,这个动作就是我们经常说的喂狗。看门狗功能由 VDD 电压域供电,在停止模式和待机模式下仍能工作。  

2 、IWDG功能框图剖析

 ①独立看门狗时钟  


  独立看门狗的时钟由独立的 RC振荡器 LSI提供,即使主时钟发生故障它仍然有效,非常独立。LSI的频率一般在 30~60KHZ之间,根据温度和工作场合会有一定的漂移,我们一般取 40KHZ,所以独立看门狗的定时时间并一定非常精确,只适用于对时间精度要求比较低的场合。


②计数器时钟  


  递减计数器的时钟由 LSI经过一个 8位的预分频器得到,我们可以操作预分频器寄存器 IWDG_PR 来设置分频因子,分频因子可以是:[4,8,16,32,64,128,256,256],计数器时钟CK_CNT= 40/ 4*2^PRV,一个计数器时钟计数器就减一。


③计数器


  独立看门狗的计数器是一个 12 位的递减计数器,最大值为 0XFFF,当计数器减到 0时,会产生一个复位信号:IWDG_RESET,让程序重新启动运行,如果在计数器减到 0 之前刷新了计数器的值的话,就不会产生复位信号,重新刷新计数器值的这个动作我们俗称喂狗。


④重装载寄存器


  重装载寄存器是一个 12 位的寄存器,里面装着要刷新到计数器的值,这个值的大小决定着独立看门狗的溢出时间。超时时间 Tout = (4*2^prv) / 40 * rlv (s) ,prv是预分频器寄存器的值,rlv是重装载寄存器的值。

⑤键值寄存器


  键值寄存器 IWDG_KR 可以说是独立看门狗的一个控制寄存器,主要有三种控制方式,往这个寄存器写入下面三个不同的值有不同的效果。

通过写往键寄存器写 0XCCC 来启动看门狗是属于软件启动的方式,一旦独立看门狗启动,它就关不掉,只有复位才能关掉。


⑥状态寄存器


  状态寄存器 SR只有位 0:PVU和位 1:RVU有效,这两位只能由硬件操作,软件操作不了。RVU:看门狗计数器重装载值更新,硬件置 1 表示重装载值的更新正在进行中,更新完毕之后由硬件清 0。PVU: 看门狗预分频值更新,硬件置’1’指示预分频值的更新正在进行中,当更新完成后,由硬件清 0。所以只有当 RVU/PVU等于 0 的时候才可以更新重装载寄存器/预分频寄存器。


3、 怎么用 IWDG


  独立看门狗一般用来检测和解决由程序引起的故障,比如一个程序正常运行的时间是50ms,在运行完这个段程序之后紧接着进行喂狗,我们设置独立看门狗的定时溢出时间为60ms,比我们需要监控的程序 50ms 多一点,如果超过 60ms 还没有喂狗,那就说明我们监控的程序出故障了,跑飞了,那么就会产生系统复位,让程序重新运行。

4 、IWDG超时实验


硬件设计:



1-IWDG,属于内部资源,无需外部硬件

2-KEY 一个

3-LED 两个,用开发板自带的RGB灯即可


实验设计


配置IWDG的超时时间为1S,如果在1S之内没有及时喂狗的话,产生系统复位,并用LED灯的状态变化来指示。


编程要点


1-如何配置IWDG的超时时间?

2-如果编写喂狗函数?

3-在main函数里面的什么地方喂狗比较合适?


 配置IWDG的超时时间。



/*

 * 设置 IWDG 的超时时间

 * Tout = prv/40 * rlv (s)

 *      prv可以是[4,8,16,32,64,128,256]

 * prv:预分频器值,取值如下:

 *     @arg IWDG_Prescaler_4: IWDG prescaler set to 4

 *     @arg IWDG_Prescaler_8: IWDG prescaler set to 8

 *     @arg IWDG_Prescaler_16: IWDG prescaler set to 16

 *     @arg IWDG_Prescaler_32: IWDG prescaler set to 32

 *     @arg IWDG_Prescaler_64: IWDG prescaler set to 64

 *     @arg IWDG_Prescaler_128: IWDG prescaler set to 128

 *     @arg IWDG_Prescaler_256: IWDG prescaler set to 256

 *

 *        独立看门狗使用LSI作为时钟。

 *        LSI 的频率一般在 30~60KHZ 之间,根据温度和工作场合会有一定的漂移,我

 *        们一般取 40KHZ,所以独立看门狗的定时时间并一定非常精确,只适用于对时间精度

 *        要求比较低的场合。

 *

 * rlv:重装载寄存器的值,取值范围为:0-0XFFF

 * 函数调用举例:

 * IWDG_Config(IWDG_Prescaler_64 ,625);  // IWDG 1s 超时溢出 

 *                        (64/40)*625 = 1s

 */


void IWDG_Config(uint8_t prv ,uint16_t rlv)

{    

    // 使能 预分频寄存器PR和重装载寄存器RLR可写

    IWDG_WriteAccessCmd( IWDG_WriteAccess_Enable );

    

    // 设置预分频器值

    IWDG_SetPrescaler( prv );

    

    // 设置重装载寄存器值

    IWDG_SetReload( rlv );

    

    // 把重装载寄存器的值放到计数器中

    IWDG_ReloadCounter();

    

    // 使能 IWDG

    IWDG_Enable();    

}

喂狗函数:


// 喂狗

void IWDG_Feed(void)

{

    // 把重装载寄存器的值放到计数器中,喂狗,防止IWDG复位

    // 当计数器的值减到0的时候会产生系统复位

    IWDG_ReloadCounter();

}


  

#include "stm32f4xx.h"

#include "./led/bsp_led.h"

#include "./key/bsp_key.h" 

#include "./iwdg/bsp_iwdg.h"



static void Delay(__IO u32 nCount); 



int main(void)

{

    /* LED 端口初始化 */

    LED_GPIO_Config();     

    

    Delay(0X8FFFFF);    


    /* 检查是否为独立看门狗复位 */

  if (RCC_GetFlagStatus(RCC_FLAG_IWDGRST) != RESET)

  {

    /* 独立看门狗复位 */

    /*  亮红灯 */

    LED_RED;


    /* 清除标志 */

    RCC_ClearFlag();

        

        /*如果一直不喂狗,会一直复位,加上前面的延时,会看到红灯闪烁

        在1s 时间内喂狗的话,则会持续亮绿灯*/

  }

  else

  {

    /*不是独立看门狗复位(可能为上电复位或者手动按键复位之类的) */

    /* 亮蓝灯 */

    LED_BLUE;

  }        

  

  /*初始化按键*/

  Key_GPIO_Config();    

    

    // IWDG 1s 超时溢出

    IWDG_Config(IWDG_Prescaler_64 ,625); 

 

    //while部分是我们在项目中具体需要写的代码,这部分的程序可以用独立看门狗来监控

  //如果我们知道这部分代码的执行时间,比如是500ms,那么我们可以设置独立看门狗的

    //溢出时间是600ms,比500ms多一点,如果要被监控的程序没有跑飞正常执行的话,那么

    //执行完毕之后就会执行喂狗的程序,如果程序跑飞了那程序就会超时,到达不了喂狗的

    //程序,此时就会产生系统复位。但是也不排除程序跑飞了又跑回来了,刚好喂狗了,

    //歪打正着。所以要想更精确的监控程序,可以使用窗口看门狗,窗口看门狗规定必须

    //在规定的窗口时间内喂狗。

    while(1)                            

    {       

        if( Key_Scan(KEY1_GPIO_PORT,KEY1_PIN) == KEY_ON  )

        {

            // 喂狗,如果不喂狗,系统则会复位,复位后亮红灯,如果在1s

            // 时间内准时喂狗的话,则会亮绿灯

            IWDG_Feed();        

            //喂狗后亮绿灯

            LED_GREEN;

        }

    }

}


static void Delay(__IO uint32_t nCount)     //简单的延时函数

{

    for(; nCount != 0; nCount--);

}


/*********************************************END OF FILE**********************/


程序先检查是否为独立看门狗复位,如果是独立看门狗复位亮红灯。如果一直不喂狗,会一直复位,加上前面的延时,会看到红灯闪烁,在1S时间内喂狗的话,则会持续亮绿灯。 


推荐阅读

史海拾趣

Anadigm公司的发展小趣事

Anadigm是一家曾经存在的半导体公司,专注于可编程模拟信号处理器(PASP)技术。以下是Anadigm公司发展的相关故事:

  1. 公司成立与初期发展:Anadigm公司成立于1997年,总部位于美国加利福尼亚州圣塔莫尼卡市。公司的创始人致力于开发一种新型的可编程模拟信号处理器(PASP),以应对传统模拟电路设计的局限性。通过引入数字技术,Anadigm旨在提供更灵活、高性能的模拟信号处理解决方案。

  2. PASP技术的推出与市场应用:Anadigm公司于2000年推出了其首款可编程模拟信号处理器产品系列。这些器件具有灵活的可编程性和高度集成的特点,能够适应多种应用场景,包括电力管理、医疗设备、汽车电子和工业控制等领域。Anadigm的PASP技术受到了行业的关注,并在市场上取得了一定的成功。

  3. 技术创新与产品优化:Anadigm公司不断投入研发,致力于改进其PASP技术并推出更先进的产品。公司持续与客户合作,了解市场需求并进行技术创新,以满足不断变化的行业需求。Anadigm的产品不断优化,性能不断提升,赢得了客户的信赖和市场份额的扩大。

  4. 合并与收购:尽管Anadigm公司在PASP技术方面取得了一定的成就,但面临着激烈的市场竞争和资金压力。在公司运营一段时间后,Anadigm于2008年被美国半导体公司Exar Corporation收购。此次收购使得Anadigm成为Exar的全资子公司,继续在模拟信号处理领域发展。

  5. 最终终止业务:然而,随着时间的推移,Anadigm在市场上的地位逐渐下滑,未能在激烈的竞争中保持竞争优势。最终,Exar Corporation于2014年宣布终止Anadigm的业务,并关闭其产品线。这标志着Anadigm作为一个独立的实体在半导体行业的终结。

以上是Anadigm公司发展的一些主要故事,展示了该公司从创立到终止业务的发展历程。

Hewlett Packard Co公司的发展小趣事
类似地,高音控制电位器(如RP5)用于调节高音成分的衰减量。顺时针旋转电位器通常会增加高音输出,逆时针旋转则会减少。
Free2Move公司的发展小趣事
负反馈的引入有助于减小电路的失真,提高音质表现。
AiT Semiconductor Inc公司的发展小趣事

随着技术的不断成熟和产品的不断完善,AiT公司开始积极拓展市场。他们通过参加国际电子展会、与国内外知名企业建立合作关系等方式,不断提升品牌知名度和市场份额。同时,公司还针对不同行业和领域的需求,推出了定制化的半导体解决方案,进一步扩大了应用范围。这一系列的举措使得AiT公司在市场中实现了跨越式发展。

Endicott Research Group Inc (ERG)公司的发展小趣事

自1979年起,Endicott Research Group(ERG)就开始涉足电源转换产品的制造领域。在初创时期,公司面临着资金紧张和技术挑战,但团队坚持创新,专注于为LCD背光供电的LED驱动器及相关电源设备的研发。通过不断的试验和改进,他们成功地开发出了一系列高效稳定的产品,为公司的后续发展奠定了坚实的基础。这一时期的艰苦奋斗和技术积累,成为了ERG发展历程中的重要篇章。

High Voltage Power Solutions Inc公司的发展小趣事

进入21世纪,随着LED技术的快速发展,ERG看到了固态照明市场的巨大潜力。2008年,公司决定成立一个新的部门——ERG Lighting,专注于为固态照明市场设计、制造和分销LED驱动器和其他照明配件。这一举措极大地拓展了公司的业务范围,并使其在市场上占据了有利地位。ERG Lighting的成立,不仅为公司带来了新的增长点,还进一步巩固了其在电源转换产品领域的领先地位。

问答坊 | AI 解惑

2-60V可调

最近打算做一个2-60V可调电源,最大电流为10A,纹波<100mv,不知大家有什么建议给我吗?虽然做过电源但是还没有做过这么大功率的,第一次尝试,不知该考虑些什么? 希望各位大虾多给提点意见 …

查看全部问答>

.net cf 没有GetDelegateForFunctionPointer函数

只有Marshal.GetFunctionPointerForDelegate函数 我要调用一个dll,该dll的函数参数是指针 在.net上可以这样调用: DelegateS myS = Marshal.GetDelegateForFunctionPointer(                 ...…

查看全部问答>

新手提问89c51中断系统IE,IP寄存器啥区别?怎么编程使用

如题,最近我在学习用KEIL C编写程序时对单片机里中断系统里寄存器IE和IP的功能很不了解,不知道中断源的优先级到底该设到哪各寄存器里,于是感到很晕,心里犯嘀咕:一个寄存器里怎么能把所有中断源优先次序排个序?!!由于对硬件不了解,就翻了几 ...…

查看全部问答>

双色LED立体显示效果

昨晚在做LED点阵无意中拍摄到的,呵呵,实际不是这样。 为了显示上面那几个字,我采用手工绘图方法绘出来。 显示代码如下: unsigned char code Display_Font[64][16]= { //1   0x03,0x03,0x03,0x01,0x03,0x03,0x03,0x03,  ...…

查看全部问答>

WINCE摄像头采集后图像如何播放?

请问:   我用的是2440CAMERA接口,驱动只完成了将数据存到帧存储器的工作,要想在WINCE上将视频,或者是一张图片显示出来,要做什么工作呢?    我的理解是LCD会不断的从帧缓冲里将数据输出到屏上,所以用memcpy将buffer_rgb的数据 ...…

查看全部问答>

关于NT内核模式中的进程问题,一直都没人解决,不知大牛们对此有何看法??

根据IRP既然可以得到宿主进程的信息,如名字和路径,那么能否得到宿主进程的ID呢? 是有代码可以得到IRP的进程ID的,得到的是PEPROCESS ProcessID,那么这个进程ID和用户模式的任务管理器中看到的进程ID有什么关系??它们是同一个东西吗???内核模 ...…

查看全部问答>

申请ez430-RF2500 开发板

不敢说项目中就会用它,但是可以多一种方案多一个选择。 完成后分享过程中的点滴。   [ 本帖最后由 sblpp 于 2010-10-13 18:55 编辑 ]…

查看全部问答>

ST给的Demo中的STM3210E-EVAL如何产生的?

IAR编译器下本来的工程应该是Debug,Release,但是ST给的Demo中的 TM3210E-EVAL如何产生的?属于Debug呢还是Release呢?…

查看全部问答>

P1REN没有定义?

我刚开始学430在编译下面代码的时候,IAR报错 Error[Pe020]: identifier \"P1REN\" is undefined E:\\workspace\\main.c 12 #include \"io430.h\"#include \"intrinsics.h\" int main( void ){  // Stop watchdog timer to prevent time out ...…

查看全部问答>

分享目前最详细最好的SD卡学习视频教程,阿迪的《MMC/SD卡入门到精通》

比较不错的SD卡/MMC卡学习视频教程,AVR单片机驱动的,在线稍微没有那么清晰东西比较大,没有上传,大家先网上看看在线的,有时间了传清晰版版本优酷网在线观看地址:第一集:http://v.youku.com/v_playlist/f5066832o1p1.html第二集:http://v.you ...…

查看全部问答>