為了簡單的展示一下不喂狗引起復(fù)位的效果。我們讓單片機給間隔一定時間給串口發(fā)送遞增的數(shù)據(jù),發(fā)送一次數(shù)據(jù),喂一次狗,兩次發(fā)送數(shù)據(jù)的時間小于喂狗要求的最大時間,程序?qū)⒄?zhí)行,在串口調(diào)試助手上,將看到它收到了逐漸遞增的數(shù)據(jù)。然后故意把喂狗的程序隱掉,重新下載程序后,在串口調(diào)試助手上,將看到當(dāng)串口接收的數(shù)據(jù)遞增到某個值時,又重新開始,說明沒有及時喂狗造成了單片機復(fù)位。
新建一個工程,文件結(jié)構(gòu)如下圖所示:
uart.c文件的介紹,請看第三章內(nèi)容。
在main.c文件中,輸入以下代碼:
#include “l(fā)pc11xx.h”
#include “wdt.h”
#include “uart.h”
void delay(void)
{
uint16_t i,j;
for(i=0;i<5000;i++)
for(j=0;j<250;j++);
}
int main()
{
uint8_t i=0;
UART_init(9600);
WDT_Enable(1); // 看門狗初始化,1秒鐘之內(nèi)喂狗
while(1)
{
delay();
WDTFeed();
UART_send_byte(i);
i++;
}
}
第10行,從main函數(shù)看起。
第12行,定義一個變量。
第13行,初始化串口波特率為9600。(關(guān)于此函數(shù)的詳細說明,請看第四章內(nèi)容。)
第14行,開啟看門狗。
第15行,進入while死循環(huán),間隔一定時間給串口發(fā)送逐漸遞增的數(shù)據(jù)。
在wdt.h文件中,輸入以下代碼:
#ifndef __NXPLPC11XX_WDT_H__
#define __NXPLPC11XX_WDT_H__
extern void WDT_Enable(uint8_t mode);
extern void WDTFeed(void);
#endif
在wdt.c文件中,輸入以下代碼:
/******************************************/
/* 函數(shù)功能:使能看門狗 */
/* 參 數(shù):mode = 1 不喂狗產(chǎn)生復(fù)位 */
/* mode = 0 不喂狗產(chǎn)生中斷 */
/******************************************/
void WDT_Enable(uint8_t mode)
{
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; // 設(shè)置看門狗分頻值為3,看門狗時鐘為100K
LPC_SYSCON->SYSAHBCLKCTRL |= (1<<15);// 允許WDT時鐘
LPC_WDT->TC = 25000; //定時時間大約1秒(這是在wdt_clk=100KHz時)
if(mode==1) LPC_WDT->MOD |= 0x03; // 寫值0x03:不喂狗產(chǎn)生復(fù)位
else if(mode==0) LPC_WDT->MOD |= 0x01; // 寫值0x01:不喂狗發(fā)生中斷
LPC_WDT->FEED = 0xAA; // 喂看門狗,開啟
LPC_WDT->FEED = 0x55;
}
/******************************************/
/* 函數(shù)功能:喂狗 */
/******************************************/
void WDTFeed(void)
{
LPC_WDT->FEED = 0xAA; // 喂狗
LPC_WDT->FEED = 0x55;
}