0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

軟件測試自身的完整性

星星科技指導(dǎo)員 ? 來源:嵌入式計(jì)算設(shè)計(jì) ? 作者:Colin Walls ? 2022-06-29 15:43 ? 次閱讀

所有重要的軟件都有錯誤。我不想稱它們?yōu)椤板e誤”,因?yàn)檫@會使它們與需要為自己的錯誤負(fù)責(zé)的開發(fā)人員分離。顯然,設(shè)計(jì)良好的軟件可能會更少,而現(xiàn)代嵌入式軟件開發(fā)工具的應(yīng)用可以將它們保持在最低限度。當(dāng)然,具體的錯誤無法預(yù)測(否則它們可以被根除),但是可以識別某些類型的軟件問題,并且有可能在問題變成災(zāi)難之前發(fā)現(xiàn)問題。

我會將此類軟件問題分為兩大類:

數(shù)據(jù)損壞

代碼循環(huán)

由于大量嵌入式代碼是用 C 編寫的,這意味著開發(fā)人員很可能會使用指針。小心使用,指針是該語言的一個強(qiáng)大功能,但它們也是最常見的程序員錯誤來源之一。指針使用的問題很難靜態(tài)識別,并且引入的錯誤可能會在代碼執(zhí)行時以微妙的方式表現(xiàn)出來。有些事情,比如取消引用空指針很容易檢測到,因?yàn)樗鼈兺ǔ?dǎo)致陷阱。只需要實(shí)現(xiàn)一個陷阱處理程序。其他的更難,因?yàn)橹羔樧罱K可能指向任何地方——通常它會指向一個有效的地址,但不幸的是,它可能不是正確的地址。自測試代碼對此幾乎無能為力。然而,有兩種特殊但非常常見的,

不應(yīng)發(fā)生堆棧溢出,因?yàn)閼?yīng)仔細(xì)確定堆棧分配,并在調(diào)試階段驗(yàn)證其使用情況。但是,很可能會忽略不尋常的情況或使用不易測試的構(gòu)造(如遞歸函數(shù))。一個簡單的解決方案是在堆??臻g的任一端包含一個額外的詞——“保護(hù)詞”。這些預(yù)加載了特定值,由自檢任務(wù)(可能在后臺運(yùn)行)監(jiān)控。如果值更改,則違反了堆棧限制。應(yīng)謹(jǐn)慎選擇該值。奇數(shù)是最好的,因?yàn)樗淮泶蠖鄶?shù)處理器的有效地址。也許是 0x55555555。只要該值“不太可能”——例如不是 0x00000001 或 0xffffffff——就有 40 億比 1 的機(jī)會發(fā)生誤報。

在某些語言中,存在用于在數(shù)組邊界之外尋址的內(nèi)置檢測,但這會引入運(yùn)行時開銷,這可能是不受歡迎的。因此,這不是在 C 中實(shí)現(xiàn)的。此外,可以使用指針而不是運(yùn)算符來訪問數(shù)組元素,因此可能會規(guī)避任何檢查。最好的方法是通過在數(shù)組末尾定位一個保護(hù)字并以與堆棧溢出檢查相同的方式進(jìn)行監(jiān)視來檢查緩沖區(qū)溢出類型的錯誤。

在這兩種情況下,當(dāng)保護(hù)字被破壞時,這表明即將發(fā)生故障。堆棧或數(shù)組可能只是一個字就溢出或不足,因此還沒有造成真正的損害。定位錯誤訪問的原因比調(diào)試可能發(fā)生的隨機(jī)崩潰要容易得多。

代碼永遠(yuǎn)不應(yīng)陷入無限循環(huán),但邏輯錯誤或未發(fā)生預(yù)期的外部事件可能會導(dǎo)致代碼掛起。當(dāng)代碼在等待某事發(fā)生時,理想情況下應(yīng)該有一個超時機(jī)制,這樣代碼就不會無限期地掛起。

在任何類型的多線程環(huán)境中——無論是 RTOS 還是帶有 ISR 的主線代碼——都可以實(shí)現(xiàn)“看門狗”機(jī)制。每個連續(xù)運(yùn)行的任務(wù)(可能只是主線代碼)都需要每隔一段時間與看門狗任務(wù)(可能是計(jì)時器 ISR)“簽入”。如果發(fā)生超時,則需要采取措施。

那么,當(dāng)檢測到堆棧溢出、數(shù)組綁定違例或掛起任務(wù)時該怎么辦呢?這取決于應(yīng)用程序。可能只需要停止和重新啟動單個任務(wù),但可能需要更激烈的操作:停止系統(tǒng)、發(fā)出某種警報或簡單地重置系統(tǒng)。選擇取決于許多因素,但從廣義上講,目標(biāo)是為了比崩潰的系統(tǒng)更好的東西。

訂閱

審核編輯:郭婷

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5046

    文章

    18821

    瀏覽量

    298598
  • RTOS
    +關(guān)注

    關(guān)注

    20

    文章

    804

    瀏覽量

    119117
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4671

    瀏覽量

    67770
收藏 人收藏

    評論

    相關(guān)推薦

    高速PCB信號完整性設(shè)計(jì)與分析

    高速PCB信號完整性設(shè)計(jì)與分析
    發(fā)表于 09-21 11:51 ?0次下載

    高速PCB的信號完整性、電源完整性和電磁兼容研究

    電子發(fā)燒友網(wǎng)站提供《高速PCB的信號完整性、電源完整性和電磁兼容研究.pdf》資料免費(fèi)下載
    發(fā)表于 09-19 17:37 ?0次下載

    信號完整性與電源完整性-電源完整性分析

    電子發(fā)燒友網(wǎng)站提供《信號完整性與電源完整性-電源完整性分析.pdf》資料免費(fèi)下載
    發(fā)表于 08-12 14:31 ?13次下載

    信號完整性與電源完整性-差分對的特性

    電子發(fā)燒友網(wǎng)站提供《信號完整性與電源完整性-差分對的特性.pdf》資料免費(fèi)下載
    發(fā)表于 08-12 14:28 ?1次下載

    信號完整性與電源完整性-信號的串?dāng)_

    電子發(fā)燒友網(wǎng)站提供《信號完整性與電源完整性-信號的串?dāng)_.pdf》資料免費(fèi)下載
    發(fā)表于 08-12 14:27 ?0次下載

    信號完整性與電源完整性 第一章 概論

    電子發(fā)燒友網(wǎng)站提供《信號完整性與電源完整性 第一章 概論.pdf》資料免費(fèi)下載
    發(fā)表于 08-09 14:49 ?1次下載

    示波器探頭在電源完整性測量上的應(yīng)用

    在電子設(shè)備的開發(fā)和維護(hù)過程中,電源完整性是一個至關(guān)重要的考量因素。電源完整性(Power Integrity, PI)涉及到電源分配網(wǎng)絡(luò)(PDN)的性能,確保電子設(shè)備能夠獲得穩(wěn)定、干凈的電源供應(yīng)
    的頭像 發(fā)表于 08-02 09:38 ?183次閱讀
    示波器探頭在電源<b class='flag-5'>完整性</b>測量上的應(yīng)用

    搞定電源完整性,不如先研究PDN

    ? 在現(xiàn)代電子設(shè)備的設(shè)計(jì)中,一個關(guān)鍵的因素是電源完整性。電源完整性不僅影響設(shè)備的性能,還直接關(guān)系到設(shè)備的穩(wěn)定性和可靠。作為電子設(shè)備的基礎(chǔ),印刷電路板(PCB)的電源完整性設(shè)計(jì)尤為重要
    的頭像 發(fā)表于 06-13 18:16 ?2003次閱讀
    搞定電源<b class='flag-5'>完整性</b>,不如先研究PDN

    什么是信號完整性

    在現(xiàn)代電子通信和數(shù)據(jù)處理系統(tǒng)中,信號完整性(Signal Integrity, SI)是一個至關(guān)重要的概念。它涉及信號在傳輸過程中的質(zhì)量保持,對于確保系統(tǒng)性能和穩(wěn)定性具有決定性的影響。本文將從信號完整性的定義、影響因素、測試方法
    的頭像 發(fā)表于 05-28 14:30 ?649次閱讀

    構(gòu)建系統(tǒng)思維:信號完整性,看這一篇就夠了!

    完整性的旅程中,以上為大家系統(tǒng)地梳理了其在硬件設(shè)計(jì)中的核心地位。從總線協(xié)議到PCB設(shè)計(jì),從材料選擇到高速互連器件的理解,每一個環(huán)節(jié)都彰顯著信號完整性的重要。而測試測量與仿真
    發(fā)表于 03-05 17:16

    有哪些高速信號完整性測試的手段

    有源等等都會是非常低的標(biāo)準(zhǔn),但是對于高速信號,這些條件就會變得非??量?,不然測試測量結(jié)果就會出現(xiàn)較大偏差。 其中比較重點(diǎn)的方向就是信號完整性測試,對于信號完整性
    的頭像 發(fā)表于 11-06 17:10 ?1022次閱讀
    有哪些高速信號<b class='flag-5'>完整性</b><b class='flag-5'>測試</b>的手段

    為什么電路端接電阻能改善信號完整性?

    為什么電路端接電阻能改善信號完整性? 在電路設(shè)計(jì)中,信號完整性是一個極其重要的概念。信號完整性是指信號在傳輸、轉(zhuǎn)換和處理過程中所遭受的失真、干擾或損失。這些信號可能是模擬信號或數(shù)字信號,它們的
    的頭像 發(fā)表于 10-24 10:04 ?736次閱讀

    電源完整性設(shè)計(jì)---于博士

    電子發(fā)燒友網(wǎng)站提供《電源完整性設(shè)計(jì)---于博士.pdf》資料免費(fèi)下載
    發(fā)表于 10-13 10:11 ?12次下載
    電源<b class='flag-5'>完整性</b>設(shè)計(jì)---于博士

    什么是信號完整性SI?信號完整性設(shè)計(jì)的難點(diǎn)

    信號完整性(Signal Integrity,SI)是指電路系統(tǒng)中信號的質(zhì)量,如果在要求的時間內(nèi),信號能不失真地從源端傳輸?shù)浇邮斩耍覀兙头Q該信號是完整的。
    的頭像 發(fā)表于 09-28 11:27 ?1852次閱讀
    什么是信號<b class='flag-5'>完整性</b>SI?信號<b class='flag-5'>完整性</b>設(shè)計(jì)的難點(diǎn)

    信號完整性分析

    手工連線面成的樣機(jī)同規(guī)范布線的最終印制板產(chǎn)品一樣都能正常工作。 但是現(xiàn)在時鐘頻率提高了,信號上升邊也已普遍變短。對大多數(shù)電子產(chǎn)品而言,當(dāng)時鐘頻率超過100MHz或上升邊小于1 ns時,信號完整性效應(yīng)
    發(fā)表于 09-28 08:18