當前位置:首頁 > 單片機 > 單片機
[導讀]前面幾項抗干擾措施都是針對I/O通道而言的。若干擾信號還未作用到CPU本身,則CPU還能正確地執(zhí)行各種抗干擾程序;若干擾信號已經(jīng)通過某種途徑作用到CPU上,則CPU就不能按正常狀態(tài)執(zhí)行程序,從而引起混亂,這就是通常所說的程序“跑飛”。程序“跑飛”后使其恢復正常最簡單的方法是讓CPU復位,讓程序從頭開始重新運行。這種方法雖然簡單,但需要人的參與,而且復位不及時。人工復位一般是在整個系統(tǒng)已經(jīng)癱瘓,無計可施的情況下才不得已而為之的。因此在進行軟件設計時就要考慮到萬一程序“跑

一、程序“跑飛”

前面幾項抗干擾措施都是針對I/O通道而言的。若干擾信號還未作用到CPU本身,則CPU還能正確地執(zhí)行各種抗干擾程序;若干擾信號已經(jīng)通過某種途徑作用到CPU上,則CPU就不能按正常狀態(tài)執(zhí)行程序,從而引起混亂,這就是通常所說的程序“跑飛”。程序“跑飛”后使其恢復正常最簡單的方法是讓CPU復位,讓程序從頭開始重新運行。這種方法雖然簡單,但需要人的參與,而且復位不及時。人工復位一般是在整個系統(tǒng)已經(jīng)癱瘓,無計可施的情況下才不得已而為之的。因此在進行軟件設計時就要考慮到萬一程序“跑

第9章單片機系統(tǒng)的抗干擾技術165

飛”,應讓其能夠自動恢復到正常狀態(tài)下運行。

二、指令冗余

程序“跑飛”后往往將一些操作數(shù)當作指令碼來執(zhí)行,從而引起整個程序的混亂。采用“指令冗余”是使“跑飛”的程序恢復正常的一種措施。所謂“指令冗余”,就是在一些關鍵的地方人為地插入一些單字節(jié)的空操作指令NOP。當程序“跑飛”到某條單字節(jié)指令上時,就不會發(fā)生將操作數(shù)當成指令來執(zhí)行的錯誤。對于MCS 51單片機來說,所有的指令都不會超過3個字節(jié),因此在某條指令前面插入兩條NOP指令,則該條指令就不會被前面沖下來的失控程序拆散,而會得到正確的執(zhí)行,從而使程序重新納入軌道。通常是在一些對程序的流向起關鍵作用的指令前插入兩條NOP指令,這些指令有RET、RETI、ACALL、LCALL、SJMP、AJMP、JZ、JNZ、JC、JNC、JB、JNB、JBC、CJNZ、DJNZ等。在某些對系統(tǒng)工作狀態(tài)至關重要的指令(如SETBEA之類)前也可插入兩條NOP指令,以保證被正確執(zhí)行。值得注意的是,在一個程序中“指令冗余”不能過多,否則會降低程序的執(zhí)行效率。

三、軟件陷阱

采用“指令冗余”,使“跑飛”的程序恢復正常是有條件的,首先“跑飛”程序必須落到程序區(qū),其次必須執(zhí)行到所設置的冗余指令。如果“跑飛”的程序落到非程序區(qū)(如EPROM中未用完的空間或某些數(shù)據(jù)表格區(qū)等),或在執(zhí)行到冗余指令前已經(jīng)形成一個死循環(huán),則“指令冗余”措施就不能使“跑飛”的程序恢復正常了。這時可采用另一個抗干擾措施,即“軟件陷阱”?!败浖葳濉笔且粭l引導指令,強行將捕獲的程序引向一個指定的地址,在那里有一段專門處理錯誤的程序。假設這段處理錯誤的程序入口地址為ERR,則下面三條指令即組成一個“軟件陷阱”:

NOP

NOP

LJMP ERR

“軟件陷阱”一般安排在下列四種地方。

1.未使用的中斷向量區(qū)

MCS 51單片機的中斷向量區(qū)為0003H~002FH,如果系統(tǒng)程序未使用完全部中斷向量區(qū),則可在剩余的中斷向量區(qū)安排“軟件陷阱”,以便能捕捉到錯誤的中斷。如某系統(tǒng)使用了兩個外部中斷INT0、INT1和一個定時器溢出中斷T0,它們的中斷服務子程序入口地址分別為FUINT0、FUINT1和FUT0,即可按下面的方式來設置中斷向量區(qū):

2.未使用的大片EPROM空間

程序一般都不會占用EPROM芯片的全部空間,對于剩余未編程的EPROM空間,一般都維持原狀,即其內(nèi)容為0FFH。0FFH對于MCS 51單片機的指令系統(tǒng)來說是一條單字節(jié)的指令:MOV R7,A。如果程序“跑飛”到這一區(qū)域,則將順利向后執(zhí)行,不再跳躍(除非又受到新的干擾)。因此在這段區(qū)域內(nèi)每隔一段地址設一個陷阱,就一定能捕捉到“跑飛”的程序。

3.表格

有兩種表格:一類是數(shù)據(jù)表格,供MOVCA,@A+PC指令或MOVCA,@A+DPTR指令使用,其內(nèi)容完全不是指令。另一類是散轉(zhuǎn)表格,供JMP@A+DPTR指令使用,其內(nèi)容為一系列的3字節(jié)指令LJMP或2字節(jié)指令AJMP。由于表格的內(nèi)容與檢索值有一一對應的關系,在表格中間安排陷阱會破壞其連續(xù)性和對應關系,因此只能在表格的最后安排陷阱。如果表格區(qū)較長,則安排在最后的陷阱不能保證一定能捕捉“跑飛”來的程序,有可能在中途再次“跑飛”,這時只能指望別處的陷阱或冗余指令來捕捉。

4.程序區(qū)

程序區(qū)是由一系列的指令構成的,不能在這些指令中間任意安排陷阱,否則會破壞正常的程序流程。但是,在這些指令中間常常有一些斷點,正常的程序執(zhí)行到斷點處就不再往下執(zhí)行了,這類指令有LJMP、SJMP、AJMP、RET、RETI,這時PC的值應發(fā)生正常跳變。如果在這些地方設置陷阱就有可能捕捉到“跑飛”的程序。例如,對一個累加器A的內(nèi)容的正、負和零的情況進行三分支的程序,軟件陷阱安排如下:

由于軟件陷阱都安排在正常程序執(zhí)行不到的地方,故不會影響程序的執(zhí)行效率。在EPROM容量允許的條件下,這種軟件陷阱多一些為好。

四、WATCHDOG

如果“跑飛”的程序落到一個臨時構成的死循環(huán)中,冗余指令和軟件陷阱都將無能為力,這時可采取WATCHDOG(俗稱“看門狗”)措施。

WATCHDOG有如下特性:

(1)本身能獨立工作,基本上不依賴于CPU。CPU只在一個固定的時間間隔內(nèi)與之打一次交道,表明整個系統(tǒng)“目前尚屬正常”。

(2)當CPU落入死循環(huán)后,能及時發(fā)現(xiàn)并使整個系統(tǒng)復位。

在8096系列單片機和增強型8051系列單片機中,已將該系統(tǒng)做入芯片里,使用起來很方便。而在普通型8051系列單片機系統(tǒng)中,必須由用戶自己建立。如果要達到WATCHDOG的真正目標,該系統(tǒng)必須包含一定的硬件電路,它完全獨立于CPU之外。如果為了簡化電路,也可采用純軟件的WATCHDOG系統(tǒng)。

WATCHDOG硬件電路為一獨立于CPU之外的單穩(wěn)部件,可用單穩(wěn)電路構成,也可用自帶脈沖源的計數(shù)器構成。CPU正常工作時每隔一段時間就輸出一個脈沖,將單穩(wěn)系統(tǒng)觸發(fā)到暫穩(wěn)態(tài),當暫穩(wěn)態(tài)的持續(xù)時間設計得比CPU的觸發(fā)周期長時,單穩(wěn)態(tài)系統(tǒng)就不能回到穩(wěn)態(tài)。當CPU陷入死循環(huán)后,再也不去觸發(fā)單穩(wěn)系統(tǒng)了,單穩(wěn)系統(tǒng)便可順利返回穩(wěn)態(tài),利用它返回穩(wěn)態(tài)時輸出的信號作為復位信號,便可使CPU退出死循環(huán)。

圖9.12所示為采用硬件電路組成的WATCHDOG。十六進制計數(shù)器對振蕩電路發(fā)出的脈沖計數(shù),當計到第8個脈沖時Q端變成高電平。單片機執(zhí)行一個從P1.7輸出清零脈沖的固定程序,只要每一次清零脈沖的時間間隔小于8個振蕩脈沖周期,計數(shù)器就總計不到8,QD端就一直保持低電平。如果CPU受到干擾使程序“跑飛”,就無法執(zhí)行這個發(fā)出清零脈沖的固定程序,計數(shù)器就會計數(shù)到8,使QD端變成高電平,經(jīng)微分電路C2、R3輸出一個正脈沖到單片機8031的RESET端,使CPU復位。此電路中還包括:上電復位(C1、R1)和人工復位(KA,R1,R2)兩部分。

圖9.12硬件WATCHDOG電路

也可以用軟件程序來形成WATCHDOG。例如,可以采用8031的定時器T0來形成WATCHDOG。將T0的溢出中斷設為高優(yōu)先級中斷,其它中斷均設置為低優(yōu)先級中斷,若采用6 MHz的時鐘,則可用以下程序使T0定時約10ms來形成軟件WATCHDOG:

軟件WATCHDOG啟動后系統(tǒng)工作程序必須每隔小于10 ms的時間執(zhí)行一次MOV TH0,#0E0H指令,重新設置T0的計數(shù)初值。如果程序跑飛后執(zhí)行不到這條指令,則在10ms之后即會產(chǎn)生一次T0溢出中斷,在T0的中斷向量區(qū)安放一條轉(zhuǎn)移到出錯處理程序的指令LJMPERR,由出錯處理程序來處理各種善后工作。采用軟件WATCHDOG有一個弱點,就是如果“跑飛”的程序使某些操作數(shù)變成了修改T0功能的指令,則執(zhí)行指令后軟件WATCHDOG就會失效,因此軟件WATCHDOG的可靠性不如硬件高。

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

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

關鍵字: 阿維塔 塞力斯 華為

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

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

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

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

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

關鍵字: 亞馬遜 解密 控制平面 BSP

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

關鍵字: 騰訊 編碼器 CPU

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

關鍵字: 華為 12nm EDA 半導體

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

關鍵字: 華為 12nm 手機 衛(wèi)星通信

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

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

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

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

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

關鍵字: BSP 信息技術
關閉