S3C2440看门狗解析

时间:2022-07-01 03:28:38

S3C2440A的看门狗定时器是用于当其由于噪声和系统错误引起的故障干扰时恢复控制器的工作。它可以被用作普通16位内部定时器来请求中断服务。看门狗定时器产生128个PCLK周期的复位信号

也就是说,在某些环境下,看门狗可以当做定时器使用,当他中断的时候并不发生复位,只发生中断,我看看图

S3C2440看门狗解析

看门狗的中断和复位信号是可以依靠wtcon来切断的(看门狗的时钟是无法切断的)

使用看门狗主要靠这几个寄存器

S3C2440看门狗解析

用来选择时钟源,分频系数,启动看门狗以及看门狗中断和复位的连接

S3C2440看门狗解析

S3C2440看门狗解析

流程基本上就是,第一次对wtcnt赋值之后启动看门狗,看门狗自动减,到达0的时候触发中断,如果连接了复位则触发复位

未连接则触发中断,另外,
看门狗定时器数据寄存器(WTDAT)的值不能被自动重载到定时计数器(WTCNT)中。由于这个理由,必须在看门狗定时器启动前写入一个初始值到看门狗定时器计数寄存器(WTCNT)中

请看具体代码,两种看门狗的使用都有

#include "watchdog.h"

u8 wwdgUp = 0;

void __irq Wdt_Int(void)
{
rSRCPND |=BIT_WDT_AC97;
rINTPND |=BIT_WDT_AC97;
rSUBSRCPND |= BIT_SUB_WDT; //清除中断标志 // WatchdogInit(0);
wwdgUp = 1;
} //看门狗不连接系统复位
//prescaler 分频系数 8位
//mux 始终选择 0 16 1 32 2 64 3 128
//countValue 计数值
void WWDGInitForTimer(u8 prescaler,u8 mux,u16 countValue)
{ rWTCON &= ~(1<<5);//看门狗禁止 rWTCON &= 0xff00;//清除预分频系数
rWTCON |= prescaler<<8;//设置预分频系数 rWTCON &= ~(0x03<<3);
rWTCON |= mux<<3;//设置时钟选择器 rWTCON |= 1<<2;//使能中断]
rWTCON &= ~(1<<0);//禁止复位
rWTDAT = countValue;
rWTCNT = countValue;//初次使用,必须设置CNT的值 rSRCPND |=BIT_WDT_AC97; //清除标志
rINTPND |=BIT_WDT_AC97;
rSUBSRCPND |= BIT_SUB_WDT; //清除子中断标志 rINTMOD &= ~BIT_WDT_AC97;//设置中断模式为IRQ模式
rINTMSK &= ~(BIT_WDT_AC97); //开中断
rINTSUBMSK &= ~(BIT_SUB_WDT);//开子中断 pISR_WDT_AC97=(unsigned)Wdt_Int;//设置中断程序入口 rWTCON |= (1<<5);//看门狗启动 } //看门狗连接系统复位
//prescaler 分频系数 8位
//mux 始终选择 0 16 1 32 2 64 3 128
//countValue 计数值
void WWDGInitForReset(u8 prescaler,u8 mux,u16 countValue)
{ rWTCON &= ~(1<<5);//看门狗禁止 rWTCON &= 0xff00;//清除预分频系数
rWTCON |= prescaler<<8;//设置预分频系数 rWTCON &= ~(0x03<<3);
rWTCON |= mux<<3;//设置时钟选择器 rWTCON &= ~(1<<2);//禁止中断]
rWTCON |= (1<<0);//使能复位
rWTDAT = countValue;
rWTCNT = countValue;//初次使用,必须设置CNT的值 rWTCON |= (1<<5);//看门狗启动 } void Watchfeed(u16 count) //看门狗喂狗
{
rWTCNT=count; //喂狗
}
#ifndef __WATCHDOG_H
#define __WATCHDOG_H
#include "2440addr.h"
#include "def.h" void WWDGInitForTimer(u8 prescaler,u8 mux,u16 countValue); void WWDGInitForReset(u8 prescaler,u8 mux,u16 countValue); void Watchfeed(u16 count); //看门狗喂狗 extern u8 wwdgUp; #endif