1 引言 Philips公司的8XC552單片機以其體積小、功能強、價格低等優(yōu)勢而廣泛地使用在工業(yè)控制、DCS控制和智能儀器等領域。筆者在智能配電監(jiān)測儀的研制過程中,雖然采取了相應的抗干擾措施,但由于工業(yè)現(xiàn)場環(huán)境中電磁場、電網(wǎng)尖峰、諧波、浪涌及雷電輻射等影響,仍有可能出現(xiàn)程序死循環(huán)、跑飛等失控現(xiàn)象。為此,筆者采用Watchdog技術保證了系統(tǒng)的正常運行,通常Watchdog技術在單片機應用系統(tǒng)中可分為軟件Watchdog和硬件Watchdog。Philips公司的8XC552、Intel的8098、Motorala的68C05以及Microchip的16C5X系列單片機本身已帶有軟件Watchdog功能,因此,只要硬件接法正確,在軟件設計中調(diào)用相應語句進行啟動即可。 2 硬件組成原理 2.1系統(tǒng)工作原理 圖1所示是87C522單片機用于智能型配電儀的連接電路,本智能配電儀中的87C552為主控芯片,該芯片除具有三個16位定時器T0、T1及T2外,還有一個專作監(jiān)視8位定時器、簡稱WDT(WatchdogTimer)的T3定時器。因為微控制器有時會受噪音、射頻干擾等環(huán)境因素的影響而導入錯誤的運行狀態(tài)。監(jiān)視定時器的功能就是在某特定的時限內(nèi)使微控制器復位,從而將其從錯誤的狀態(tài)中恢復過來以重新開始正常運行。當T3用作Watchdog定時器并由軟件啟動計時后,如果系統(tǒng)已達到所設定的預定時間而仍沒有重新啟動定時器,此時就會產(chǎn)生溢出信號并停止計時,表明系統(tǒng)出現(xiàn)異常。CPU可以對定時器重新啟動、清零、設定計時值等操作。系統(tǒng)正常運行時,CPU將周期性地重新啟動定時器,當然其啟動周期應小于定時器的設定值,以保證定時器始終不能產(chǎn)生溢出信號。而當系統(tǒng)運行不正常時,由于CPU不能周期性地啟動定時器,因而定時器將產(chǎn)生溢出信號,以強迫CPU恢復系統(tǒng)的正常運行。 2.2 Watchdog的內(nèi)部結構原理 監(jiān)視定時器的結構原理如圖2所示。它的核心為一8位定時器,其前級是一個11位定標器。后者的輸入信號為fosc/12,即定標器對機器周期進行遞增計數(shù)。這樣,每過2個機器周期,定時器T3的值便增加1000次。若用16MHz或24MHz晶體振蕩器,則監(jiān)視定時器的增值間隔將分別為1.536ms和1.024ms;其相應的最大溢出周期分別為393.216ms和262.144ms。 當監(jiān)視定時器溢出時,系統(tǒng)將產(chǎn)生一個內(nèi)部復位脈沖以使8XC552復位。由圖2可以看出,T3溢出時,RST引腳內(nèi)側(cè)的晶體管因柵極出現(xiàn)一個負脈沖而瞬時導通,從而在RST引腳上輸出一個復位正脈沖,其寬度為3個機器周期。如果RST引腳外接電容,則這么窄的輸出脈沖可能遭到破壞,因為電容不允許RST引腳電壓產(chǎn)生突變,但這不會影響到內(nèi)部復位操作。 如果將8XC552的 如果 3 調(diào)試中的常見問題及其解決方法 在對系統(tǒng)進行調(diào)試時,有可能出現(xiàn)閃屏、無法顯示以及顯示雜亂等現(xiàn)象,現(xiàn)將這些問題的解決方法介紹如下: (1)LCD出現(xiàn)閃屏,無法翻屏顯示現(xiàn)象 筆者在用仿真器運行編程時,LCD能夠翻屏并不斷顯示采集來的三相用電參數(shù),但離開仿真器處于脫機運行狀態(tài)時,LCD只能顯示第一屏數(shù)據(jù)。經(jīng)查仿真器的 (2)LCD無顯示 RST端的電容應確保連接正確,否則在高電平時將無法加到復位端而使CPU不能運行程序,從而出現(xiàn)LCD無顯示的現(xiàn)象。 (3)LCD顯示數(shù)據(jù)雜 亂無章、數(shù)據(jù)死鎖把 4 軟件設計 4.1軟件設計 編寫監(jiān)視定時器運行軟件時,程序員首先應當確定系統(tǒng)能夠在錯誤狀態(tài)下支持的時間,也就是設定溢出周期的依據(jù)。例如能維持16ms,則把T3的初值設定為10,這樣,在16MHz晶振的情況下,溢出周期為15.36ms。此時程序員就可對其軟件進行劃分,以確定把重寫T3值的指令插在什么地方,才能使相鄰兩次重寫操作間隔不超過監(jiān)視定時器的溢出周期,以保證正常運作時T3不溢出。因此,程序員應當了解所有軟件模塊的執(zhí)行時間,同時也要考慮到出現(xiàn)條件跳轉(zhuǎn)、子程序及內(nèi)外中斷等因素所帶來的影響。對于那些很難估算其執(zhí)行時間的程序段落,應按最壞情況估算。為防止誤寫,監(jiān)視定時器值的重寫可分兩步進行。首先將PCON.4(監(jiān)視定時器裝入允許位WLE)置1,以允許對T3進行寫入;第二步向T3寫入新值。由圖2可知,對T3的寫信號同時也會加到WLE的清0端,于是每當T3被寫入新值時,WLE位便自動復位。因此,當該值為00H時,溢出間隔最大;而FFH值則對應最小溢出周期。若采用12MHz晶振,這兩值則分別為524ms和2ms。最大和最小溢出周期的計算公式分別為: 由于在空閑方式下,監(jiān)視定時器照常運行。因此,該方式與掉電方式是矛盾的,因為前者需要時鐘,后者凍結時鐘。故當 4.2 定時間隔和訪問時間的設定 數(shù)據(jù)采集及處理是程序中的關鍵部分,也是決定儀器精度的關鍵所在。本儀器采用電壓、電流、頻率、相位為主要采集參數(shù),且這些參數(shù)是連續(xù)變化的,因此采樣時間不宜設置得過長,否則會影響儀器的精度。筆者將電流與電壓的采樣時間定為5ms,頻率與相位的采集時間為20ms,這樣,Watchdog的定時間隔設置較佳,具體如圖3所示。圖3中,Watchdog在WDT1時間內(nèi)完成對采集頻率數(shù)據(jù)的監(jiān)控,而在WDT2、WDT3、WDT4內(nèi)分別負責對電壓、電流、相位數(shù)據(jù)采集的監(jiān)控。在設計程序時,一般取1.1Ts<Tw<2Ts,其中Ts為采樣周期,Tw為Watchdog的定時時間,Ts分別為T1、T2、T3、T4的大小,Tw分別為WDT1、WDT2、WDT3、WDT4的大小。Tw設置太小會增加訪問頻率,影響程序執(zhí)行效率;而設置太大則會干擾程序的正常運行,且需等待很長時間才可以恢復運行,而采集或控制對象可能已在這一步偏離過大。因此,CPU訪問時間原則上小于Tw就可以了,為防止時間估計不準,設計時應小些為好,這樣可以防止系統(tǒng)異常而處于每經(jīng)過Tw時間啟動一次的死循環(huán)中。 4.3 軟件程序 本智能監(jiān)控儀用C語言編寫程序,并采用12MHz晶振時,其溢出時間應分別設置為6ms、20ms、524ms…,這樣,在源程序中應適時加入的各Watchdog程序如下: 5 結束語 在智能配電儀的源程序中加入Watchdog后,其整個系統(tǒng)運行將更加穩(wěn)定、可靠,從而有效地克服了來自工業(yè)用電現(xiàn)場的各種干擾。 |