摘要:軟件抗干擾措施是硬件抗干擾措施的一個補(bǔ)充和延伸,運(yùn)用得法可以顯著提高工控系統(tǒng)的可靠性和智能,并且在一定程度上避免和減輕意外事故的發(fā)生。本文提出了實(shí)時控制軟件的自監(jiān)視法、互監(jiān)視法和常用方法等等一系列軟件抗干擾技術(shù)。
關(guān)鍵詞:計(jì)算機(jī);控制; 抗干擾;可靠性; 軟件
0 引言
工業(yè)現(xiàn)場各種動力設(shè)備在不斷地啟停運(yùn)行。使得現(xiàn)場環(huán)境惡劣,電磁干擾嚴(yán)">

      技術(shù)頻道

      工控計(jì)算機(jī)軟件抗干擾分析

      摘要:軟件抗干擾措施是硬件抗干擾措施的一個補(bǔ)充和延伸,運(yùn)用得法可以顯著提高工控系統(tǒng)的可靠性和智能,并且在一定程度上避免和減輕意外事故的發(fā)生。本文提出了實(shí)時控制軟件的自監(jiān)視法、互監(jiān)視法和常用方法等等一系列軟件抗干擾技術(shù)。
      關(guān)鍵詞:計(jì)算機(jī);控制; 抗干擾;可靠性; 軟件
      0 引言
      工業(yè)現(xiàn)場各種動力設(shè)備在不斷地啟停運(yùn)行。使得現(xiàn)場環(huán)境惡劣,電磁干擾嚴(yán)重。工業(yè)控制計(jì)算機(jī)在這樣的環(huán)境里面臨著巨大的考驗(yàn)。可以說我們研制的工業(yè)控制系統(tǒng)能否正常運(yùn)行,并且產(chǎn)生出應(yīng)有的經(jīng)濟(jì)效益,其抗干擾能力是一個關(guān)鍵的因素。因此,除了整個系統(tǒng)的結(jié)構(gòu)和每個具體的工控機(jī)都需要仔細(xì)設(shè)計(jì)硬件抗干擾措施之外,還需要注重軟件抗干擾措施的應(yīng)用。我們在多年的工業(yè)控制研究中,深感工業(yè)現(xiàn)場意外因素太多并且危害很大。有時一個偶然的人為或非人為干擾,例如并不很強(qiáng)烈的雷擊,就使得我們自認(rèn)為無懈可擊的硬件抗干擾措施無能為力,工控機(jī)死機(jī)了(即程序跑飛了)或者控制出錯了(此時CPU內(nèi)部寄存器內(nèi)容被修改或者RAM和I/O口數(shù)據(jù)被修改)。這在某些重要的工業(yè)環(huán)節(jié)上將造成巨大的事故。使用軟件抗干擾措施就可以在一定程度上避免和減輕這些意外事故的后果。軟件抗干擾技術(shù)就是利用軟件運(yùn)行過程中對自己進(jìn)行自監(jiān)視,和工控網(wǎng)絡(luò)中各機(jī)器間的互監(jiān)視,來監(jiān)督和判斷工控機(jī)是否出錯或失效的一個方法。這是工控系統(tǒng)抗干擾的最后一道屏障。
      1 工控計(jì)算機(jī)實(shí)時控制軟件運(yùn)行過程中的自監(jiān)視法
      自監(jiān)視法是工業(yè)控制計(jì)算機(jī)自己對自己的運(yùn)行狀態(tài)的監(jiān)視。
      某些類型的工控機(jī)CPU內(nèi)部具有Watchdog Timer,例如INTEL8098、80198系列,就可以方便的通過設(shè)定Watchdog工作方式以及采用合適的軟件編程的配合來達(dá)到自監(jiān)視目的。而沒有Watchdog Timer的CPU,例如Z80、8051系列等,當(dāng)然也可以通過外加Watchdog電路,再配以軟件完成自監(jiān)視目的。這種軟硬結(jié)合的自監(jiān)視法通常是很有效的,可以大幅度提高工控機(jī)的抗干擾能力。如果Watchdog電路設(shè)計(jì)得好,并且軟件也編制得好的話,不但可以及時發(fā)現(xiàn)程序跑飛,而且還可以實(shí)現(xiàn)“跑飛”程序修復(fù)。這是最好的自監(jiān)視手段。
      然而,這并不等于萬無一失。例如,① Watchdog電路本身失效;②設(shè)置Watchdog的指令正好在取指令時被干擾而讀錯;③ Watchdog“發(fā)現(xiàn)”程序跑飛之后,其產(chǎn)生的復(fù)位脈沖或者NMI申請信號正好被干擾而沒奏效等等。雖然以上的導(dǎo)致Watchdog失效的因素的幾率很小,但總是存在的。另一個方面,還有相當(dāng)數(shù)量的工業(yè)控制計(jì)算機(jī)沒有Watchdog電路。因此,以下重點(diǎn)討論的軟件自監(jiān)視法就勢在必行了。
      1.1 隨時監(jiān)督檢查程序計(jì)數(shù)器PC的值是否超出程序區(qū)
      計(jì)算機(jī)正常運(yùn)行,其PC值一定在程序區(qū)內(nèi)。如果PC值跑出程序區(qū),計(jì)算機(jī)肯定已發(fā)生了程序跑飛。檢查程序計(jì)數(shù)器PC值是否在程序區(qū)內(nèi)的方法,是在一個經(jīng)常要產(chǎn)生外部中斷的某個中斷服務(wù)程序中,讀取轉(zhuǎn)入該中斷時壓入堆棧的斷點(diǎn)地址。如果該地址在程序區(qū)內(nèi),則認(rèn)為PC值正常,否則一定是程序跑飛了。此時,程序跳轉(zhuǎn)到機(jī)器的重啟動入口或者復(fù)位入口,機(jī)器重新啟動。于是機(jī)器又自救活了。如果沒有一個這樣合適的中斷源,可以專門設(shè)置一個定時中斷或者幾個定時中斷,在中斷服務(wù)程序中檢查PC值是否合法,一旦發(fā)現(xiàn)不對就立即轉(zhuǎn)入機(jī)器的重啟動入口。定時器中斷的時間常數(shù),可視機(jī)器的繁忙程度和重要性設(shè)定,一般從幾個毫秒到幾十毫秒都可以。
      這個方法的局限性是不能查出PC值在程序區(qū)內(nèi)的亂跳,即此時PC值雖受干擾卻并沒有超出程序區(qū),而是錯位亂拼指令而構(gòu)成一些莫名其妙的操作,或者死循環(huán)。
      1.2 主循環(huán)程序和中斷服務(wù)程序相互監(jiān)視
      每個工控機(jī)的主循環(huán)程序和中斷服務(wù)程序都有一定的運(yùn)行規(guī)律可循。因此可以設(shè)計(jì)出主循環(huán)程序與各中斷服務(wù)程序、各中斷服務(wù)程序之間的相互監(jiān)視。每個監(jiān)視對要定義一個RAM單元,依靠對其計(jì)數(shù)/清零的方法表達(dá)相互監(jiān)視信息。例如,某工控機(jī)的主循環(huán)程序循環(huán)一次最長時間為80 ms,它的一個定時中斷時間常數(shù)為10 ms,當(dāng)我們安排該定時中斷監(jiān)視主循環(huán)程序運(yùn)行時,可以每次10 ms中斷對該RAM單元加1計(jì)數(shù),而主循環(huán)程序每循環(huán)一次對該RAM單元清零。因此,正常運(yùn)行時,這個監(jiān)視計(jì)數(shù)RAM單元的計(jì)數(shù)值不可能≥9,如果10 ms定時中斷服務(wù)程序發(fā)現(xiàn)其計(jì)數(shù)值≥9,就知道主循環(huán)程序已經(jīng)被干擾跑飛或出現(xiàn)死循環(huán),于是就跳轉(zhuǎn)到機(jī)器的重啟動入口,重新恢復(fù)運(yùn)行。使用這個方法,如果設(shè)計(jì)得當(dāng)?shù)脑挘欠浅S行У摹N覀兌嗄甑慕?jīng)驗(yàn)是:主循環(huán)程序被干擾跑飛可能性最大,中斷服務(wù)程序越短小越不易跑飛。主循環(huán)程序和中斷服務(wù)程序以及中斷服務(wù)程序之間的相互監(jiān)視,應(yīng)當(dāng)多設(shè)計(jì)幾個監(jiān)視對會更好。
      1.3 隨時校驗(yàn)程序代碼的正確性
      工業(yè)控制計(jì)算機(jī)的實(shí)時控制程序代碼通常都采用EPROM固化運(yùn)行,一般不易發(fā)生被改寫的情況。但成年累月運(yùn)行,我們有時也會發(fā)現(xiàn)極個別的單元出錯。其原因可能是芯片質(zhì)量問題或者因靜電、雷擊干擾等造成的改寫。程序出錯了,將直接造成運(yùn)行錯誤或者無法運(yùn)行。校驗(yàn)的方式可以采用累加和校驗(yàn)或者BCH校驗(yàn)(一種CRC校驗(yàn)方法)。當(dāng)采用BCH校驗(yàn)時,其分組附加的冗余字節(jié)可以集中在程序區(qū)之外的某個EPROM區(qū)域里。校驗(yàn)方法是在某個短小而且經(jīng)常發(fā)生的中斷服務(wù)程序內(nèi)安排一個校驗(yàn)?zāi)K,可以設(shè)計(jì)成每次循環(huán)校驗(yàn)一部分程序代碼,分若干次校驗(yàn)完成;或者當(dāng)代碼少,任務(wù)輕松時也可以一次校驗(yàn)完。如果發(fā)現(xiàn)校驗(yàn)錯,應(yīng)當(dāng)立即向工控網(wǎng)絡(luò)主站報告或者以自身報警的辦法告知操作人員,以便及時處理。這個方法的局限性是被損壞的程序代碼不是校驗(yàn)程序塊,而且以該中斷還可以正常響應(yīng)為前提。由于該中斷服務(wù)程序短小,通常還是有很大的概率自監(jiān)視程序代碼的正確性。
      1.4 隨時校驗(yàn)RAM的正確性
      RAM成年累月運(yùn)行,其質(zhì)量因素和接插件接觸因素都將導(dǎo)致其故障。這也將使控制系統(tǒng)發(fā)生錯誤。因此需要經(jīng)常監(jiān)視RAM的正確性。監(jiān)視的辦法可以安排在主循環(huán)程序,也可以安排在某個經(jīng)常要發(fā)生的中斷服務(wù)程序里。分幾次或者全部一次對RAM進(jìn)行檢查。檢查的方法是先把被檢查的RAM單元的內(nèi)容讀出,存放在某個通用寄存器里,然后對該單元寫入一個特定碼,再讀出比較,如果不正確就說明該單元可能損壞,此時要及時報告工控網(wǎng)絡(luò)主站或者自身報警,提醒操作人員處理。這個寫入的特定碼常用的是55H-AAH法,即寫入55H,再讀出比較,如果正確,再寫入AAH,再讀出比較,該組碼對每bit都有“0”、“1”寫入讀出檢驗(yàn),如果不正確時,最好再驗(yàn)證兩次才肯定校驗(yàn)結(jié)果。不管該單元是否有錯,校驗(yàn)之后都應(yīng)還回它的原始數(shù)據(jù),再報警或往下操作。使用這個方法要注意處理好各個中斷源的級別關(guān)系!
      2 實(shí)時控制系統(tǒng)的互監(jiān)視法
      一個分布式工控網(wǎng)絡(luò)或者重要環(huán)節(jié)的雙機(jī)熱備份運(yùn)行,都可以構(gòu)成軟件抗干擾的互監(jiān)視法。主從式的工控網(wǎng),主站和從站可以相互監(jiān)視運(yùn)行狀況,環(huán)形網(wǎng)的相鄰站或者全部站也都可以相互監(jiān)視運(yùn)行狀況,雙機(jī)熱備份運(yùn)行的兩工控機(jī),更應(yīng)該相互監(jiān)視。對于網(wǎng)絡(luò)型的各站間的相互監(jiān)視,主要是定時互相詢問和按要求回答,如果沒有按要求回答,則表示該站可能出問題(當(dāng)然也可能是網(wǎng)絡(luò)通信出問題),操作人員應(yīng)及時前往處理。最簡單的詢問和回答碼的設(shè)計(jì)是詢問方發(fā)出一組數(shù)字,回答方經(jīng)過某種簡單運(yùn)算,例如求反,再發(fā)回詢問方。這種相互監(jiān)視法可檢驗(yàn)被詢站是否死機(jī)以及校驗(yàn)通信網(wǎng)絡(luò)完好與否。而重要環(huán)節(jié)的雙機(jī)熱備份運(yùn)行的相互監(jiān)視則可做得很深入,除了這種詢問回答方式之外,還應(yīng)做到控制量是否正常的相互監(jiān)視,發(fā)現(xiàn)問題應(yīng)當(dāng)及時報警,通知值班人員處理。
      3 其它常采用的軟件抗干擾方法
      3.1 廣布陷井法
      以上論述的自監(jiān)視法和互監(jiān)視法都是建立在工控機(jī)能正確運(yùn)行全部或部分程序的基礎(chǔ)上的。有時一個意想不到的干擾,破壞了中斷和所有程序的正常運(yùn)行。此時PC值可能在程序區(qū)內(nèi),也可能在程序區(qū)之外,要使其能夠自恢復(fù)正常運(yùn)行,只有依賴于廣布“陷井”的絕招了。
      這里所謂的“陷井”,是指某些類型的CPU提供給用戶使用的軟中斷指令或者復(fù)位指令。例如,Z80指令RST 38H,其機(jī)器碼為FFH。CPU執(zhí)行該指令時,則將當(dāng)前程序計(jì)數(shù)器PC的值壓入堆棧,然后轉(zhuǎn)到0038H地址執(zhí)行程序。如果把0038H作為一個重啟動入口,則機(jī)器就可以恢復(fù)新的工作了。再例如,INTEL8098、80198系列的復(fù)位指令RST,機(jī)器碼也為FFH。CPU執(zhí)行該指令時,其內(nèi)部進(jìn)行復(fù)位操作,然后從2080H開始執(zhí)行程序。當(dāng)然,80198系列還有更多的非法操作碼可作為陷井指令使用,這時只需要在2012H的一個字的中斷矢量單元里安排中斷入口,并且編制一個處理非法操作碼的中斷服務(wù)程序,一遇非法操作碼就能進(jìn)行故障處理。作者多年的經(jīng)驗(yàn)表明,陷井不但需要在ROM的全部非內(nèi)容區(qū)、RAM的全部非數(shù)據(jù)區(qū)設(shè)置,而且在程序區(qū)內(nèi)的模塊之間廣泛布置。一旦機(jī)器程序跑飛,總會碰上陷井,立即就可以振救活機(jī)器了。
      3.2 重復(fù)功能設(shè)定法
      工控機(jī)的很多功能的設(shè)定,通常都是在主程序開始時的初始化程序里設(shè)定的,以后再也不去設(shè)定了。這在正常情況下本無問題。但偶然的干擾會改變CPU內(nèi)部的這些寄存器或者接口芯片的功能寄存器,例如,把中斷的類型、中斷的優(yōu)先級別、串行口、并行口的設(shè)定修改了,機(jī)器的運(yùn)行肯定會出錯,因此,只要重復(fù)設(shè)定功能操作不影響其當(dāng)前連續(xù)工作的性能,都應(yīng)當(dāng)納入主程序的循環(huán)圈里。每個循環(huán)就可以刷新一次設(shè)定,避免了偶然不測發(fā)生。對于那些重復(fù)設(shè)定功能操作會影響當(dāng)前連續(xù)工作性能的,要盡量想法找機(jī)會重新設(shè)定。例如串行口,如果接收完某幀信息或者發(fā)送完某幀信息之后,串口會有一個短暫的空閑時,就應(yīng)作出判斷并且安排重新設(shè)定一次的操作。
      3.3 重要數(shù)據(jù)備份法
      工控機(jī)中的一些關(guān)鍵數(shù)據(jù),應(yīng)當(dāng)有至少有兩個以上的備份副本,當(dāng)操作這些數(shù)據(jù)時,可以把主、副本進(jìn)行比較,如其改變,就要分析原因,采取預(yù)先設(shè)計(jì)好的方法處理。還可以把重要數(shù)據(jù)采用校驗(yàn)和或者分組BCH校驗(yàn)的方法進(jìn)行校驗(yàn)。這兩種方法一并使用則更可靠。
      4 結(jié)束語
      軟件抗干擾的內(nèi)容還有很多,例如,檢測量的數(shù)字濾波、壞值剔除;人工控制指令的合法性和輸入設(shè)定值的合法性判別等等,這些都是一個完善的工業(yè)控制系統(tǒng)必不可少的。
      工業(yè)控制是計(jì)算機(jī)的最重要的應(yīng)用領(lǐng)域,也是計(jì)算機(jī)的最艱難的應(yīng)用環(huán)境。我從多年來的研究經(jīng)驗(yàn)認(rèn)為:工業(yè)控制計(jì)算機(jī)的抗干擾性能根本在硬件結(jié)構(gòu),軟件抗干擾只是一個補(bǔ)充。硬件的設(shè)計(jì)應(yīng)當(dāng)盡可能的完善,不能輕易降低標(biāo)準(zhǔn),讓軟件去補(bǔ)救!而軟件的編制則要處處考慮到硬件可能的失效,可能受到的干擾等種種問題,在保證實(shí)時性、控制精度和控制功能的前提下,盡力提高系統(tǒng)的抗干擾性能。要考慮得很細(xì)致,努力賦予軟件高度的智能。這樣,軟件才是完美的。把硬件和軟件有機(jī)的結(jié)合起來,一個經(jīng)得起長期現(xiàn)場考驗(yàn)的盡可能完善的工業(yè)控制系統(tǒng)才能實(shí)現(xiàn)。

      文章版權(quán)歸西部工控xbgk所有,未經(jīng)許可不得轉(zhuǎn)載。

      主站蜘蛛池模板: 无码一区二区三区免费| 国产高清一区二区三区| 亚洲国产一区二区三区青草影视| 少妇人妻精品一区二区三区| 激情啪啪精品一区二区| 伊人色综合网一区二区三区 | 亚洲一本一道一区二区三区| 一区二区三区国产| 区三区激情福利综合中文字幕在线一区 | 国产在线精品一区二区中文 | 亚洲一区在线视频观看| 成人精品一区二区三区不卡免费看| 日韩伦理一区二区| 亚洲日韩AV一区二区三区四区 | 亚洲一区二区三区国产精华液| 亚洲熟妇av一区二区三区下载| 末成年女AV片一区二区| 日本午夜精品一区二区三区电影| 亚洲av鲁丝一区二区三区 | 亚洲av色香蕉一区二区三区蜜桃 | 黑人一区二区三区中文字幕| 亚洲av无一区二区三区| 日韩一区二区超清视频| 亚洲欧洲专线一区| 国产精品成人一区无码| 国产MD视频一区二区三区| 精品一区二区三区视频在线观看| 99偷拍视频精品一区二区| 国产综合精品一区二区| 一区视频免费观看| 熟妇人妻一区二区三区四区| 国精产品一区一区三区免费视频| 国产激情无码一区二区| 中文字幕一区二区三区在线观看 | 日韩a无吗一区二区三区| 立川理惠在线播放一区| 一区国严二区亚洲三区| 精品一区二区三区在线观看l | 亚洲日韩中文字幕一区| 国产主播一区二区三区在线观看| 精品成人一区二区三区免费视频|