0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

【技術(shù)分享】"喂狗",也要講究方法

AGk5_ZLG_zhiyua ? 來源:未知 ? 2023-07-21 11:55 ? 次閱讀
看似乖巧的看門狗,也有比較調(diào)皮的一面,在燒錄無法喂狗的特殊情況下仍會毫不留情的復(fù)位芯片,造成燒錄失敗,該如何避免這種情況的發(fā)生嗎?

8fc4744c-2779-11ee-962d-dac502259ad0.jpg??初識看門狗

嵌入式產(chǎn)品設(shè)備在電源瞬變、電磁干擾、靜電放電、極端溫濕度等復(fù)雜環(huán)境的干擾下可能會造成程序異常,從而使系統(tǒng)陷入癱瘓狀態(tài),這時候我們就希望設(shè)備能夠自動復(fù)位,而不需要人工干預(yù),看門狗定時器可以幫助捕獲和重置已經(jīng)“失控”的設(shè)備,實現(xiàn)無人值守,提高系統(tǒng)可靠性。看門狗又叫 watchdog timer,是一個定時器電路,一般有一個輸入端用來喂狗,一個輸出端RST接到芯片的復(fù)位引腳,芯片正常工作的時候,每隔一段時間輸出一個信號到喂狗端,給看門狗清零,如果超過規(guī)定的時間不喂狗,看門狗溢出,就會給出一個復(fù)位信號,拉低RST引腳使得芯片復(fù)位。ZL6300是廣州致遠微電子有限公司自行設(shè)計的一款集欠壓監(jiān)測復(fù)位、手動復(fù)位和超時復(fù)位功能的看門狗芯片,具有以下特性:
  • 上電復(fù)位脈沖200mS;
  • 支持手動復(fù)位;
  • 看門狗定時器溢出周期1.7S;
  • 低功耗僅9uA;
  • 欠壓復(fù)位。
8fd6b594-2779-11ee-962d-dac502259ad0.png

圖1 ZL6300內(nèi)部結(jié)構(gòu)

8fe50f40-2779-11ee-962d-dac502259ad0.jpg應(yīng)用電路

通過之前對看門狗的初步認識,好的看門狗設(shè)計可以大大提升產(chǎn)品的穩(wěn)定可靠性,我司基于該理念,核心板上均板載獨立看門狗,為適應(yīng)各種復(fù)雜環(huán)境保駕護航。下面以我司性能卓越的M3568核心板為例,看下它如何靈活設(shè)計看門狗電路,對應(yīng)的原理圖如下圖2所示,看門狗芯片選型ZL6300,支持手動按鍵復(fù)位和看門狗溢出復(fù)位,當(dāng)系統(tǒng)正常運行時從芯片上電啟動到加載看門狗喂狗驅(qū)動所需時長約為1S左右,ZL6300溢出周期為1.7S,可以在看門狗溢出周期內(nèi)及時喂狗清除定時器。

8ff11f88-2779-11ee-962d-dac502259ad0.png

圖2看門狗電路

當(dāng)芯片處于燒錄狀態(tài)時因內(nèi)核停止工作,喂狗程序不能正常運行,不能及時喂狗,看門狗溢出拉低芯片復(fù)位引腳,導(dǎo)致程序下載失敗。為應(yīng)對這種特殊情況,預(yù)留了跳線冒選項,插上短路帽即可禁用看門狗,當(dāng)J2插上短路帽時,WDO_EN被拉至低電平,Q1三級管處于關(guān)斷狀態(tài),WDI引腳處于高組態(tài),當(dāng)WDI引腳檢測到它處于高阻抗狀態(tài)時將產(chǎn)生自己的WDI脈沖,對應(yīng)的喂狗波形如下圖3所示。

9025c21a-2779-11ee-962d-dac502259ad0.png

圖3 看門狗禁能時喂狗波形

當(dāng)燒錄完成后拔掉跳線帽,Q3處于導(dǎo)通狀態(tài),芯片產(chǎn)生的喂狗脈沖WDI_GPIO可通過Q3傳遞到WDI引腳,實現(xiàn)正常喂狗,對應(yīng)的喂狗波形如下圖4所示。

904a52f6-2779-11ee-962d-dac502259ad0.png

圖4看門狗使能時喂狗波形

8fe50f40-2779-11ee-962d-dac502259ad0.jpg總結(jié)

下面簡單匯總看門狗電路設(shè)計注意事項
  • 看門狗復(fù)位脈沖時長要大于CPU的最少復(fù)位時間;

  • 看門狗溢出周期要大于系統(tǒng)啟動到加載看門狗驅(qū)動時長,并留有一定的余量;

  • 充分利用WDI引腳在高阻態(tài)時看門狗定時器功能禁用;

  • 避免通過使能看門狗的電源來控制看門狗工作與否,否則會造成系統(tǒng)一直重啟,看門狗芯片上電后會輸出一個時長200mS的POR信號。

8fe50f40-2779-11ee-962d-dac502259ad0.jpg關(guān)聯(lián)產(chǎn)品 8fe50f40-2779-11ee-962d-dac502259ad0.jpg技術(shù)交流長按識別如下二維碼可加入“工控板/核心板技術(shù)交流群”,與志同道合的朋友交流,并有專業(yè)技術(shù)人員為您答疑解惑,如有問題可以咨詢小致微信zlgmcu-888。90a4c434-2779-11ee-962d-dac502259ad0.png ?


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 致遠電子
    +關(guān)注

    關(guān)注

    13

    文章

    405

    瀏覽量

    31259

原文標題:【技術(shù)分享】"喂狗",也要講究方法

文章出處:【微信號:ZLG_zhiyuan,微信公眾號:ZLG致遠電子】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    《DNK210使用指南 -CanMV版 V1.0》第十七章 machine.WDT類實驗

    ;: WDT.WDT_DEVICE_0})machine.WDT類為WDT對象提供了feed()方法,用于對WDT對象進行喂狗操作,feed()方法如下所示:WDT.feed()feed()
    發(fā)表于 10-15 14:32

    運放輸入端不是以信號幅值為主嗎?為什么有些應(yīng)用輸入也要匹配到50Ω?

    運放輸入端不是以信號幅值為主嗎?為什么有些應(yīng)用輸入也要匹配到50Ω? 另外,對于AB類的MOSFET來說,如果負載需求的功率超過了它能提供的范圍,MOS管會怎樣?
    發(fā)表于 09-24 07:08

    請問雙極性運放的同向輸入端也要提供偏置電流的工作點嗎?

    工程師您好,請問雙極性運放的同向輸入端也要提供偏置電流的工作點嗎,什么情況下可以直接加信號的輸入,而不用提供偏流電阻!謝謝
    發(fā)表于 09-24 06:00

    THS4131空載也要消耗32mA左右的電流,發(fā)熱嚴重是什么原因?怎么解決?

    我用如下電路。 我想把兩路DA產(chǎn)生的兩個信號經(jīng)這個差分放大器放大。IC:THS4131 這THS4131空載也要消耗32mA 左右的電流,發(fā)熱嚴重。 當(dāng)然,當(dāng)有信號輸入的時候,它是可以放大信號的。 請問是這是什么原因?怎解決? 謝謝??!
    發(fā)表于 08-30 07:07

    SPC582B用SPC5Studio打開SWT后,哪一個是喂狗函數(shù)???

    SPC582B的芯片,用SPC5Studio打開SWT后,哪一個是喂狗函數(shù)啊?還是要自己寫?
    發(fā)表于 05-31 08:25

    華為專利公布:內(nèi)存管理方法及相關(guān)設(shè)備

    該專利主要講述如何通過特定方法優(yōu)化內(nèi)存管理效率,包括確定N個具有相同虛擬地址但權(quán)限各異的進程(N必須為大于或等于2的整數(shù)),并據(jù)此建立特定映射關(guān)系表以及權(quán)限表,每一進程均對應(yīng)一個權(quán)限表。
    的頭像 發(fā)表于 04-16 09:51 ?361次閱讀
    華為專利公布:內(nèi)存管理<b class='flag-5'>方法</b>及相關(guān)設(shè)備

    Raspberry Pi樹莓派使用Python實現(xiàn)MQTT通信設(shè)計

    這次的例子,主要講述如何基于PYTHON的 MQTT 客戶端的使用方法
    的頭像 發(fā)表于 03-14 11:45 ?735次閱讀
    Raspberry Pi樹莓派使用Python實現(xiàn)MQTT通信設(shè)計

    為什么PWM模式輸出不能執(zhí)行喂狗操作?

    為什么PWM模式輸出不能執(zhí)行喂狗操作,喂狗已初始化,Keil示波器顯示一秒中斷?
    發(fā)表于 03-08 06:03

    求助,關(guān)于看門狗定時器的喂狗時間和多APP看門狗的問題求解

    : 如果我在我的app1里面加入了看門狗, 我的app0沒有喂狗操作。 當(dāng)我的程序有app1跳轉(zhuǎn)到app0后,是否會因為不喂狗而導(dǎo)致復(fù)位。 另外我的app1如果引起了看門狗復(fù)位,那么是復(fù)位到app0的入口開始執(zhí)行還是復(fù)位到app1的入口開始執(zhí)行。
    發(fā)表于 02-21 06:50

    TLE9879開啟看門狗后不喂狗也不會出現(xiàn)復(fù)位的現(xiàn)象是為什么?

    開啟看門狗后不喂狗也不會出現(xiàn)復(fù)位的現(xiàn)象,用官方例程也是一樣的效果,有人遇到過這個情況嗎?
    發(fā)表于 02-19 07:06

    使用TC275 CPU看門狗,在不喂狗的情況下只能復(fù)位一次,然后再次復(fù)位時,就直接死機了是什么情況?

    使用TC275CPU看門狗,定時器設(shè)為1.3秒,在不喂狗的情況下只能復(fù)位一次,然后再次復(fù)位時,就直接死機了,程序不能重啟運行。這是什么情況
    發(fā)表于 02-05 07:10

    請問TC397 PMIC TLF35584看門狗在正常情況下沒有喂狗,會讓它重置信號嗎?

    開啟 INAPPMIC TLF 35584 看門狗(WWD),配置進入 normal模式,在 normal中沒有喂狗,會讓 rot 產(chǎn)生 resetsentiSettiNoun 號嗎?現(xiàn)在不給狗喂東西的情況下,量化測試沒有重置信號產(chǎn)生,怎么能讓 rot 產(chǎn)生重置信號?
    發(fā)表于 01-19 08:26

    RT-Thread Nano入門:獨立看門狗(IWDT)

    本文主要介紹怎么用RT-Thread Nano實現(xiàn)獨立看門狗IWDT驅(qū)動,創(chuàng)建一個喂狗線程,實現(xiàn)定時喂狗功能。
    的頭像 發(fā)表于 11-22 11:04 ?2093次閱讀
    RT-Thread Nano入門:獨立看門狗(IWDT)

    i.MX6ULL——ElfBoard ELF1板卡 在自啟腳本中打開看門狗,通過QT應(yīng)用來喂狗方法來啦

    修改看門狗源碼,設(shè)置了超時時間后,關(guān)閉/dev/dev/watchdog節(jié)點., 4.編譯之后,再次進行測試。(如何編譯應(yīng)用方法可以看一下之前發(fā)布的貼子哦) 在不啟動QT喂狗應(yīng)用時,系統(tǒng)超時60S重啟。 在啟動QT應(yīng)用后,不再報錯,能夠成功
    發(fā)表于 11-14 10:18

    嵌入式學(xué)習(xí)——ElfBoard ELF1板卡 在自啟腳本中打開看門狗,通過QT應(yīng)用來喂狗方法來啦

    修改看門狗源碼,設(shè)置了超時時間后,關(guān)閉/dev/dev/watchdog節(jié)點。 4.編譯之后,再次進行測試。(如何編譯應(yīng)用方法可以看一下之前發(fā)布的貼子哦) 在不啟動QT喂狗應(yīng)用時,系統(tǒng)超時60S重啟。 在啟動QT應(yīng)用后,不再報錯,能夠成功
    發(fā)表于 11-14 10:15