當(dāng)前位置:首頁 > 單片機 > 單片機
[導(dǎo)讀] 如果我們自己編寫了一個程序,程序能正常編譯,運行起來也實現(xiàn)了我們期望的輸出,那是不是這個程序就很完善了呢?對于工業(yè)產(chǎn)品來說,“好”、“能用”和“完善”,或者說“標(biāo)準(zhǔn)&

 如果我們自己編寫了一個程序,程序能正常編譯,運行起來也實現(xiàn)了我們期望的輸出,那是不是這個程序就很完善了呢?對于工業(yè)產(chǎn)品來說,“好”、“能用”和“完善”,或者說“標(biāo)準(zhǔn)”,甚至是代碼的“安全”,顯然不是一個層面的東西。因為C語言雖然是我們開發(fā)嵌入式應(yīng)用的最主要工具之一,然而C語言并非是專門為嵌入式系統(tǒng)設(shè)計,相當(dāng)多的嵌入式系統(tǒng)較一般計算機系統(tǒng)對軟件安全性有更苛刻的要求;例如在那些對安全性要求很高的系統(tǒng)中,如飛行器、汽車和工業(yè)控制中,只要代碼的工作稍有偏差,就有可能造成重大的財產(chǎn)損失或者人員傷亡。

那么如何衡量我們的代碼是否滿足某些標(biāo)準(zhǔn),是“安全的”、“健壯的”呢?此時我們就可以根據(jù)具體的應(yīng)用來查找相關(guān)的行業(yè)標(biāo)準(zhǔn)。舉個例子,在工業(yè)領(lǐng)域中,MISRA-C就是在的某些行業(yè)中要求遵守的行業(yè)標(biāo)準(zhǔn)。MISRA C是由汽車產(chǎn)業(yè)軟件可靠性協(xié)會(MISRA,motor industry software reliability association)提出的C語言開發(fā)標(biāo)準(zhǔn)。其目的是在增進嵌入式系統(tǒng)的安全性及可移植性。針對C++語言也有對應(yīng)的標(biāo)準(zhǔn)MISRA C++。MISRA C一開始主要是針對汽車產(chǎn)業(yè):如果我們?nèi)⒓咏鼛啄甑挠嘘P(guān)汽車行業(yè)的基于自動代碼生成技術(shù)和基于模型的設(shè)計技術(shù)的講座、研討會等等,無一例外都會聽到有關(guān)MISRA-C 2004,甚至是MISRA-C 2008、MISRA-C 2012等更新版本的介紹。此外,其他產(chǎn)業(yè)也已經(jīng)逐漸開始使用MISRA C:包括航空航天、電信、國防、醫(yī)療設(shè)備、鐵路等領(lǐng)域中都已有廠商使用MISRA C:這些領(lǐng)域無一不對代碼的規(guī)范,特別是代碼的安全有非常高的要求。MISRA C的第一版《Guidelines for the use of the C language in vehicle based software》是在1998年發(fā)行,一般稱為MISRA-C:1998.。MISRA-C:1998有127項規(guī)則,規(guī)則從1號編號到127號,其中有93項是強制要求,其余的34項是推薦使用的規(guī)則。在2004年時發(fā)行了第二版的MISRA C的第一版《Guidelines for the use of the C language in critical systems》(或稱作MISRA-C:2004),其中有許多重要建議事項的變更,其規(guī)則也重新編號。MISRA-C:2004有141項規(guī)則,其中121項是強制要求,其余的20項是推薦使用的規(guī)則。規(guī)則分為21類,從“開發(fā)環(huán)境”到“運行期錯誤”。通常認(rèn)為,如果能夠完全遵守這些標(biāo)準(zhǔn),則你的C代碼是易讀、可靠、可移植和易于維護的。最近很多嵌入式開發(fā)者都以MISRA C來衡量自己的編碼風(fēng)格,比如著名的uC/OS-II就得意地宣稱自己99%遵守MISRA標(biāo)準(zhǔn)。目前有許多工具聲稱可以檢查代碼和MISRA規(guī)則相容性,不過MISRA沒有相關(guān)認(rèn)證的程序。相關(guān)工具可以幫助使用者評估和比較檢查的結(jié)果,也會提供一些可符合MISRA-C規(guī)定的指南,但是目前大部分的工具對靜態(tài)代碼分析的工具檢查基本能實現(xiàn),對動態(tài)代碼分析則還不能完美實現(xiàn)。

考慮到MISRA-C:2004有141項規(guī)則,其中僅強制要求就有121項,其余的20項是推薦使用的規(guī)則,顯然讓我們僅僅是把這么多規(guī)則瀏覽一遍就需要花費大量的時間,更不用提手工對照規(guī)則來檢查我們的軟件了。幸好我們使用的DSP編程環(huán)境CCS提供了相應(yīng)的選項,使得編譯器可以自動檢查我們的代碼是否違反了MISRA-C的相關(guān)規(guī)則,并提供給我們詳細的診斷與警告信息。

在C語言的標(biāo)準(zhǔn)ANSI C 和 ISO C之后,又產(chǎn)生了更新的C99以及最新的C11 (ISO/IEC 9899:2011),但是因為最新版本的規(guī)范從推出到各大編譯器廠家支持以及開發(fā)者的適應(yīng)都需要一定的時間,所以目前最常用的仍然是ANSI C或者C99。與此類似, 雖然MISRA-C的標(biāo)準(zhǔn)最弱已經(jīng)有最新的2012,但是人們談?wù)摵褪褂米疃嗟娜匀皇?004版本,所以在CCS的編譯器選項里仍以MISRC-C:2004的規(guī)則為準(zhǔn)。

啟用了--check_misra={all|required|advisory|none|rulespec}的選項使能MISRC-C:2004規(guī)則檢查之后,還可以在代碼中可以配合相關(guān)的預(yù)處理指令使能某些代碼的檢查/停止檢查功能,包括:

#pragma CHECK_MISRA ("{all|required|advisory|none|rulespec}");

#pragma RESET_MISRA ("{all|required|advisory|rulespec}");

其中,CHECK_MISRA用來使能或者禁止對MISRC-C:2004規(guī)則的檢查,它的作用與--check_misra是一致的。RESET_MISRA則用來復(fù)位MISRC-C:2004規(guī)則檢查的狀態(tài)。

rulespec參數(shù)則可以用來指定我們使用哪些MISRC-C:2004中的哪些規(guī)則來進行特點的檢查,包括:

[-]X 使能 (或者禁止) X主題下各個規(guī)則的檢查。(主題包括變量、字符、初始化等)

[-]X-Z 使能 (或者禁止) 從X到Z主題下各個規(guī)則的檢查

[-]X.A 使能 (或者禁止) X主題下規(guī)則A的檢查。

[-]X.A-C 使能 (或者禁止) X主題下從規(guī)則A到規(guī)則C的檢查。

舉例說明:--check_misra=1-5,-1.1,8.2-4的含義是:

檢查從主題1到主題5的規(guī)則。(不清楚的網(wǎng)友可以去搜索MISRA規(guī)范,1.環(huán)境;2.語言擴展;3.文檔;4.字符集;5.標(biāo)識符)

禁止規(guī)則1中1.1條目的規(guī)則(規(guī)則1.1(強制): 所有代碼都必須遵照ISO 9899:1990 “Programming languages - C”,由ISO/IEC 9899/COR1:1995,ISO/IEC 9899/AMD1:1995,和ISO/IEC9899/COR2:1996 修訂),規(guī)則1中的其它規(guī)則保持有效。

檢查主題8中的規(guī)則2到4.為了方便,我們可以列出這幾條規(guī)則的定義(其內(nèi)容較長,有興趣的網(wǎng)頁請在搜索引擎中檢索):

主題8: 聲明與定義

規(guī)則8.2(強制): 不論何時聲明或定義了一個對象或函數(shù),它的類型都應(yīng)顯式聲明。

規(guī)則8.3(強制): 函數(shù)的每個參數(shù)類型在聲明和定義中必須是等同的,函數(shù)的返回類型也該是等同的。

規(guī)則8.4(強制): 如果對象或函數(shù)被聲明了多次,那么它們的類型應(yīng)該是兼容的。

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉