zoukankan      html  css  js  c++  java
  • S3C2440看门狗解析

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

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


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

     

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


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



    流程基本上就是,第一次对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
    


     

     

  • 相关阅读:
    windows的80端口被占用时的处理方法
    Ansible自动化运维工具安装与使用实例
    Tomcat的测试网页换成自己项目首页
    LeetCode 219. Contains Duplicate II
    LeetCode Contest 177
    LeetCode 217. Contains Duplicate
    LeetCode 216. Combination Sum III(DFS)
    LeetCode 215. Kth Largest Element in an Array(排序)
    Contest 176 LeetCode 1354. Construct Target Array With Multiple Sums(优先队列,递推)
    Contest 176
  • 原文地址:https://www.cnblogs.com/dengxiaojun/p/4279417.html
Copyright © 2011-2022 走看看