周立功的《深入浅出ARM7》上_看门狗

周立功的《深入浅出ARM7》上_看门狗周立功的《深入浅出ARM7》上_看门狗1.看门狗概述看门狗(WD,Watchdog)包括一个4分频的预分频器和一个32位计数器。时钟通过预分频器输入定时器。定时器递减计数。定时器递减的最小值为0x

大家好,又见面了,我是你们的朋友全栈君。

周立功的《深入浅出ARM7》上_看门狗

1.看门狗概述

       看门狗(WD,Watchdog)包括一个4分频的预分频器和一个32位计数器。时钟通过预分频器输入定时器。定时器递减计数。定时器递减的最小值为0xFF。如果设置一个小于0xFF的值,系统会将0xFF装入计数器。因此最小看门狗间隔为(tplck*256*4) ,最大间隔为(tplck*232*4)的倍数。看门狗的用途是使微控制器在进入错误状态后的一定时间内复位。当看门狗使能时,如果用户程序没有在周期时间内喂狗(重装),看门狗会产生一个系统复位。

  特点:

  如果没有周期性重装,则产生片内复位;

  调试模式;

  由软件使能,但要求禁止硬件复位或看门狗复位/中断;

  错误/不完整的喂狗时序会导致复位/中断(如果使能);

  指示看门狗复位的标志;

  带内部预分频的可编程32位定时器

  可选择tpclk*4倍数的时间周期:从(tpclk*256*4)到(tplck*232*4)

2.看门狗功能结构图

<span role="heading" aria-level="2">周立功的《深入浅出ARM7》上_看门狗

 

3.看门狗寄存器描述

  看门狗包含4个寄存器,如下表所示:

<span role="heading" aria-level="2">周立功的《深入浅出ARM7》上_看门狗

 

  3.1 看门狗模式寄存器–Watchdog Mode Register(WDMOD-0xE0000000)

  WDMOD寄存器通过WDEN和RESET的组合来控制看门狗的操作。如下表所示:

<span role="heading" aria-level="2">周立功的《深入浅出ARM7》上_看门狗

  看门狗模式寄存器

<span role="heading" aria-level="2">周立功的《深入浅出ARM7》上_看门狗

  3.2 看门狗定时器常数寄存器–Watchdog Timer Constant Register(WDTC-0xE0000004)

  WDTC寄存器决定看门狗超时值。当喂狗时序产生时,WDTC的内容重新装入看门狗定时器。它是一个32位寄存器,低8位在复位时设置为1。写入一个小于0xFF的值会使0xFF的值会使0xFF装入WDTC,因此超时的最小时间间隔为tpclk*256*4。

<span role="heading" aria-level="2">周立功的《深入浅出ARM7》上_看门狗

  3.3 看门狗喂狗寄存器–Watchdog Feed Register(WDFEED-0xE0000008)

  向该寄存器写入0xAA,然后写入0x55会使WDTC的值重新装入看门狗定时器。如果看门狗通过WDMOD寄存器使能,该操作还将启动看门狗运行。置位WDMOD中的WDEN位不足以使能看门狗。在看门狗能够产生中断/复位之前,必须完成一次

有效的喂狗时序。否则,看门狗将忽略喂狗错误。向WDFEED寄存器写入0xAA的下一个操作应当是向WDFEED寄存器写入0x55,除非看门狗被触发。在一个喂狗时序中,一次对看门狗定时器寄存器不正确的访问之后第二个plck周期将产生中断/复

位。

  如果应用程序开启了其它中断,为了保证喂狗操作的原子性,在喂狗之前要关闭中断,喂狗之后再开中断。

  看门狗喂狗寄存器

<span role="heading" aria-level="2">周立功的《深入浅出ARM7》上_看门狗

  3.4 看门狗定时器值存储器–Watchdog Timer Value Register(WDTV -0xE000000C)

  WDTV寄存器用于读取看门狗定时器的当前值。

<span role="heading" aria-level="2">周立功的《深入浅出ARM7》上_看门狗

4. 基本操作,看门狗应当根据下面的方法来使用:

  –在WDTC寄存器中设置看门狗定时器的固定装载值;

  –在WDMOD寄存器中设置模式;

  –通过向WDFEED寄存器写入0xAA和0x55启动看门狗;

  –在看门狗向下溢出之前应当再次喂狗以防止复位/中断。

  当看门狗计数器向下溢出时,程序计数器将从0x00000000开始,和外部复位一样。可以检查看门狗超时标志(WDTOF)来确定看门狗是否产生复位条件。WETOF标志必须由软件清零。

  4.1 使用示例

  步骤1.设置看门狗模式

         WDMOD=0x03;//设置看门狗模式;中断且复位

  4.2 设置看门狗定时常数

         WDTC=0xff0000;//设置看门狗定时器参数

  4.3 喂狗操作

         WDFEED=0xaa; //注意:第一次喂狗启动看门狗

         WDFEED=0x55;

  4.4 喂狗之前关中断

         IRQDisable();或者FIQDisbale();//喂狗之前关中断

         WDFEED=0xaa;

         WDFEED=0x55;

         IRQEnable();或者FIQEnable();//喂狗之后开中断。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/154924.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • codeforces Arrival of the General 题解

    codeforces Arrival of the General 题解

    2022年1月31日
    37
  • Java案例:实现九九乘法表「建议收藏」

    Java案例:实现九九乘法表「建议收藏」Java案例:实现九九乘法表前言本篇文章主要讲述并实现Java实现九九乘法表。一、九九乘法表?九九乘法表就是咱们小学时期最开始接触乘法运算时,数字10以内,以及结果100以内的乘法口诀。二、解题思路因为涉及到行与列,而且均有1~9这样的循环出现,因此首先想到的就是for循环,而且要出现两个其次,因为九九乘法表每一行的等式左边的因数为等式的列,右边的因数为等式的行,同一行,右边的因数不变,所以for循环有嵌套关系又因为左边的因数永远小于等于右边的因数,所以嵌套的for循环条件一定为

    2022年7月15日
    26
  • QQ空间钓鱼源码_QQ空间视频提取值源码

    QQ空间钓鱼源码_QQ空间视频提取值源码IgotthiswebsitefrommypalwhosharedwithmeconcerningthiswebpageandatthemomentthistimeIamvisitingthiswebsiteandreadingveryinformativearticlesorreviewshere.回复thejjreport.com…

    2022年8月24日
    9
  • 〖免杀〗.net程序一键免杀Win10 20H2 Defender「建议收藏」

    〖免杀〗.net程序一键免杀Win10 20H2 Defender「建议收藏」WIN10更新至最新版20H2发现,查杀能力比以前强了不少,特别是针对CS加载.NET程序集或NIM加载.NET的查杀,毕竟你要调用的函数微软很了解,它想拦截想杀还是比较容易的。但是不知道大家有没听说过一个故事“微软的编程工具的开发工程师,编写程序时,也需要查阅文档”,说明什么?微软系统的API很多,是微软写的没错,但又不是一个人自己写的,就算是一个人自己写的,功能那么多,他也根本记不起,用到自己的东西也要查阅文档,就像我用Ladon有时也要查阅文档,这很正常,因为我写过的工具或功能太多,有些久不用,甚至都

    2022年8月20日
    9
  • linux rootfs_linux常用文件系统类型

    linux rootfs_linux常用文件系统类型linux中有一个让很多初学者都不是特别清楚的概念,叫做“根文件系统”。我接触linux前前后后也好几年了,但是对这个问题,至今也不是特别的清楚,至少没法向其他初学者们给出一个很全面很到位的解释。于是,今天我们就来理一理这个话题。

    2022年10月7日
    2
  • JAVA中字符串常量池和缓冲池理解与作用「建议收藏」

    JAVA中字符串常量池和缓冲池理解与作用「建议收藏」字符串池与常量池是完全不同的两个东西,但是很多地方都喜欢把它们混为一谈,很容易让初学者产生误解,在这里我想好好讨论一下它们。字符串池也可以被称为字符串常量池,我认为这个名称就是产生误解的根源,有些人说着说着就把字符串三个字省略了,只剩下了常量池…所以为了避免误解,我建议在指代字符串对象的缓存池的时候,就直接称之为字符串池1常量池常量池分为两个类型,一是.class文件中静态的常量池,二是.class文件中的静态常量池被加载到JVM中而形成的运行时常量池。1.1静态常量池.cla

    2022年7月28日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号