999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

民用飛機(jī)A級(jí)別機(jī)載軟件項(xiàng)目源代碼到目標(biāo)代碼追溯性分析研究

2016-09-29 10:51:11
科技視界 2016年20期

童岳威 劉建方

【摘 要】機(jī)載軟件在某些特定情況下應(yīng)該分析源代碼和目標(biāo)代碼之間的對(duì)應(yīng)關(guān)系,RTCA/DO-178B第6.4.4.2節(jié)指出:機(jī)載軟件結(jié)構(gòu)覆蓋率分析可以在源代碼層級(jí)進(jìn)行,如果軟件為A級(jí)別并且編譯過(guò)程中生成了無(wú)法追溯到源代碼的目標(biāo)代碼,則應(yīng)該在目標(biāo)代碼層級(jí)完成額外的驗(yàn)證工作以保證這些目標(biāo)代碼的正確性。因此,對(duì)于A級(jí)別軟件,如果編譯器生成了無(wú)法追溯到源代碼的目標(biāo)代碼,那么除了完成源代碼層級(jí)結(jié)構(gòu)覆蓋率分析,還應(yīng)該完成源代碼和目標(biāo)代碼之間的追溯性分析,并對(duì)不能追溯到源代碼的目標(biāo)代碼進(jìn)行額外的驗(yàn)證。本文研究了源代碼到目標(biāo)代碼的追溯性分析方法。

【關(guān)鍵詞】機(jī)載軟件;源代碼;目標(biāo)代碼;追溯性分析;結(jié)構(gòu)覆蓋率

0 引言

隨著電子計(jì)算機(jī)技術(shù)快速地發(fā)展,機(jī)載軟件在民用飛機(jī)上的使用越來(lái)越廣泛,并且扮演著日益關(guān)鍵的角色。許多高安全關(guān)鍵性的機(jī)載系統(tǒng)都由機(jī)載軟件實(shí)現(xiàn)主要的控制、監(jiān)控和維護(hù)功能,并且通過(guò)系統(tǒng)初步安全性分析過(guò)程為這些機(jī)載軟件分配相應(yīng)的IDAL等級(jí)。對(duì)于IDAL級(jí)別為A、B和C級(jí)的機(jī)載軟件,RTCA/DO-178B要求除了滿足基于需求的測(cè)試覆蓋率分析外,還需要完成結(jié)構(gòu)覆蓋率分析,結(jié)構(gòu)覆蓋率分析用于確定基于需求的測(cè)試未覆蓋到的代碼結(jié)構(gòu),結(jié)構(gòu)覆蓋率分析目的的詳細(xì)信息可參考RTCA/DO-248B FAQ#43。

RTCA/DO-178B并沒(méi)有限制在源代碼層級(jí)或者目標(biāo)代碼層級(jí)來(lái)完成機(jī)載軟件結(jié)構(gòu)覆蓋率分析工作,但在第6.4.4.2節(jié)指出:機(jī)載軟件結(jié)構(gòu)覆蓋率分析可以在源代碼層級(jí)進(jìn)行,如果軟件為A級(jí)別并且編譯過(guò)程中生成了無(wú)法追溯到源代碼的目標(biāo)代碼,則應(yīng)該在目標(biāo)代碼層級(jí)完成額外的驗(yàn)證工作以保證這些目標(biāo)代碼的正確性。

機(jī)載軟件在編譯過(guò)程中會(huì)生成額外的目標(biāo)代碼,比如初始化目標(biāo)代碼、內(nèi)置錯(cuò)誤探測(cè)目標(biāo)代碼、異常處理目標(biāo)代碼等等。因此,對(duì)于A級(jí)別軟件,如果在源代碼層級(jí)完成結(jié)構(gòu)覆蓋率分析,還應(yīng)該分析源代碼和目標(biāo)代碼之間的追溯性,并對(duì)不能追溯到源代碼的目標(biāo)代碼進(jìn)行額外的驗(yàn)證。

本文通過(guò)分析機(jī)載軟件編譯過(guò)程以及目標(biāo)代碼生成的影響因素研究了源代碼到目標(biāo)代碼的追溯性分析方法。

1 機(jī)載軟件編譯過(guò)程

機(jī)載軟件通常采用“高級(jí)語(yǔ)言”編寫,如Ada、C、C++等編程語(yǔ)言,編譯器將“高級(jí)語(yǔ)言”源代碼翻譯成“低級(jí)語(yǔ)言”匯編代碼的過(guò)程稱為“編譯過(guò)程”。典型的編譯過(guò)程如圖1所示,包括詞法分析、語(yǔ)法分析、語(yǔ)義分析、中間代碼生成、代碼優(yōu)化和目標(biāo)代碼生成等過(guò)程。

1)詞法分析:對(duì)輸入的源程序字符串進(jìn)行掃描和分解,從而識(shí)別出一個(gè)個(gè)符號(hào),并轉(zhuǎn)化成機(jī)器比較容易使用的內(nèi)碼形式;

2)語(yǔ)法分析:在詞法分析的基礎(chǔ)上將符號(hào)序列分解成各類語(yǔ)法短語(yǔ),如程序、語(yǔ)句、表達(dá)式等;

3)語(yǔ)義分析:語(yǔ)義分析檢查源程序有無(wú)語(yǔ)義錯(cuò)誤,為代碼生成階段收集類型信息;

4)中間代碼生成:在語(yǔ)法分析和語(yǔ)義分析后,將源程序翻譯成中間代碼。一般而言,中間代碼是獨(dú)立于具體硬件的記號(hào)系統(tǒng),在某種程度上解決計(jì)算機(jī)的指令形式,或者比較容易轉(zhuǎn)化為計(jì)算機(jī)的機(jī)器指令;

5)代碼優(yōu)化:代碼優(yōu)化過(guò)程是對(duì)前階段產(chǎn)生的中間代碼進(jìn)行變換或改造,目的是使生成的目標(biāo)代碼更為高效,即節(jié)省時(shí)間和空間,代碼優(yōu)化遵循等價(jià)變換規(guī)則;

6)目標(biāo)代碼生成:目標(biāo)代碼生成過(guò)程是把中間代碼編譯成特定機(jī)器上的絕對(duì)指令代碼或可重定位的指令代碼或匯編代碼,這個(gè)階段的工作涉及到硬件系統(tǒng)功能部件的實(shí)現(xiàn)、機(jī)器指令的選擇、各種數(shù)據(jù)類型變量的存儲(chǔ)空間分配以及寄存器和后援寄存器的調(diào)度。

在大多數(shù)情況下機(jī)載軟件是運(yùn)行在嵌入式平臺(tái)上的。由于性能和資源的限制,嵌入式軟件大多數(shù)在PC等上位機(jī)環(huán)境中開發(fā),然后加載到嵌入式目標(biāo)計(jì)算中運(yùn)行。這種情況下,就要用到交叉編譯。簡(jiǎn)單而言,交叉編譯就是在一種環(huán)境中編譯生成能夠在另一種環(huán)境中運(yùn)行的目標(biāo)代碼。

因?yàn)榫幾g生成的目標(biāo)代碼與硬件環(huán)境是緊密相關(guān)的,因此將相同的源代碼編譯為在不同處理器上運(yùn)行的目標(biāo)代碼時(shí),需要分別對(duì)這些目標(biāo)代碼進(jìn)行追溯性分析。

2 目標(biāo)代碼生成的影響因素

在將源代碼編譯成目標(biāo)代碼的過(guò)程中,應(yīng)該考慮影響最終生成目標(biāo)代碼的因素,這些因素會(huì)影響到源代碼和目標(biāo)代碼之間追溯性,包括以下幾點(diǎn):

1)目標(biāo)處理器:同一系列的新處理器通常使用向上兼容的指令集,但是不同系列或者不同廠商的處理器可能采用不同的指令集。由于目標(biāo)代碼與運(yùn)行的處理器緊密相關(guān),所以將相同源代碼經(jīng)過(guò)編譯在不同處理器上運(yùn)行,可能生成不同的目標(biāo)代碼;

2)編譯器選項(xiàng):對(duì)于編譯器進(jìn)行不同的選項(xiàng)設(shè)置,可能影響編譯的執(zhí)行過(guò)程,進(jìn)而影響最終生成的目標(biāo)代碼;

3)代碼優(yōu)化層次:代碼優(yōu)化能夠提高目標(biāo)代碼的執(zhí)行效率,但是深層次的優(yōu)化會(huì)對(duì)源代碼進(jìn)行重構(gòu),從而使源代碼和目標(biāo)代碼的追溯關(guān)系難以確定;

4)編程語(yǔ)言特征:有些編程語(yǔ)言的特性導(dǎo)致部分目標(biāo)代碼很難發(fā)現(xiàn),例如寄存器使用優(yōu)化,循環(huán)展開優(yōu)化,C++中多態(tài)特性使用等等。

可以看出,影響最終目標(biāo)代碼生成的影響因素有許多,常見的不能追溯到源代碼的目標(biāo)代碼包括:初始化代碼,內(nèi)置錯(cuò)誤探測(cè),異常處理,數(shù)組邊界檢查等等。

3 源代碼和目標(biāo)代碼追溯性分析方法

根據(jù)RTCA/DO-178B的要求,如果A級(jí)別軟件在源代碼層級(jí)完成結(jié)構(gòu)覆蓋率分析,而且編譯器生成了無(wú)法直接追溯到源代碼的目標(biāo)代碼,那么應(yīng)該對(duì)這些目標(biāo)代碼進(jìn)行額外的驗(yàn)證。因此,為了識(shí)別出不能追溯到源代碼的目標(biāo)代碼,應(yīng)該對(duì)源代碼和目標(biāo)代碼之間進(jìn)行追溯性分析。通常而言,源代碼和目標(biāo)代碼的追溯分析可以采用以下幾種方法:

1)全面目標(biāo)代碼分析:對(duì)于規(guī)模相對(duì)較小的機(jī)載軟件,可以將源代碼編譯為匯編目標(biāo)代碼,然后通過(guò)人工分析的方法來(lái)識(shí)別出哪些目標(biāo)代碼不是運(yùn)行源代碼所必須的,并對(duì)追溯不到源代碼的目標(biāo)代碼進(jìn)行額外的驗(yàn)證以確保其正確性。

2)對(duì)源代碼結(jié)構(gòu)最小子集進(jìn)行分析:該方法的主要思路是按照軟件編碼標(biāo)準(zhǔn)的約束編寫樣例代碼,然后進(jìn)行編譯,并通過(guò)人工分析的方法來(lái)分析樣例代碼的目標(biāo)代碼和源代碼的追溯關(guān)系。在實(shí)際軟件研制過(guò)程中,應(yīng)該嚴(yán)格遵循軟件編碼標(biāo)準(zhǔn),并通過(guò)源代碼結(jié)構(gòu)最小子集到目標(biāo)代碼追溯性分析來(lái)滿足機(jī)載軟件源代碼到目標(biāo)代碼的追溯性要求。相對(duì)于全面代碼分析而言,源代碼結(jié)構(gòu)最小子集分析方法的追溯性分析工作量大大減少,而且分析報(bào)告可以在多個(gè)機(jī)載軟件項(xiàng)目上重復(fù)使用。源代碼結(jié)構(gòu)最小子集分析方法如圖2所示。

圖2 源代碼結(jié)構(gòu)最小子集分析法

具體過(guò)程如下:

(1)編制機(jī)載軟件編碼標(biāo)準(zhǔn),對(duì)軟件編碼所使用的編程語(yǔ)言、規(guī)則、復(fù)雜度等進(jìn)行約束和限制;

(2)按照機(jī)載軟件編碼標(biāo)準(zhǔn)中的約束和限制提取軟件源代碼結(jié)構(gòu)最小子集,源代碼結(jié)構(gòu)是編程語(yǔ)言最基本的組成部分,如加減法等函數(shù)結(jié)構(gòu)、循環(huán)/比較等邏輯結(jié)構(gòu)等等;

(3)將機(jī)載軟件項(xiàng)目源代碼和源代碼結(jié)構(gòu)最小子集進(jìn)行比較,判定源代碼結(jié)構(gòu)最小子集是否覆蓋了機(jī)載軟件項(xiàng)目所有源代碼結(jié)構(gòu);

(4)按照源代碼結(jié)構(gòu)最小子集編寫樣例代碼;

(5)在與實(shí)際機(jī)載軟件項(xiàng)目相同的編譯環(huán)境下使用相同的編譯器、設(shè)置相同的編譯器選項(xiàng)編譯樣例代碼,并生成目標(biāo)代碼;

(6)對(duì)樣例源代碼和樣例目標(biāo)代碼做追溯性分析;

(7)生成追溯性分析報(bào)告,識(shí)別出不能追溯到樣例源代碼的樣例目標(biāo)代碼。

3)基于目標(biāo)代碼的結(jié)構(gòu)覆蓋分析:在目標(biāo)代碼層級(jí)進(jìn)行結(jié)構(gòu)覆蓋分析的情況下,RTCA/DO-178B不再要求進(jìn)行源代碼到目標(biāo)代碼的追溯性分析。但是,采用該方法時(shí),需要在目標(biāo)代碼層級(jí)滿足RTCA/DO-178B對(duì)A級(jí)別軟件結(jié)構(gòu)覆蓋率要求,包括語(yǔ)句覆蓋、決策覆蓋、MC/DC覆蓋和數(shù)據(jù)耦合/控制耦合覆蓋。

源代碼和目標(biāo)代碼追溯性分析可以用于識(shí)別出哪些目標(biāo)代碼不能追溯到源代碼,但不能用來(lái)表明這些額外的目標(biāo)代碼的正確性。對(duì)于這些額外的目標(biāo)代碼,應(yīng)該通過(guò)驗(yàn)證來(lái)確認(rèn)它們正確地運(yùn)行并且不會(huì)對(duì)機(jī)載軟件引入異常行為。RTCA/DO-178B中定義了驗(yàn)證方法可以是評(píng)審、分析和測(cè)試,因此第6.4.4.2節(jié)中對(duì)不能追溯到源代碼的目標(biāo)代碼的驗(yàn)證并不等同于額外的目標(biāo)代碼應(yīng)滿足A級(jí)別機(jī)載軟件結(jié)構(gòu)覆蓋率分析的要求。

4 總結(jié)

本文分析了機(jī)載軟件編譯過(guò)程及生成目標(biāo)代碼的影響因素,并研究了民用飛機(jī)A級(jí)別機(jī)載軟件項(xiàng)目源代碼到目標(biāo)代碼追溯性分析方法。隨著機(jī)載軟件在民用飛機(jī)高安全性系統(tǒng)上的使用越來(lái)越廣泛,A級(jí)別機(jī)載軟件廣泛分布于現(xiàn)代民用飛機(jī)飛控、剎車、起落架、顯示等系統(tǒng)中,為了滿足RTCA/DO-178B第6.4.4.2節(jié)對(duì)于A級(jí)別機(jī)載軟件結(jié)構(gòu)覆蓋率的要求,需要對(duì)機(jī)載軟件源代碼到目標(biāo)代碼追溯性進(jìn)行研究。

【參考文獻(xiàn)】

[1]RTCA. DO-178B Software considerations in airborne systems and equipment certification[J]. Washington DC, 1992.

[2]RTCA. DO-248B Final report for clarification of DO-178B software considerations in airborne systems and equipment certification[J]. Washington DC, 2001.

主站蜘蛛池模板: 国产精品3p视频| 亚洲美女一级毛片| 毛片大全免费观看| 亚洲天堂视频网站| 无码国产偷倩在线播放老年人| 国产人前露出系列视频| 日韩福利在线视频| 国产午夜人做人免费视频中文| 国产91视频免费| 国产在线八区| 久久精品只有这里有| 亚洲精品第一页不卡| 白浆免费视频国产精品视频| 国产精品黑色丝袜的老师| 91麻豆精品国产91久久久久| 手机看片1024久久精品你懂的| 欧美一级视频免费| 日本免费福利视频| 久久精品亚洲中文字幕乱码| 99国产在线视频| 国产小视频a在线观看| 国产精品欧美日本韩免费一区二区三区不卡| 国产午夜精品鲁丝片| 精品成人一区二区三区电影 | 欧美高清视频一区二区三区| 亚洲人成网站在线观看播放不卡| 热99re99首页精品亚洲五月天| 国产成人精品一区二区| 91精品视频在线播放| 免费人成视网站在线不卡| 国产亚洲一区二区三区在线| 免费人欧美成又黄又爽的视频| 久久久久亚洲精品无码网站| 日日噜噜夜夜狠狠视频| 91在线播放国产| 性视频一区| 日韩欧美综合在线制服| 国产美女91视频| 青青操国产| 精品人妻一区无码视频| 国产成人精品日本亚洲| 亚洲高清在线播放| 麻豆精品在线播放| 日韩大片免费观看视频播放| 亚洲天堂日韩av电影| 日本成人不卡视频| 亚洲啪啪网| 福利国产微拍广场一区视频在线| 欧美激情一区二区三区成人| 成·人免费午夜无码视频在线观看 | 米奇精品一区二区三区| 国产精品短篇二区| 亚洲一区二区精品无码久久久| 久久香蕉国产线看观看精品蕉| 欧美a在线看| 亚洲一区二区约美女探花| 免费高清毛片| 国产精品午夜福利麻豆| 精品一区二区三区自慰喷水| 色九九视频| 欧美另类第一页| 国产成人h在线观看网站站| 久久青青草原亚洲av无码| AV不卡国产在线观看| 2021国产在线视频| 日本不卡在线| aa级毛片毛片免费观看久| 欧美日韩一区二区三| 欧美黄色网站在线看| 精品久久香蕉国产线看观看gif| 国产乱子精品一区二区在线观看| 蜜臀AV在线播放| 亚洲男人天堂久久| 91无码网站| Aⅴ无码专区在线观看| 国产丝袜91| 福利在线一区| 亚洲色大成网站www国产| 国产精品久久精品| 久久精品视频亚洲| 99re精彩视频| 青青网在线国产|