單片機編程:如何餵狗的靈魂拷問...

2021-02-13 工控網智造工程師

[導讀] 單片機程序寫辣麼多,看門狗狗天天見,你的狗狗養的對麼?不停的餵狗,只要狗不叫就完了嘛?真是這樣麼?事實上可能不是你想的辣麼簡單

啥叫看門狗?

看門狗也稱為看門狗定時器,本質上是一種定時電路或者軟體定時器機制。

工作原理:

看門狗的硬體基礎是一個計數器,該計數器被設置為某個定時初值,然後遞減至零。軟體負責經常將計數重置為其定時初值,以確保計數永遠不會達到零。如果確實達到零,則意味著某種故障發生,該採取對應措施應對,或重啟或進入失效安全狀態,具體取決於系統的設計。

正常工作時,單片機、處理器或者線程,周期性重置看門狗定時器的定時值,定時器則在後臺不斷的計數,如果定時時間到了且沒有再次餵狗,則狗叫,意味著一些不尋常的事情發生了!此時,狗狗對外發出指令,執行相應的動作。這裡所謂的動作究竟是什麼?取決於實際系統的設計。常見的看門狗晶片則會發出復位信號給單片機或者處理,對於軟體定時器而言,具體會有何種動作,則靈活多變,具體取決於採用何種安全策略。

通俗講也稱為餵狗,這個定時值相當於狗糧,狗狗吃飽了,胃裡不斷消耗狗糧,如果在消耗完之前沒有在餵狗糧,再狗狗餓得直叫喚,發出預警消息。反言之,一個一直正常工作的系統,其看門狗總是被餵養的很好,不會餓了狂叫。

註:看到有文章把重置看門狗定時器叫踢狗(kick watchdog),嗯嗯,這不太好,要對狗狗好一點,不要踢,叫餵吧~~~

看門狗機制在電子系統中作用非常之重要,這裡舉個極端的慄子,火星車如果程序掛了,就相當於失聯,如果沒有看門狗電路。你想像一下是什麼場景,無法通訊無法喚醒,秒變太空垃圾~~~

能看住哪些錯誤呢?
強電磁幹擾破壞數據導致系統異常,這你或許不好理解,你就想像一下軍事領域,或者航空航天領域很多電子系統,常工作在強電磁幹擾環境中

原因萬萬千,憋慌!你還有個好狗狗在幫你,讓看門狗來收拾殘局吧。在一個複雜的嵌入式系統中,不可能保證沒有bug,但是通過使用看門狗,您可以保證沒有任何bug會無限期地掛起系統。

狗叫後該咋整?

常見的處理策略有哪些呢?

系統復位,大多數人都有的體驗,系統掛了咋整,重啟。不由想起了劉歡的<<從頭再來>>,人生如能重啟該多好,然而並不能!有興趣的聽聽~~~失效安全,老外常叫fail-safe 模式。就是設備即使出現致命故障了,也別造成安全事故。粗魯點說,就是掛了,也不要影響他人。不易理解,舉個例子,一個正在下降的電梯,加入看門狗檢測到程序異常了,安全的做法是趕緊停止電機轉動,否則自由落體,就要涼涼啦。這在IEC61508 功能安全標準,或者醫療安全標準、汽車安全標準中都有體現。這裡描述一種推薦做法,晶片復位後,利用晶片復位狀態寄存器值,對看門狗復位事件計數,事不過三,如果連續三次此類復位,則保守做法就是將系統切換到安全狀態或顯示錯誤消息,這樣可以避免無限重新啟動。怎麼做呢?以IAR為例,可以定義一個變量不讓系統自動初始化(如IAR中叫,__no_init),實現計數,復位後其值仍然保存,除非斷電。__no_init int wdtResetCounter;

如果我們希望系統快速恢復,應該採用看門狗復位後的初始化比正常加電初始化短的策略。也就是說跳過設備的一些自檢。當然,在某些系統中最好進行全面自檢,因為看門狗超時的根本原因可能是通過此類硬體異常導致的。

具體咋餵狗呢?

對於裸機程序而言,我推薦了下面兩種處理策略:故障檢測式餵狗,故障檢測加強式餵狗。

故障檢測式餵狗

對於一個裸奔單片機程序而言,可以在餵狗時同時檢測一些關鍵的運行時狀態,比如棧深度、緩衝區、關鍵功能鏈的硬體(如傳感器、執行機構等),如這些狀態異常,則記錄錯誤狀態,將設備至於功能安全狀態。

故障檢測加強式餵狗

啥叫序列檢測式餵狗呢?IEC-61508中有種範式叫sequence check,有點邪乎?看下圖,你就馬上明了了。

將是將main函數的主體關鍵功能塊,設置一個序列標記,如果如果序列出錯就做安全故障處理,正確則繼續下一塊的執行。在餵狗的時候,看下序列是否正確,正確就喂,否則就做錯誤處理,或者乾脆讓狗叫也是一種方式。

對於多任務實時系統而言,有這樣一些不一樣的需求:

檢測由於高優先級任務佔用CPU而導致某些低優先級任務無法運行母狗帶群仔餵狗法

取這個名字有點俗了,哈哈哈。為了方便理解,就這麼叫吧,依然上個圖了再解釋吧:

實現策略描述

watchdogTask可看成狗窩,裡面住了一群狗,其中硬體看門狗是母狗,子任務軟體看門狗為小狗仔。每個子任務需要在每一個loop循環餵一次狗(當然實際實現時也可以加入任務故障檢測式餵狗),在watchdogTask每一個循環都對所有軟體看門狗遞減,如果溢出則軟狗叫了,需要做異常處理(復位或進入失效安全模式)。如果所有的軟體狗都沒有溢出,則餵硬體看門狗(可能是單片機內置或外置晶片)

實際實現時須注意:

每個loop應調用os_delay一定時間,以出讓CPU時間給其他task運行。掛起的時間應小於最大硬體看門狗延時時間。狗多久叫合理呢? 過短之痛

看門狗定時器定時時間設置過短,則系統容易誤判,可能會導致頻繁複位或進入失效安全模式。因為任何一條安全鏈的好壞取決於它最薄弱的一環,如果選擇一個太短的超時間隔。固件的循環時間是動態的,尤其外部的異步事件比較多,或者有中斷嵌套的情況,則波動會比較大,所以需要考慮最壞情況,系統循環一次要多久。

過長之害

一種方法是選擇一個幾秒鐘長的間隔。當您僅嘗試復位一個確實掛起的系統,但不希望對系統的時間進行詳細研究時,可以採用此策略。這是一個健壯的方法。但有些系統需要快速恢復,這就造成故障診斷過慢的危害了,尤其在一些對安全要求極高的場合,比如核電系統,汽車電子系統、醫療器械繫統等等。

所以實際設計時需要兼顧最壞情況下,儘量選擇相對較短的定時時長,在兩者中尋找一個平衡。

總結一下

對於單片機編程而言,其實對嵌入式Linux甚至在資料庫中,看門狗策略都有大量的應用,如何合理的使用看門狗,對於設計一個健壯的電子系統而言是非常重要的一個話題。

原創不易,如覺得本文對有價值,請點再看或者分享給身邊的小夥伴,讓人更多看到。

相關焦點

  • 單片機程式語言的比較
    引言  單片機又稱單片微控制器,它是把一個計算機系統,包括cpu、ram、rom、定時/計數器和多種i/o接口集成到一個晶片上。例如,懂得彙編語言指令就可以使用在片內ram作變量的優勢,因為片外變量需要幾條指令才能設置累加器和數據指針進行存取。同樣的,當要求使用浮點數和啟用函數時也只有具備彙編編程經驗才能避免生成龐大的、效率低的程序,對於這方面的編程,沒有彙編語言是做不到的。
  • 單片機編程軟體大佬:明確單片機編程軟體編寫單片機程序步驟
    單片機用什麼軟體編程?單片機開發中除必要的硬體外,同樣離不開軟體,我們寫的彙編語言源程序要變為CPU可以執行的機器碼有兩種方法,一種是手工彙編,另一種是機器彙編,目前已極少使用手工彙編的方法了。機器彙編是通過彙編軟體將源程序變為機器碼,用於MCS-51單片機的彙編軟體有早期的A51,隨著單片機開發技術的不斷發展,從普遍使用彙編語言到逐漸使用高級語言開發,單片機的開發軟體也在不斷發展,Keil軟體是目前最流行開發MCS-51系列單片機的軟體,這從近年來各仿真機廠商紛紛宣布全面支持Keil即可看出。
  • 單片機編程魔法之三權分立
    在單片機編程中,有很多人會因為一些貌似簡單的處理而把問題弄得亂七八糟,如林中蛛網一樣
  • 單片機模塊化編程的原則有哪些
    目前我們在學習和開發單片機時廣泛採用 c 語言進行編程,當我們開發的單片機項目較小時,或者我們所寫的練習程序很小時,我們總是習慣於將所有代碼編寫在同一個 c 文件下,由於程序代碼量較少,通常為幾十行或者上百行, 此時這種操作是可行方便的, 也沒有什麼問題。
  • 學單片機如何編程?非常詳細的Keil工程建立全過程講解
    在單片機的開發或使用過程中除了掌握必要的硬體外,同樣離不開軟體,只有通過軟體(程序)的執行,硬體才能發揮出具體的作用。機器如何認識我們用各種符號編寫的程序呢?早期我們寫的彙編語言源程序要變為CPU可以執行的機器碼有兩種方法,一種是手工彙編,另一種是機器彙編,目前已極少使用手工彙編的方法了。
  • 單片機C語言模塊化編程方法
    初學者往往搞不懂如何模塊化編程,其實它是簡單易學,而且又是組織良好程序結構行之有效的方法之一.本文將先大概講一下模塊化的方法和注意事項,最後將以初學者使用最廣的keil c編譯器為例,給出模塊化編程的詳細步驟。
  • 單片機科普:單片機的IO口不夠用了怎麼辦?如何擴展單片機的IO口
    單片機是一種可編程器件,在各種消費類電子、工業電子、汽車電子等行業應用廣泛,目前開發產品的構架就是以單片機為核心,根據不同的功能搭建不同的外設電路
  • 圖形化編程玩51單片機(十七)-數字鐘
    我們學習單片機的同學們,大家都想用自己學到的單片機知識來做一個有實用價值的電子產品。那麼數字鐘就是最好的首選。1,邏輯思維相對簡單,容易理解,比如:我們都知道60秒=1分鐘;60分鐘=1小時;24小時=1天,;所以,到了24小時清零,再循環就可以了。2,儘管邏輯相對簡單,但要運用我們單片機的多個器件的配合使用。
  • 嵌入式入門基礎:如何快速學習8051單片機
    了解單片機的工程師們都知道8051單片機是一款燒寫簡單、通用性廣泛且教程案例非常豐富的一款單片機。它只用通過宏晶的工具通過串口MAXRS232的TX、RX腳位就可以將程序燒錄到晶片,是一個非常不錯的嵌入式入門基礎單片機。本文介紹了關於8051單片機的學習基礎方法,希望能夠給初學者提供如何更快速的掌握嵌入式入門的基礎知識的方法。
  • 單片機的程式語言:彙編語言、C語言、PL/M和BASIC語言
    由於單片機的種種優點和特性,其應用領域極其廣泛。單片機系統同樣也由硬體系統和軟體系統構成,因此涉及到程序的編寫問題。單片機的程式語言很多,目前常見的程式語言有4種,即彙編語言、C語言、PL/M和BASIC語言。
  • 單片機的燒寫原理
    ↑ 點擊上方「電子工程專輯」輕鬆關注我要問的不是如何製作燒寫接口。
  • C語言和彙編語言在開發單片機時各有哪些優缺點?
    在校學生的話,實踐機會的確會比較少,但是有機會的話,可以畢業實習選擇相關的課題,這樣就可以接觸到實際的項目。而且如果單片機微機原理是一門主課的話,相信學校會安排比較多的實踐上機機會。有能力的話,可以找一些相關兼職工作做做,會更有幫助。而且單片機開發應用需要軟硬體結合,所以不能只滿足於編程技巧如何完美,平時也要注意硬體知識的積累,多上上電子論壇網站,買一些相關雜誌。
  • ARM7單片機輕鬆入門與實踐 — 暢學單片機
    本課程是ARM7單片機學習者從入門到深入的一套經典視頻教程,以初學者為對象,從零開始手把手教你學習單片機,循序漸進地基於理論講解並結合實驗項目實戰開發,講解當前最熱門的ARM7單片機的C程序設計!
  • 單片機簡介
    單片機簡介數字電路簡介在一個控制系統中, 單片機是電路的一部分, 單片機中的程序是針對其所在的電路編寫的。因此,要對單片機編程並實現一定的功能,必須了解整個系統的電路圖。單片機編程是針對某個特定的電路進行的單片機編程是針對某個特定的電路進行的, 這一點和普通的編程不一樣。 編程時很可能要經常參照電路圖。
  • 基於AT89S52單片機和ATF1508AS可編程邏輯器件實現LED顯示屏的硬體...
    本文詳細分析採用Verilog HDL對ATF1508AS進行編程,實現雙口RAM訪問和產生LED點陣驅動電路所需的各種時序信號。1 LED顯示屏的基本結構及關鍵技術 本系統設計中,控制系統採用單片機+CPLD的方案來實現,整個控制系統可分為:信號接收及處理模塊和CPLD的掃描控制模塊和LED點陣驅動模塊,如圖1 所示。
  • 如何設置單片機定時器?
    在單片機的學習過程中,單片機定時器的合理設置和應用是非常關鍵的一步,也是剛開始接觸單片機知識的新人工程師們比較容易出錯誤的一個環節之一
  • 單片機和PLC哪個更好上手?
    單片機是微型計算機系統,屬於微控制器的其中一種,PLC的全稱是可編程邏輯控制器,從名字上來看這二者肯定有相通之處,但又互相區別。單片機的確功能比PLC強大,但功能越強越廣,就意味著電路也會很複雜,,單片機的程式語言C語言或彙編語言相較於梯形圖來說,沒那麼容易懂。總而言之,想學單片機,你不僅得有計算機硬體基礎。還要會C語言編程,而且對電路這方面也要多多了解。接下來具體分析在這幾個方面的單片機和PLC的優劣勢。
  • 說說單片機的裸奔程序的框架!
    而且對MCU的編程控制會提升一個高度概況——就是對各種外圍進行控制(如果是對複雜算法的運算就會用DSP了),而外圍與MCU的通信方式一般也就幾種時序:IIC,SPI,intel8080,M6800。這樣看來MCU周圍的編程就是一個很簡單的東西了。
  • 閒說各家單片機的優缺點
    經常會在網上看到各家推廣單片機的人員宣傳他們代理的單片機,比如pic,avr,c8051等,當然從宣傳推廣的角度,總是要多說些他說宣傳推廣的單片機的優點,這樣才能讓眾多不是專家的工程師,學生,公司採購人員,老闆對其感興趣,進而受到誘惑而使用他們的單片機。
  • 單片機學習之二:單片機軟體使用簡明教程
    在我們開始單片機學習之前,我們有必要先來介紹一下單片機編程開發環境。我們現在常用的2種編程開發環境是:偉福WAVE和KEIL C軟體。我們這裡以大家最常用的KEIL C軟體為例,簡單介紹一下編程環境。