看似乖巧的
看門狗,也有比較調(diào)皮的一面,在燒錄無法喂狗的特殊情況下仍會(huì)毫不留情的復(fù)位
芯片,造成燒錄失敗,該如何避免這種情況的發(fā)生嗎?
??初識(shí)看門狗
嵌入式產(chǎn)品設(shè)備在電源瞬變、電磁干擾、靜電放電、極端溫濕度等復(fù)雜環(huán)境的干擾下可能會(huì)造成程序異常,從而使系統(tǒng)陷入癱瘓狀態(tài),這時(shí)候我們就希望設(shè)備能夠自動(dòng)復(fù)位,而不需要人工干預(yù),看門狗定時(shí)器可以幫助捕獲和重置已經(jīng)“失控”的設(shè)備,實(shí)現(xiàn)無人值守,提高系統(tǒng)可靠性。看門狗又叫 watchdog timer,是一個(gè)定時(shí)器電路,一般有一個(gè)輸入端用來喂狗,一個(gè)輸出端RST接到芯片的復(fù)位引腳,芯片正常工作的時(shí)候,每隔一段時(shí)間輸出一個(gè)信號(hào)到喂狗端,給看門狗清零,如果超過規(guī)定的時(shí)間不喂狗,看門狗溢出,就會(huì)給出一個(gè)復(fù)位信號(hào),拉低RST引腳使得芯片復(fù)位。ZL6300是廣州致遠(yuǎn)微電子有限公司自行設(shè)計(jì)的一款集欠壓監(jiān)測(cè)復(fù)位、手動(dòng)復(fù)位和超時(shí)復(fù)位功能的看門狗芯片,具有以下特性:-
上電復(fù)位脈沖200mS;
-
支持手動(dòng)復(fù)位;
-
看門狗定時(shí)器溢出周期1.7S;
-
低功耗僅9uA;
-
欠壓復(fù)位。
圖1 ZL6300內(nèi)部結(jié)構(gòu)
應(yīng)用電路
通過之前對(duì)看門狗的初步認(rèn)識(shí),好的看門狗設(shè)計(jì)可以大大提升產(chǎn)品的穩(wěn)定可靠性,我司基于該理念,核心板上均板載獨(dú)立看門狗,為適應(yīng)各種復(fù)雜環(huán)境保駕護(hù)航。下面以我司性能卓越的M3568核心板為例,看下它如何靈活設(shè)計(jì)看門狗電路,對(duì)應(yīng)的原理圖如下圖2所示,看門狗芯片選型ZL6300,支持手動(dòng)按鍵復(fù)位和看門狗溢出復(fù)位,當(dāng)系統(tǒng)正常運(yùn)行時(shí)從芯片上電啟動(dòng)到加載看門狗喂狗驅(qū)動(dòng)所需時(shí)長(zhǎng)約為1S左右,ZL6300溢出周期為1.7S,可以在看門狗溢出周期內(nèi)及時(shí)喂狗清除定時(shí)器。
圖2看門狗電路
當(dāng)芯片處于燒錄狀態(tài)時(shí)因內(nèi)核停止工作,喂狗程序不能正常運(yùn)行,不能及時(shí)喂狗,看門狗溢出拉低芯片復(fù)位引腳,導(dǎo)致程序下載失敗。為應(yīng)對(duì)這種特殊情況,預(yù)留了跳線冒選項(xiàng),插上短路帽即可禁用看門狗,當(dāng)J2插上短路帽時(shí),WDO_EN被拉至低電平,Q1三級(jí)管處于關(guān)斷狀態(tài),WDI引腳處于高組態(tài),當(dāng)WDI引腳檢測(cè)到它處于高阻抗?fàn)顟B(tài)時(shí)將產(chǎn)生自己的WDI脈沖,對(duì)應(yīng)的喂狗波形如下圖3所示。
圖3 看門狗禁能時(shí)喂狗波形
當(dāng)燒錄完成后拔掉跳線帽,Q3處于導(dǎo)通狀態(tài),芯片產(chǎn)生的喂狗脈沖WDI_GPIO可通過Q3傳遞到WDI引腳,實(shí)現(xiàn)正常喂狗,對(duì)應(yīng)的喂狗波形如下圖4所示。
圖4看門狗使能時(shí)喂狗波形
總結(jié)
下面簡(jiǎn)單匯總看門狗電路設(shè)計(jì)注意事項(xiàng)-
看門狗復(fù)位脈沖時(shí)長(zhǎng)要大于CPU的最少?gòu)?fù)位時(shí)間;
-
看門狗溢出周期要大于系統(tǒng)啟動(dòng)到加載看門狗驅(qū)動(dòng)時(shí)長(zhǎng),并留有一定的余量;
-
充分利用WDI引腳在高阻態(tài)時(shí)看門狗定時(shí)器功能禁用;
-
避免通過使能看門狗的電源來控制看門狗工作與否,否則會(huì)造成系統(tǒng)一直重啟,看門狗芯片上電后會(huì)輸出一個(gè)時(shí)長(zhǎng)200mS的POR信號(hào)。
關(guān)聯(lián)產(chǎn)品
技術(shù)交流群長(zhǎng)按識(shí)別如下二維碼可加入“工控板/核心板技術(shù)交流群”,與志同道合的朋友交流,并有專業(yè)技術(shù)人員為您答疑解惑,如有問題可以咨詢小致微信:zlgmcu-888。
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。
舉報(bào)投訴
原文標(biāo)題:【技術(shù)分享】"喂狗",也要講究方法
文章出處:【微信號(hào):ZLG_zhiyuan,微信公眾號(hào):ZLG致遠(yuǎn)電子】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
相關(guān)推薦
今天咋們要講的是SPI與4G模組的技術(shù)要領(lǐng),以低功耗模組Air724UG為例,展示給大家學(xué)習(xí)。
發(fā)表于 11-20 23:25
?99次閱讀
;: WDT.WDT_DEVICE_0})machine.WDT類為WDT對(duì)象提供了feed()方法,用于對(duì)WDT對(duì)象進(jìn)行喂狗操作,feed()方法如下所示:WDT.feed()feed()方
發(fā)表于 10-15 14:32
運(yùn)放輸入端不是以信號(hào)幅值為主嗎?為什么有些應(yīng)用輸入也要匹配到50Ω?
另外,對(duì)于AB類的MOSFET來說,如果負(fù)載需求的功率超過了它能提供的范圍,MOS管會(huì)怎樣?
發(fā)表于 09-24 07:08
工程師您好,請(qǐng)問雙極性運(yùn)放的同向輸入端也要提供偏置電流的工作點(diǎn)嗎,什么情況下可以直接加信號(hào)的輸入,而不用提供偏流電阻!謝謝
發(fā)表于 09-24 06:00
我用如下電路。
我想把兩路DA產(chǎn)生的兩個(gè)信號(hào)經(jīng)這個(gè)差分放大器放大。IC:THS4131
這THS4131空載也要消耗32mA 左右的電流,發(fā)熱嚴(yán)重。
當(dāng)然,當(dāng)有信號(hào)輸入的時(shí)候,它是可以放大信號(hào)的。
請(qǐng)問是這是什么原因?怎解決?
謝謝!!
發(fā)表于 08-30 07:07
我使用OPA567做了一個(gè)可調(diào)電源,電流限制已經(jīng)設(shè)定到最大。但是當(dāng)接上負(fù)載打開負(fù)載開關(guān)時(shí)總是容易報(bào)OCP,而且ocp_flag(PIN7)引腳一直在保持active狀態(tài).即便斷開負(fù)載還是會(huì)有這個(gè)flag.
問:是不是OCP flag active之后必須要講EN腳disable之后flag才會(huì)復(fù)位?
發(fā)表于 08-13 07:35
SPC582B的芯片,用SPC5Studio打開SWT后,哪一個(gè)是喂狗函數(shù)啊?還是要自己寫?
發(fā)表于 05-31 08:25
該專利主要講述如何通過特定方法優(yōu)化內(nèi)存管理效率,包括確定N個(gè)具有相同虛擬地址但權(quán)限各異的進(jìn)程(N必須為大于或等于2的整數(shù)),并據(jù)此建立特定映射關(guān)系表以及權(quán)限表,每一進(jìn)程均對(duì)應(yīng)一個(gè)權(quán)限表。
發(fā)表于 04-16 09:51
?381次閱讀
STM32_USB_Device_Library和STM32_USB_Host_Library。請(qǐng)問下,H750既要實(shí)現(xiàn)主機(jī),也要實(shí)現(xiàn)從機(jī)功能,要怎么實(shí)現(xiàn)呢?有什么資料可以參考下嗎?
發(fā)表于 03-19 06:46
這次的例子,主要講述如何基于PYTHON的 MQTT 客戶端的使用方法
發(fā)表于 03-14 11:45
?748次閱讀
為什么PWM模式輸出不能執(zhí)行喂狗操作,喂狗已初始化,Keil示波器顯示一秒中斷?
發(fā)表于 03-08 06:03
:
如果我在我的app1里面加入了看門狗, 我的app0沒有喂狗操作。 當(dāng)我的程序有app1跳轉(zhuǎn)到app0后,是否會(huì)因?yàn)椴?b class='flag-5'>喂狗而導(dǎo)致復(fù)位。 另外我的app1如果引起了看門狗復(fù)位,那么是復(fù)位到app0的入口開始執(zhí)行還是復(fù)位到app1的入口開始執(zhí)行。
發(fā)表于 02-21 06:50
開啟看門狗后不喂狗也不會(huì)出現(xiàn)復(fù)位的現(xiàn)象,用官方例程也是一樣的效果,有人遇到過這個(gè)情況嗎?
發(fā)表于 02-19 07:06
使用TC275CPU看門狗,定時(shí)器設(shè)為1.3秒,在不喂狗的情況下只能復(fù)位一次,然后再次復(fù)位時(shí),就直接死機(jī)了,程序不能重啟運(yùn)行。這是什么情況
發(fā)表于 02-05 07:10
開啟 INAPPMIC TLF 35584 看門狗(WWD),配置進(jìn)入 normal模式,在 normal中沒有喂狗,會(huì)讓 rot 產(chǎn)生 resetsentiSettiNoun 號(hào)嗎?現(xiàn)在不給狗喂東西的情況下,量化測(cè)試沒有重置信號(hào)產(chǎn)生,怎么能讓 rot 產(chǎn)生重置信號(hào)?
發(fā)表于 01-19 08:26
評(píng)論