當(dāng)前位置:首頁 > 單片機(jī) > 單片機(jī)
[導(dǎo)讀]一、獨(dú)立看門狗IWDG概述1.)看門狗設(shè)備(獨(dú)立看門狗和窗口看門狗)可用來檢測和解決由軟件錯(cuò)誤引起的故障;當(dāng)計(jì)數(shù)器達(dá)到給定的超時(shí)值時(shí),觸發(fā)一個(gè)中斷或產(chǎn)生系統(tǒng)復(fù)位。2.)功能圖:(由于本人無法貼圖,請見參考手冊,1

一、獨(dú)立看門狗IWDG概述

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

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

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

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

5.)IWDG_KR寫入OXCCCC,啟動(dòng)獨(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ù)位后,看門狗會(huì)自動(dòng)開始運(yùn)行;如果在計(jì)數(shù)器計(jì)數(shù)結(jié)束前,若軟件沒有向鍵寄存器寫入相應(yīng)的值,則系統(tǒng)會(huì)產(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)次以后,不再加載看門狗。這樣,看門狗會(huì)在后面的時(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;temp<200000;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

/* Set the Vector Table base location at 0x20000000 */

NVIC_SetVectorTable(NVIC_VectTab_RAM, 0x0);

#else  /* VECT_TAB_FLASH  */

/* Set the Vector Table base location at 0x08000000 */

NVIC_SetVectorTable(NVIC_VectTab_FLASH, 0x0);

#endif

NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQChannel;

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;

NVIC_InitStructure.NVIC_IRQChannelSubPriority = 1;

NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;

NVIC_Init(&NVIC_InitStructure);

}

void Timer_init(void)

{

TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;

// ---------------------------------------------------------------

//  TIM3 Configuration:  定時(shí)器3配置

//  TIM3CLK = 36 MHz, Prescaler =36000, TIM3 counter clock = 1KHz

//  SET TTIM3 TIME 200mS

//---------------------------------------------------------------

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3,ENABLE);

// Time base configuration

TIM_TimeBaseStructure.TIM_Period = 200;

TIM_TimeBaseStructure.TIM_Prescaler = 0;

TIM_TimeBaseStructure.TIM_ClockDivision = 0;

TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Down;

TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure);

//Enables peripheral Preload register on ARR

TIM_ARRPreloadConfig(TIM3,ENABLE);

// Prescaler configuration

TIM_PrescalerConfig(TIM3, 35999, TIM_PSCReloadMode_Immediate);

TIM_InternalClockConfig(TIM3);

//Enables  TIM interrupts

TIM_ITConfig(TIM3,TIM_FLAG_Update,ENABLE);

//TIM3 enable counter

TIM_Cmd(TIM3, ENABLE);

}

………………………………………………………………………

void TIM3_IRQHandler(void)

{

static u8 count=0;

if (TIM_GetITStatus(TIM3, TIM_IT_Update) != RESET)

{

TIM_ClearITPendingBit(TIM3, TIM_IT_Update);

//TIM3溢出中斷需執(zhí)行的代碼在此添加

count++;

if(count<=25)

{

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

IWDG_WriteAccessCmd(IWDG_WriteAccess_Enable);

/* Reload IWDG counter */

IWDG_ReloadCounter();

}

}

}

四、結(jié)語

獨(dú)立看門狗時(shí)鐘由內(nèi)部40KHZ提供,所以不受主時(shí)鐘的影響,即一旦啟動(dòng)看門狗,即便在調(diào)試過程中,暫停程序運(yùn)行,看門狗也將不會(huì)停止,在復(fù)位時(shí)間到后仍會(huì)將系統(tǒng)復(fù)位。

原帖地址:http://bbs.21ic.com/icview-110937-1-1.html

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉