看门狗的工作原理:

设本系统程序完整执行一周期的时间是Tp,看门狗的定时周期为Ti,Ti>Tp,在程序正常执行时,定时器就不会溢出,若因为干扰等原因使系统不能在Tp时刻改动定时器的记数值,定时器将在Ti时刻溢出,引发系统复位,使系统得以又一次执行,从而起到监控的作用。

看门狗具有两个功能:

1、 当做常规时钟,能够产生中断;

2、 当看门狗定时器使用,当计数器WTCNT为0时,产生复位;

看门狗的功能方框图:



我程序中PCLK为50MHz,预分频值=77,时钟除数因子选128,

时钟周期t_watchdog=1/[PCLK/(预分频值+1)/时钟除数因子]

=1/[50*1000000/(77+1)/128]=0.0002

t_watchdog表示的是看门狗计数计时器WTCNT每降低1所用的时间,WTCNT又相当于一个节拍的作用,当WTCNT为0时,假设看门狗控制寄存器WTCON[0]开启复位功能,则复位;假设看门狗控制寄存器WTCON[0] 禁止复位,开启中断,则中断操作,并数据(WTDAT)寄存器又一次赋值到计数(WTCNT)寄存器内,循环中断操作(这里的中断就类似RTC的闹钟中断)。

所谓的喂狗:就是使WTCNT在为0之前又一次赋值,不使之发生中断或者复位。

引用赵老师的一段话:

s3c2440的看门狗定时器不仅能够引起系统复位,还能够引起一般的中断,因此s3c2440的看门狗定时器能够当作一般的定时器使用。

看门狗中断结果:

每四秒一个中断,LED点亮并串口提示

看门狗复位结果:

AXD调试执行到看门狗计数器rWTCNT为零时,进入复位,CPU停止工作,也就不产生中断。

复位关闭axd后,u-boot串口初始化提示(没能及时在第一次蜂鸣器响按下按键停止autoboot):

复位关闭axd后,u-boot串口初始化提示(及时在第一次蜂鸣器响按下按键停止autoboot):

这里就是复位到用uboot初始化开发板的时候,可是不明确为什么必需要在第一次蜂鸣器就按下按键才干进到uboot

附:

硬件环境:J-link v8、mini2440、J-link转接板、串口转USB线

软件环境:windows7(32位)、开发板uboot(NandFlash)、J-link驱动(J-Link ARM V4.10i)、SecureCRT、ADS1.2

 

代码块

//====================================================================
// 实现功能:
// 看门狗中断和复位操作
// 当WTCON[0] 开启复位功能; 实现复位
// 当WTCON[0] 禁止复位,WTCON[2]开启中断; 实现中断
// by:梁惠涌
//====================================================================
#include "2440addr.h"
#include "def.h"
#include "2440lib.h" static U8 led_flag=0;
/**************************************************************
看门狗初始化函数
**************************************************************/
void watchdog_init(){
rWTCON=((77<<8)|(1<<5)|(3<<3)|(1<<2)); //预分频值=77;看门狗定时器使能;时钟除数因子=128 ;看门狗中断使能;
//时钟周期t_watchdog=1/[PCLK/(预分频值+1)/时钟除数因子]=1/[50*1000000/(77+1)/128]=0.0002
//t_watchdog表示的是看门狗计数计时器WTCNT每降低1所用的时间
rWTDAT=20000; //WTDAT看门狗数据寄存器,看门狗定时器重载的计数值
rWTCNT=20000; //WTCNT看门狗计数寄存器,看门狗定时器当前计数值
} /**************************************************************
看门狗中断函数
**************************************************************/
void __irq watchdog_isr(){
rSUBSRCPND |=1<<13; //清除次级中断挂起状态
rSRCPND|=0x1<<9; //清除中断挂起状态
rINTPND|=0x1<<9; //中断LED点亮
led_flag++;
Uart_Printf("\n -----看门狗中断,点亮LED %d\n",led_flag);
rGPBCON=0x015400;
switch(led_flag){
case 1: rGPBDAT=0xe<<5 ;break;
case 2: rGPBDAT=0xd<<5 ;break;
case 3: rGPBDAT=0xb<<5 ;break;
case 4: rGPBDAT=0x7<<5 ;break;
}
if(led_flag==4) led_flag=0; rSUBSRCPND &=(~0x1<<13);
rSRCPND &=(~0x1<<9); //开中断
rINTPND &=(~0x1<<9);
} /**************************************************************
看门狗子函数
**************************************************************/
void watchdog(){ watchdog_init(); //初始化看门狗寄存器 //选择是否开启复位
//rWTCON |= (1<<0);//开启复位
rWTCON |= (0<<0);//禁止复位 rINTSUBMSK &=~(1<<13);//开看门狗次级中断
rINTMSK &=~(1<<9); //开看门狗中断
pISR_WDT_AC97=(unsigned)watchdog_isr; while(1){
}
}


mini2440裸机试炼之——看门狗中断和复位操作的更多相关文章

  1. mini2440裸机试炼之—RTC闹钟中断,节拍中断

    版权声明:博客地址:http://blog.csdn.net/muyang_ren.源代码能够在我的github上找看看 https://blog.csdn.net/muyang_ren/articl ...

  2. S5PV210 看门狗定时和复位

    第一节 S5PV210的看门狗定时器S5PV210上的看门狗定时器相当于一个普通的16bit的定时器,它与PWM定时器的区别是看门狗定时器可以产生reset信号而PWM定时器不能,S5PV210看门狗 ...

  3. mini2440裸机试炼之——DMA直接存取 实现Uart(串口)通信

    这个仅仅能作为自己初步了解MDA的开门篇 实现功能: 将字符串数据通过DMA0通道传递给UTXH0,然后在终端 显示.传输数据完后.DMA0产生中断,beep声, LED亮. DMA基本知识 计算机系 ...

  4. mini2440裸机试炼之——Uart与pc端实现文件、字符传输

    1.  波特率(Baud rate)即调制速率,1波特即指每秒传输1个符号. 2.  非FIFO模式,即数据传输不利用FIFO缓存,一个字节一个字节地传输. 3.  位能够用来推断发送缓存器中是否为空 ...

  5. S3C2440看门狗解析

    个PCLK周期的复位信号 也就是说,在某些环境下,看门狗可以当做定时器使用,当他中断的时候并不发生复位,只发生中断,我看看图 看门狗的中断和复位信号是可以依靠wtcon来切断的(看门狗的时钟是无法切断 ...

  6. 基于mini2440的看门狗(裸机)

    在由单片机构成的微型计算机系统中,由于单片机的工作常常会受到来自外界电磁场的干扰,造成程序的跑飞,而陷入死循环,程序的正常运行被打断,由单片机控制的系统无法继续工作,会造成整个系统的陷入停滞状态,发生 ...

  7. linux内核中断之看门狗

    一:内核中断 linux内核中的看门狗中断跟之前的裸板的中断差不多,在编写驱动之前,需要线把内核自带的watch dog模块裁剪掉,要不然会出现错误:在Device Drivers /Watchdog ...

  8. zigbee学习之路(十一):看门狗

    一.前言 今天,我们要通过实验学习和认识一下看门狗的使用,看门狗是为了防止防止程序跑飞的,通过不断的喂狗,使看门狗能持续监管程序的运行状态,当程序跑飞时,能及时把程序拽回来. 二.原理与分析 在CPU ...

  9. STM32之独立看门狗与窗口看门狗总结

    一.独立看门狗 STM32 的独立看门狗由内部专门的 40Khz 低速时钟驱动,即使主时钟发生故障,它也仍然有效. 看门狗的原理:单片机系统在外界的干扰下会出现程序跑飞的现象导致出现死循环,看门狗电路 ...

随机推荐

  1. 四、python之 if while for

    一.if条件判断 if 条件判断: 逻辑操作…… …… else: 逻辑操作…… 其中"判断条件"成立时(非零),则执行后面的语句,而执行内容可以多行,以缩进来区分表示同一范围. ...

  2. VK Cup 2016 - Qualification Round 2 D. Three-dimensional Turtle Super Computer 暴力

    D. Three-dimensional Turtle Super Computer 题目连接: http://www.codeforces.com/contest/638/problem/D Des ...

  3. apache&mod_wsgi&django部署多个项目

    今天做好了第二个django项目,但在部署时出了一点小问题,在此记录一下. 1.mod_wsgi 3.4已经支持了部署多个项目,只需在httpd.conf中进行如下配置: WSGIScriptAlia ...

  4. set bin 集合

    set: create table rr(zz char(4));create table test5 (rr set('美丽','态度好','温柔','善良'));insert into test5 ...

  5. MYSQL Out of resources when opening file './xxx.MYD' (Errcode: 24)

    出现Out of resources when opening file './xxx.MYD' (Errcode: 24)错误是因为打开的文件数超过了my.cnf的--open-files-limi ...

  6. DELPHI纤程的演示

    DELPHI纤程的演示 DELPHI7编译运行通过. 纤程实现单元: unit FiberFun; //Fiber(纤程测试Demo)//2018/04/11//QQ: 287413288 //参考 ...

  7. SharePoint 2013 本地创建解决方案

    在之前的博客<SharePoint 2013本地开发解决方案以及远程调试>中,我们介绍了如何通过修改注册表,使SharePoint 2013 解决方案可以本地编辑,也提及了即使修改注册表, ...

  8. 开始学习深度学习和循环神经网络Some starting points for deep learning and RNNs

    Bengio, LeCun, Jordan, Hinton, Schmidhuber, Ng, de Freitas and OpenAI have done reddit AMA's.  These ...

  9. 多种非接触卡 ATQA 字节说明

      原文地址 13.56 MHz RFID Software An Open Source implementation of an NFC stack, and various related ut ...

  10. go语言基础之类型转换

    1.类型转换 示例: package main //必须有一个main包 import "fmt" func main() { //这种不能转换的类型,叫不兼容类型 var fla ...