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

當前位置:首頁 > 嵌入式 > 嵌入式教程
[導讀]如何提高嵌入式軟件質(zhì)量

 操作應用于安全苛刻的航空和軍事領(lǐng)域的嵌入式軟件時必須高度關(guān)注安全問題。為達到可靠性目標,軟件開發(fā)團隊精益求精,力爭使這些軟件應用符合嚴格的驗證流程并實現(xiàn)零缺陷目標。Edsger Dijkstra有句名言:測試只能發(fā)現(xiàn)錯誤,但不能證明錯誤不存在。如果測試無法證明不存在嚴重的運行錯誤,那么嵌入式軟件開發(fā)團隊如何才能確定其軟件沒有這些錯誤呢?基于數(shù)學證明的代碼驗證是值得一試的解決方案。在軟件驗證方面,可擴展的高性能數(shù)學技術(shù)在實際應用方面的最新發(fā)展十分有用,可實現(xiàn)對軟件中不存在運行時錯誤進行證明。

  航空領(lǐng)域的軟件應用

  高集成系統(tǒng)中的嵌入式軟件日益復雜。在軍事領(lǐng)域中,用于F-22猛禽戰(zhàn)斗機的航空電子軟件由170萬行代碼組成,用于F-35聯(lián)合攻擊戰(zhàn)斗機的航空電子軟件預計有570萬行代碼。對于商務班機,波音787飛機飛行控制系統(tǒng)將有大約650萬行代碼。軟件內(nèi)容不斷膨脹,飛機復雜性不斷增加,使發(fā)生故障的風險也不斷加劇,從而使獲得高度可信性軟件的過程復雜無比。

  軟件故障風險

  研究以往發(fā)生的嵌入式設(shè)備故障對于理解代碼相關(guān)的問題大有裨益。例如,一次性使用火箭在測試飛行期間發(fā)生的故障歸根于代碼缺陷。在這種特殊情況下,發(fā)射器在發(fā)射后不到一分鐘的時間內(nèi)自毀,原因在于:攻角超過規(guī)定的安全限度,導致發(fā)射器遭遇高氣動載荷。

  事后調(diào)查揭露了故障的根本原因:溢出導致嵌入式軟件發(fā)生運行錯誤。在將一個64位浮點數(shù)轉(zhuǎn)換為16位有符號整數(shù)時,一對決定火箭姿態(tài)和位置的冗余慣性參考系統(tǒng)中產(chǎn)生溢出,從而將火箭噴管移到了極端位置。冗余系統(tǒng)的存在不起作用,因為備用系統(tǒng)也發(fā)生了同樣的問題。

  如上所述的運行時錯誤代表一類特定的軟件錯誤,稱作潛伏性故障。這類故障位于代碼中,但是除非在特殊條件下運行特定測試,否則在系統(tǒng)測試期間無法檢測到這些故障。因此,這些代碼表面上能正常運行,但實際上會導致意外的系統(tǒng)故障。以下為若干運行時錯誤示例:數(shù)據(jù)未初始化;數(shù)組訪問越界;空指針解引用;溢出和下溢;計算錯誤;同時訪問共享數(shù)據(jù);非法類型轉(zhuǎn)換。

  高集成軟件驗證

  按照傳統(tǒng)方法,源代碼級軟件驗證涉及代碼檢查、靜態(tài)分析和動態(tài)測試。每種方法都有缺點。

  代碼檢查僅依賴于檢察人員的專業(yè)技術(shù),若有大量代碼需要檢查,則會是一項繁瑣的工作。傳統(tǒng)的靜態(tài)分析技術(shù)主要依靠模式匹配方法檢測不安全的代碼模式,但無法證明不存在運行時錯誤。隨著嵌入式軟件日益復雜,對所有操作條件進行動態(tài)測試已經(jīng)不太可能,這進一步證明了Edsger Dijkstra的觀點:測試只能發(fā)現(xiàn)錯誤,但不能證明錯誤不存在。

  一種新的驗證方法稱為抽象解釋,它以靜態(tài)分析為基礎(chǔ),使用形式化數(shù)學證明,可發(fā)現(xiàn)某些運行時錯誤或證明它們不存在。抽象解釋可直接應用于源代碼,而無需執(zhí)行代碼。

  抽象解釋和基于證明的驗證方法作為一種基于證明的驗證方法,通過在以下問題中將三個大整數(shù)相乘可對抽象解釋進行說明:–4586×34985×2389=?

  雖然手動計算此問題的答案很費時,但是我們可以應用乘法法則確定答案的符號為負。確定此計算的符號就是抽象解釋的一種應用。這種技巧使我們不需要對整數(shù)執(zhí)行完成的乘法計算就能夠準確地知道最終結(jié)果的一些屬性,例如符號。利用乘法法則,我們還知道此計算的結(jié)果符號不可能為正。采用類似方式可將抽象解釋應用到軟件符號學中,以證明軟件的某些屬性。不執(zhí)行程序本身,

  通過驗證源代碼的某些動態(tài)屬性,抽象解釋在傳統(tǒng)靜態(tài)分析技術(shù)和動態(tài)測試之間架起橋梁。抽象解釋在單個階段中調(diào)查程序的所有可能行為,即所有可能值的組合,以確定如何以及在何種條件下程序會產(chǎn)生某些類別的運行時故障。由于抽象解釋與考慮中的操作相關(guān),我們可以用數(shù)學方法證明該技術(shù)能預測正確的結(jié)果,因此它得出的結(jié)果被認為是可靠的。

  使用抽象解釋驗證軟件

  抽象檢查可用作靜態(tài)分析工具,檢測并用數(shù)學方法證明源代碼中不存在某些運行時錯誤,如溢出、除以零以及數(shù)組訪問超出邊界等。執(zhí)行此驗證無需執(zhí)行程序、代碼插裝或測試用例。MathWorks Polyspace代碼驗證產(chǎn)品使用的便是此類靜態(tài)分析。向Polyspace產(chǎn)品輸入C、C++或Ada源代碼。Polyspace產(chǎn)品首先檢查源代碼,以確定可能出現(xiàn)潛在運行時錯誤的位置。然后它會生成一份報告,該報告使用顏色編碼表示代碼中各元素的狀態(tài),如圖1和表1所示。

  


 

  圖1 Polyspace顏色編碼

  表1:顏色編碼

  

 

  標為綠色的Polyspace結(jié)果表示代碼中不存在某些運行時錯誤。在檢測到運行時錯誤且代碼顯示為紅色、灰色或橙色的情況下,軟件開發(fā)人員和測試人員可使用驗證流程中生成的信息修復發(fā)現(xiàn)的運行時錯誤。

  結(jié)論

  靜態(tài)分析融合抽象解釋后,可提高高集成系統(tǒng)中嵌入式軟件的質(zhì)量和可靠性。此方法能幫助工程師實現(xiàn)證明軟件中不存在某些運行時錯誤的目標。具有抽象解釋的代碼驗證解決方案有助于實現(xiàn)良好的質(zhì)量流程。這是強有力的驗證流程,可幫助實現(xiàn)嵌入式設(shè)備的高集成性。

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

旅行不設(shè)限 商務亦休閑 上海2022年9月21日 /美通社/ -- 近年來,"Bleisure" 休閑商務旅行的出行模式蔚為風潮,越來越多的賓客在商務出行時愈發(fā)關(guān)注休閑的需求。作為高端商務...

關(guān)鍵字: BSP 數(shù)字化 SPACE WORKS

2022年上半年收入7.1億元 同比增長14.5%  嵌入式軟件和安全支付產(chǎn)品發(fā)展勢頭強勁 收入同比增長28.7% 香港2022年8月16日 /美通社/ -- 金邦達寶嘉控股有限公司及其附屬公司(以下合稱“...

關(guān)鍵字: 數(shù)字化 嵌入式軟件 供應鏈 代碼

上海2022年8月11日 /美通社/ -- 8月19日至8月30日,富士X-SPACE策劃的兩個攝影項目將亮相北京798藝術(shù)區(qū)悅·美術(shù)館:瑪格南攝影師Olivia Arthur(奧利維婭·亞瑟...

關(guān)鍵字: CONNECTION SPACE 富士 影像

北京2022年7月26日 /美通社/ -- 7月16日,香港大學SPACE中國商業(yè)學院(ICB)舉辦主題為「創(chuàng)·贏」的2022年7月開學典禮。為配合各地疫情的最新情況及防疫政策,本次活動采取線上線下混合模式...

關(guān)鍵字: SPACE IC BSP 微軟

(全球TMT2022年7月22日訊)由知名策展人何伊寧策劃的"New Connection"于7月22日-8月15日在上海X-SPACE富士影像共享空間與大眾見面,展覽集合了12組青年攝影師和影像藝術(shù)家作品,從更廣博處...

關(guān)鍵字: CONNECTION SPACE 富士 影像

北京2022年4月22日 /美通社/ -- 紅外熱成像通過探測景物目標自身的熱輻射能量,可以呈現(xiàn)出人類視覺無法捕捉的信息。在工業(yè)測溫、夜視安防、輔助駕駛、災情預警等諸多場景均可延伸人類的視覺能力,是視覺的“第六...

關(guān)鍵字: 探測器 高集成 測溫 PLAYER

獨立的 IDE 插件使開發(fā)人員能夠檢測源代碼和開源依賴項中的安全漏洞

關(guān)鍵字: 新思科技 IDE 插件 源代碼

來自:知乎,作者:Name1e5s鏈接:https://zhuanlan.zhihu.com/p/40490357故事要從前兩天交流群中一位同學提到的這個問題開始這個問題看起來十分刁鉆,不過稍有常識的人都知道,制定C標準...

關(guān)鍵字: POINTER RETURN SPACE SYSTEMS

(全球TMT2021年12月7日訊)開放原子開源基金會(簡稱“開源基金會”)作為中國首個以開源為主題的基金會,是開源項目的孵化器、連接器和倍增器,致力于為全球開發(fā)者搭建可持續(xù)的開源合作平臺,OpenHarmony、op...

關(guān)鍵字: 開源 PEN 開發(fā)者 源代碼

文|周立功日期|2021年12月2日ZLG致遠電子創(chuàng)始人周立功EsDA(EmbededsoftwareDesignAutomation),全稱是嵌入式軟件設(shè)計自動化,它是一個由多種軟件組成的軟件過程管理和開發(fā)的工具,致力...

關(guān)鍵字: 自動化 嵌入式軟件 ESD 周立功

嵌入式教程

6897 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉