周立功的《深入浅出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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 计算机网络的分类_计算机网络是怎样分类的

    计算机网络的分类_计算机网络是怎样分类的计算机网络的分类:按照覆盖范围分,计算机网络可以分为局域网(LAN)、城域网(MAN)、和广域网(WAN)。局域网(LAN)是一个高速数据通信系统,它在较小的区域内将若干独立的数据设备连接起来,使

    2022年8月2日
    2
  • C#酒店管理系统_酒店管理系统免费

    C#酒店管理系统_酒店管理系统免费1.酒店管理系统概要c#实现的酒店管理系统,里面包含了数据库文件,简易酒店管理系统源码,采用WinFrom程序设计开发的酒店管理系统;应用到标准的三层技术,多个视图工具控件;功能介绍用户可根据自己的需求入住登记不同类型的房间,同时登记个人基本信息,管理员可通过对不同类型房间的管理及房间信息管理设置不同的类型房间进行增删改查,并对入住客户的信息及点退房信息查询,并改变房间的入住与退房或空房间的状态信息2.数据库设计由于数据库较多,所以暂时不放出来,下面我们看运行截图3.运行截图

    2022年9月24日
    2
  • java集合系列——java集合概述(一)[通俗易懂]

    在JDK中集合是很重要的,学习java那么一定要好好的去了解一下集合的源码以及一些集合实现的思想! 一:集合的UML类图(网上下载的图片) Java集合工具包位置是java.util.*二:集合工具的分析 1:Java集合是java提供的工具包,常用的数据结构:集合、链表、队列、栈、数组、映射等 2:java集合主要划分为五个部分: List列表、Set集合、Map映射、迭代器(It

    2022年2月26日
    58
  • “找不到VMware Tools 安装包”的解决办法——安装VMware Tools

    “找不到VMware Tools 安装包”的解决办法——安装VMware Tools最近刚接触虚拟机,在VMware下安装的是Ubuntu16.04.4。在安装完Ubuntu以后,想安装一个VMwareTools来解决文件在win10和虚拟机之间的拖拽问题,但是按照网上的教程左键点击“虚拟机——安装VMwareTools”选项卡以后没有找到VMwareTools的压缩包。VMwareTools的好处在于可以直接将win10下的文件拖拽或者复制粘贴到ubuntu中,而且…

    2022年5月9日
    364
  • Group Convolution 分组卷积

    Group Convolution 分组卷积GroupConvolution分组卷积最早见于AlexNet——2012年Imagenet的冠军方法,GroupConvolution被用来切分网络,使其在2个GPU上并行运行,AlexNet网络结构如下:ConvolutionVSGroupConvolution如果输入featuremap尺寸为C∗H∗W,卷积核有N个,输出featuremap与卷积核的数量相同也是N,每…

    2025年7月18日
    5
  • client的中文意思是什么_java中cin什么意思

    client的中文意思是什么_java中cin什么意思IE中: document.body.clientWidth==>BODY对象宽度 document.body.clientHeight==>BODY对象高度 document.documentElement.clientWidth==>可见区域宽度 document.documentElement.clientHeight==>可见区域高度 FireFox中:

    2022年9月11日
    3

发表回复

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

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