www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 嵌入式 > 嵌入式硬件
[導讀]引言嵌入式軟件開發(fā)往往缺乏必要的調(diào)試工具和調(diào)試手段,同時需要有較高的容錯處理能力,程序正常運行過程中盡量不因為出現(xiàn)異常而導致系統(tǒng)停止。一旦發(fā)生錯誤或異常,開發(fā)人

引言

嵌入式軟件開發(fā)往往缺乏必要的調(diào)試工具和調(diào)試手段,同時需要有較高的容錯處理能力,程序正常運行過程中盡量不因為出現(xiàn)異常而導致系統(tǒng)停止。一旦發(fā)生錯誤或異常,開發(fā)人員需要盡量多的錯誤環(huán)境信息來查找問題的原因。從程序編寫的角度來講,一般嵌入式軟件都采用C語言開發(fā)。C語言本身的特點決定了無法利用語言本身的功能實現(xiàn)對異常的跟蹤與處理,只能通過良好的編程模型與習慣,以及后期的大量測試,來發(fā)現(xiàn)和解決異常。因此,如何進一步提升程序開發(fā)中的可調(diào)試性,對于運行中的異常如何保存現(xiàn)場,從而方便進行異常追蹤等,是開發(fā)者需要考慮的重要問題。本文針對嵌入式C語言開發(fā)的特點,提出一種基于堆棧模式的異常追蹤編程模型,能夠?qū)崿F(xiàn)有效的異常現(xiàn)場保存與恢復,并為后期的問題分析與解決打好基礎(chǔ)。同時,本文所提出的思路亦可作為實際運行階段提升可調(diào)試性的一種手段應用于嵌入式軟件編程中,最大限度實現(xiàn)對于異常發(fā)生環(huán)境的保存與定位,提升系統(tǒng)的可維護性。

1 建立全局錯誤代碼表

對于嵌入式軟件來說,盡量節(jié)省內(nèi)存資源、降低程序代碼量是十分重要的。因此,將程序中所有錯誤、異常情況都進行了統(tǒng)一編碼,提高了錯誤處理代碼的規(guī)范化與可讀性。設(shè)計8位整數(shù)編碼格式如下:

 

每個錯誤代碼在程序中僅需要1個字節(jié)進行存儲。對于程序中每個可能異常的地方(如COM1沒打開),都設(shè)定1個唯一編號,當出現(xiàn)錯誤或異常時根據(jù)該編號可以直接定位到源程序?qū)募统绦蚨危⒋_定錯誤類型。

采用錯誤代碼的形式存儲錯誤信息,不僅可以精確描述錯誤的類型、位置等信息,還可以最大限度地節(jié)省寶貴的可執(zhí)行內(nèi)存資源,降低程序?qū)?nèi)存的需求。

2 建立全局異常堆棧

在一個復雜的嵌入式實時系統(tǒng)中,程序處理流程復雜,不同資源之間往往在操作上存在著交叉。當出現(xiàn)程序錯誤或異常時,不能簡單地退出程序,而是應當盡量將錯誤處理掉,實在無法處理的錯誤應進行記錄,但整個程序的運行不應當中斷。對此,使用1個錯誤堆棧來保存錯誤信息。該棧用下面數(shù)組定義:

 

ERROR_STACK為全局錯誤棧類型定義,MainErrStack為全局棧實例,其元素個數(shù)由ERR_STACK_SIZE確定。 ErrorParm為字符數(shù)組,當錯誤發(fā)生時可以依次保存函數(shù)的人口參數(shù)以及異常發(fā)生之前局部變量的值等。實際數(shù)組長度ERR_ENV_LEN可以根據(jù)情況調(diào)整,一般情況下開發(fā)階段可以設(shè)置大一些,保證存放更多的錯誤信息用于調(diào)試;進入實際運行階段可以適當縮小該錯誤環(huán)境棧長度,減少內(nèi)存空間的占用。

為了確保錯誤處理機制本身不會給程序引入新的異常,因此將堆棧的操作完全封裝為Push和Pop兩個函數(shù),并引入當前堆棧指針stackCu- rrentPos(初始為一1表示堆棧為空,有效取值范圍為一1~ERR_STlACK_SIZE一1,該指針始終指向棧頂元素)。算法說明如下:

 

3 建立統(tǒng)一的錯誤描述字典表

為了進一步提高代碼規(guī)范化程度并降低內(nèi)存需求,可以將每種類型的錯誤定義一個錯誤描述保存在單獨的文件或緩沖區(qū)中。當發(fā)生錯誤時,系統(tǒng)根據(jù)錯誤代碼取出該錯誤的詳細描述并顯示給用戶。以上操作可以封裝為ShowErrorMessage函數(shù),定義為Char*ShowErrorMessage(int errorId)。在錯誤發(fā)生位置并不直接描述錯誤信息的方法,不僅可以降低可執(zhí)行內(nèi)存需求,而且避免了由于不同開發(fā)者對錯誤文字描述的差異而導致對用戶的提示信息不統(tǒng)一。例如錯誤提示“數(shù)組越下界!代碼:53017010”,530即表示數(shù)組越下界異常,17表示編號為“17”的C源程序文件,010表示文件中第10個錯誤位置。部分錯誤代碼描述示例如表1所列。

 

4 應用說明

下面以1個簡單的例子來說明本文方法的運行。假設(shè)程序需要提供1個通過GPRS發(fā)送數(shù)據(jù)的函數(shù) GprsSendData(char*ip,char*buf,int size),實現(xiàn)將buf緩沖區(qū)指定長度為size的字符串通過TCP方式發(fā)送到給定IP地址。示例代碼如下:

 

由上面可以看出,可能出現(xiàn)錯誤的位置都加入了錯誤壓棧操作,當GprsSendData函數(shù)的返回值為假時,上級調(diào)用函數(shù)會繼續(xù)將其異常時的運行狀態(tài)(局部變量、參數(shù)等)繼續(xù)壓棧,以此類推直到需要處理該異常的最頂級。開發(fā)人員后期調(diào)試時可以將棧頂元素依次出棧,構(gòu)成一條完整的函數(shù)調(diào)用鏈,比較容易找出上述產(chǎn)生ip為空串的根本原因。

在軟件開發(fā)階段及運行的初期階段,適當加大錯誤堆棧容量,可以儲存更多信息輔助調(diào)試。隨著設(shè)備軟件可靠性、穩(wěn)定性的增加,在正式投入運行后可以將異常棧設(shè)定為較小的容量,以降低存儲需求。

可以設(shè)想,若整個嵌入式軟件在開發(fā)中嚴格按照本文思路處理異常,應當可以很方便地進行異常的查找與處理。當嵌入式設(shè)備投入運行后,定期對該設(shè)備的錯誤棧進行分析,對于棧中存儲的錯誤信息進行及時處理,可以迅速有效地增加設(shè)備軟件的運行可靠性。一個經(jīng)過嚴格測試的設(shè)備在絕大多數(shù)情況下錯誤棧應為空。

結(jié)語

本文對于基于C語言的嵌入式軟件開發(fā)中的錯誤追蹤機制進行了詳細描述。該機制可以有效地降低軟件異常發(fā)生的概率,提升軟件的可靠性,減少開發(fā)成本。同時,該機制亦可以用于正常開發(fā)階段的輔助調(diào)試中,在關(guān)鍵程序段將環(huán)境信息壓棧實現(xiàn)后期分析,也為改進嵌入式軟件的調(diào)試手段提供了新的輔助思路。文中所述機制已經(jīng)在作者主持的電力GPRS集抄終端的軟件設(shè)計中得到了實際應用,取得了良好的效果。[!--empirenews.page--]

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

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉