当前位置:首页 > 单片机 > 单片机
[导读]看门狗定时器是一个倒计时定时器。假设我们规定,当定时器计数到4000和0之间时喂狗,符合条件。当在大于4000的时候喂狗,和计数器倒数到0没有喂狗都不符合要求。这就是窗口看门狗。在实际应用中,当发生提前喂狗,和

看门狗定时器是一个倒计时定时器。假设我们规定,当定时器计数到4000和0之间时喂狗,符合条件。当在大于4000的时候喂狗,和计数器倒数到0没有喂狗都不符合要求。这就是窗口看门狗。在实际应用中,当发生提前喂狗,和没有喂狗都会使得单片机复位,从而使程序得到了双重保护。

如果我们要知道定时器是否计数到了规定的两值之间,最直接的办法当然是读取定时器的当前值,但是这样必须在程序中时刻读取定时器的当前值,不仅给程序带来了很大的负担,而且有些时候,程序无法满足读取当前值的条件。所以,LPC1114中,给出了这么一个寄存器:WDWARNINT。即看门狗提醒中断寄存器。改寄存器的定义如下所示:

WDWARNINT:看门狗提醒中断寄存器

位符号描述复位值9:0WARNINT看门狗提醒中断比较值031:10–保留位。不能给这些位写1–

该寄存器可以设置一个值,当看门狗定时器倒计时到这个值时,产生看门狗中断。该值是个10位的值,最大0x3FF,即1023。

假设窗口看门狗的定时器值范围是4000~0,给WDWARNINT寄存器写入值1023,当定时器倒计时到1023的时候,产生中断,在看门狗中断服务函数里面,写入喂狗的函数,即可解决上面提出的时刻读取计数值的问题。

窗口看门狗的上限值在WDWINDOW寄存器里面定义。

WDWINDOW:看门狗窗口寄存器

位符号描述复位值23:0WINDOW看门狗窗口值0xFFFFFF31:24–保留位,不能给这些位写1–

下面做一个示例:

让单片机间隔一定时间给电脑串口发送一个递增的数据。正常情况下,会一直发送。

当我们故意把看门狗定时器中断服务函数里面的喂狗函数去掉,即当定时器倒计时到0时,会产生复位,在电脑串口调试助手上看到的结果将是,当单片机复位,会使得串口调试助手上的数从0开始递增。

当我们故意把看门狗定时器中断服务函数里面的喂狗函数放到发送第一个字节以后,即提前喂狗,将会使得单片机复位,在串口调试助手上,将会一直收到00,即来不及递增,单片机就复位从新开始执行了。

新建一个工程,结果如下图所示:

uart.c文件的介绍,请看第四章内容。

在main.c文件中,输入以下代码:

#include “lpc11xx.h”

#include “wdt.h”

#include “uart.h”

void delay(void)

{

uint16_t i,j;

for(i=0;i<5000;i++)

for(j=0;j<280;j++);

}

void WDT_IRQHandler(void)

{

LPC_WDT->MOD &= ~(0x1<<2);

WDTFeed();

}

int main()

{

uint8_t cnt=0;

UART_init(9600);

WDT_Window_Enable();

NVIC_EnableIRQ(WDT_IRQn);

while(1)

{

UART_send_byte(cnt++);

delay();

}

}

从main函数开始看起。

第17行,定义了一个变量,该变量用来递增。

第18行,初始化串口波特率为9600。(关于此函数的详细说明,请看第四章内容。)

第19行,开启窗口看门狗功能。

第20行,开启看门狗中断。

第21~25行,间隔给串口发送递增的数据,循环发送。

在wdt.h中,输入以下代码:

#ifndef __NXPLPC11XX_WDT_H__

#define __NXPLPC11XX_WDT_H__

extern void WDT_Window_Enable(void);

extern void WDTFeed(void);

extern void WDT_IRQHandler(void);

#endif

在wdt.c中,输入以下代码:

#include “lpc11xx.h”

#include “wdt.h”

#include “uart.h”

void WDT_Window_Enable()

{

LPC_SYSCON->PDRUNCFG &= ~(0x1<<6); // 看门狗振荡器时钟上电(bit6)

LPC_SYSCON->WDTOSCCTRL = (0x1<<5);// WDT_OSC_CLK=300KHz

LPC_SYSCON->WDTCLKSEL = 0x2; // 选择看门狗时钟源

LPC_SYSCON->WDTCLKUEN = 0x01; // 更新时钟源

LPC_SYSCON->WDTCLKUEN = 0x00; // 先写0,再写1达到更新目的

LPC_SYSCON->WDTCLKUEN = 0x01;

while ( !(LPC_SYSCON->WDTCLKUEN & 0x01) ); // 等待更新成功

LPC_SYSCON->WDTCLKDIV = 3; // 设置看门狗分频值为3

LPC_SYSCON->SYSAHBCLKCTRL |= (1<<15);// 允许WDT时钟

LPC_WDT->TC = 25000; // 给看门狗定时器赋值,定时时间大约1秒(wdt_clk=100KHz时)

LPC_WDT->WARNINT = 1023; // 当看门狗定时器倒数到1023时,产生中断

LPC_WDT->WINDOW = 4600; // 最大喂狗值

LPC_WDT->MOD |= 0x03; // 写值0x03:不喂狗产生复位

LPC_WDT->FEED = 0xAA; // 喂看门狗,开启

LPC_WDT->FEED = 0x55;

}

void WDTFeed(void)

{

LPC_WDT->FEED = 0xAA;

LPC_WDT->FEED = 0x55;

}

和前面的使能看门狗函数相比,只多了第13、14行的代码。

第13行,设置提醒中断值。

第14行,设置喂狗最大值,窗口值。


本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

在嵌入式系统开发中,看门狗(Watchdog Timer, WDT)是保障系统可靠性的核心组件,其初始化时机的选择直接影响系统抗干扰能力和稳定性。本文从硬件架构、软件流程、安全规范三个维度,系统分析看门狗初始化的最佳实践...

关键字: 单片机 看门狗 嵌入式系统

看门狗是实现嵌入式计算机系统运行状态监控的一种措施 , 能够有效提高系统运行可靠性 。针对HKSP6102处理器在嵌入式计算机中的应用 ,分析了通用看门狗的设计方法及其特点;最后介绍了数据处理模块的看门狗设计方法 ,基于...

关键字: 看门狗 嵌入式计算机 监控

在嵌入式系统开发中,看门狗(Watchdog Timer, WDT)是一种重要的故障检测和恢复机制。当系统因软件错误、硬件故障或外部干扰而陷入异常状态时,看门狗能够自动触发复位操作,使系统恢复到正常运行状态。本文将深入探...

关键字: 嵌入式系统 看门狗

为了保护个人信息和网络设备的安全,专家们致力于开发各种安全技术和工具。其中,路由器看门狗功能成为了网络安全领域的一大创新。

关键字: 路由器 看门狗

STM32有两个看门狗,独立看门狗和窗口看门狗。其实两者的功能是类似的,只是喂狗的限制时间不同。

关键字: 看门狗 窗口看门狗

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

关键字: 单片机 看门狗 计算机

STC单片机是一款增强型51单片机,完全兼容MCS-51,还增加了新的功能,比如新增两级中断优先级,多一个外中断,内置EEPROM,硬件看门狗,具有掉电模式,512B内存等。还支持ISP下载,不用编程器,只要一个MAX2...

关键字: 单片机 看门狗 中断

今天要学习的是独立看门狗,看门狗电路的应用,使单片机可以在无人状态下实现连续工作,其 工作原理是:看门狗芯片和单片机的一个I/O引脚相连,该I/O引脚通过程序控制它定时地往看门狗的 这个引脚上送入高电平(或低电平),这一...

关键字: 看门狗 中断函数 单片机

看门狗(watch dog)是一个定时器,可以设置一个定时时间,计时到时会把MCU复位,所以MCU必须要在定时时间到之前将计数值重置(这个动作通常称为喂狗)。在嵌入式系统中加入看门狗,可以监测MCU是否还在正常运行,如果...

关键字: 看门狗 定时器

我们是否因系统上出现意外的电压尖峰或电流浪涌而担心系统安全?电流浪涌和电压尖峰可能是由系统上运行的软件引起的。来自软件的意外命令会使系统陷入无限循环,从而导致电源轨上出现电流浪涌或电压尖峰,并可能损坏设备。

关键字: 看门狗 电流浪涌
关闭