新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 我的獨(dú)立看門狗總結(jié)

我的獨(dú)立看門狗總結(jié)

作者: 時(shí)間:2013-04-10 來源:網(wǎng)絡(luò) 收藏

一、概述

1.)看門狗設(shè)備(和窗口看門狗)可用來檢測和解決由引起的故障;當(dāng)計(jì)數(shù)器達(dá)到給定的超時(shí)值時(shí),觸發(fā)一個(gè)中斷或產(chǎn)生系統(tǒng)復(fù)位。

2.)功能圖:(由于本人無法貼圖,請見參考手冊,125頁)

3.)()由專用的40kHz 的低速時(shí)鐘為驅(qū)動;因此,即使主時(shí)鐘發(fā)生故障它也仍然有效。

4.)其中_PR為預(yù)分頻器寄存器,IWDG_RLR為重新加載計(jì)數(shù)器寄存器,IWDG_KR為控制器存器。IWDG_SR為狀態(tài)寄存器。(見圖)

5.)IWDG_KR寫入OXCCCC,啟動獨(dú)立看門狗功能,計(jì)數(shù)器值開始遞減,減到0時(shí),看門狗復(fù)位。IWDG_KR寫入0XAAAA,計(jì)數(shù)器值被重新加載,即避免看門狗復(fù)位。IWDG_KR寫入0X5555,則允許寫IWDG_PR 和IWDG_RLR寄存器寫操作。寫入其它值,IWDG_PR 和IWDG_RLR被保護(hù),數(shù)據(jù)將無法寫入這兩個(gè)寄存器。IWDG_SR狀態(tài)寄存器指示預(yù)分頻值和遞減計(jì)數(shù)器是否正在被更新。IWDG_RLR寄存器范圍為0-0xfff.

6.)如果用戶在選擇字節(jié)中啟用了“硬件看門狗“功能,在系統(tǒng)上電復(fù)位后,看門狗會自動開始運(yùn)行;如果在計(jì)數(shù)器計(jì)數(shù)結(jié)束前,若軟件沒有向鍵寄存器寫入相應(yīng)的值,則系統(tǒng)會產(chǎn)生復(fù)位。

7。)看門狗復(fù)位時(shí),系統(tǒng)復(fù)位,程序重新開始運(yùn)行。

二、實(shí)驗(yàn)功能

為了實(shí)現(xiàn)IWDG復(fù)位功能,本人做了一個(gè)實(shí)驗(yàn):

采用優(yōu)易特電子的EDU開發(fā)板,功能如下:

系統(tǒng)上電,蜂鳴器延時(shí)叫一聲,之后關(guān)閉。IWDG 40K的內(nèi)部低速時(shí)鐘進(jìn)行8分頻產(chǎn)生5KHZ的看門狗計(jì)數(shù)時(shí)鐘,RLR設(shè)為2500,即看門狗復(fù)位時(shí)間設(shè)為500MS。LD1燈亮,表示看門狗初始化完畢。開啟看門狗功能。定時(shí)器3定為200MS定時(shí)器,在每次定時(shí)器中斷中,將看門狗計(jì)數(shù)器重新加載,當(dāng)加載到25(5S)次以后,不再加載看門狗。這樣,看門狗會在后面的時(shí)間發(fā)生復(fù)位,從而系統(tǒng)重新運(yùn)行。檢查蜂鳴器是否每約5S叫一聲,如果這樣表示IWDG發(fā)生了復(fù)位。功能檢驗(yàn)完成。

經(jīng)實(shí)驗(yàn)證明,以上功能均正確。

三、程序如下

main()

{

u32 temp;

RCC_init();

Gpio_int();

GPIO_ResetBits(GPIOC,GPIO_Pin_6);//蜂鳴器叫一聲關(guān)閉

for(temp=0;temp200000;temp++);

GPIO_SetBits(GPIOC,GPIO_Pin_6);

IWDG_init();

GPIO_SetBits(GPIOF,GPIO_Pin_6);//LD1燈亮

Timer_init();

NVIC_init();

while(1);

}

……………………………………………………………………….

void IWDG_init(void)

{

/* Enable write access to IWDG_PR and IWDG_RLR registers */

IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);

/* IWDG counter clock: 40KHz(LSI) / 8 = 5 KHz */

IWDG_SetPrescaler(IWDG_Prescaler_8);

/* Set counter reload value to 2499,500ms */

IWDG_SetReload(2499);

/* Reload IWDG counter */

IWDG_ReloadCounter();

/* Enable IWDG (the LSI oscillator will be enabled by hardware) */

IWDG_Enable();

}

void NVIC_init(void)

{

NVIC_InitTypeDef NVIC_InitStructure;

#ifdef VECT_TAB_RAM

分頻器相關(guān)文章:分頻器原理
塵埃粒子計(jì)數(shù)器相關(guān)文章:塵埃粒子計(jì)數(shù)器原理
蜂鳴器相關(guān)文章:蜂鳴器原理

上一頁 1 2 下一頁

評論


技術(shù)專區(qū)

關(guān)閉