基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法
【專利摘要】本發(fā)明所述的一種基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法,該方法首先通過對無線傳感網(wǎng)軟件源代碼分析并建立動態(tài)查找表,然后建立軟件模型,該模型是無線傳感網(wǎng)軟件源代碼的靜態(tài)結(jié)構(gòu)和動態(tài)行為的抽象,在此基礎(chǔ)上定義模型轉(zhuǎn)換規(guī)則,實現(xiàn)軟件模型轉(zhuǎn)化向C語言的代碼轉(zhuǎn)化,最后使用有界模型檢驗工具對轉(zhuǎn)化后的代碼進(jìn)行有界模型檢驗。本發(fā)明能夠有效緩解無線傳感網(wǎng)軟件模型檢驗中的狀態(tài)空間爆炸問題,可應(yīng)用于無線傳感網(wǎng)系統(tǒng)驗證。
【專利說明】基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法
【技術(shù)領(lǐng)域】
[0001]本發(fā)明涉及一種無線傳感網(wǎng)軟件代碼驗證方法,主要利用有界模型檢驗技術(shù)來解決無線傳感器網(wǎng)絡(luò)軟件的模型驗證問題,屬于計算機技術(shù)、無線通信、無線傳感器網(wǎng)絡(luò)、實時技術(shù)、分布式系統(tǒng)和驗證技術(shù)的交叉技術(shù)應(yīng)用領(lǐng)域。
【背景技術(shù)】
[0002]無線傳感網(wǎng)是一種全新的信息獲取和處理技術(shù),能夠協(xié)作地實時監(jiān)測、感知和采集網(wǎng)絡(luò)分布區(qū)域內(nèi)各種環(huán)境或監(jiān)測對象的信息,并對這些信息進(jìn)行處理,獲得詳盡而準(zhǔn)確的信息,傳送給需要這些信息的用戶。傳感器網(wǎng)絡(luò)可以使人們在任何時間、地點和任何環(huán)境條件下獲取大量詳實而可靠的信息,具有十分廣闊的應(yīng)用前景。
[0003]無線傳感網(wǎng)的發(fā)展非常迅速,這使得應(yīng)用在上面的軟件也越來越廣泛,伴隨的軟件驗證問題也越來越多。無線傳感網(wǎng)軟件規(guī)模越來越大,致使系統(tǒng)復(fù)雜性也愈來愈高,除此之外,在很多的不同應(yīng)用領(lǐng)域都對無線傳感網(wǎng)軟件有很高的性能要求。模型檢驗技術(shù)為保證應(yīng)用于無限傳感器網(wǎng)絡(luò)中的軟件性能提供了新的思路,其在協(xié)議驗證領(lǐng)域和硬件領(lǐng)域都獲得了很大的成功之后,也被用在有關(guān)軟件驗證問題的解決上。軟件相對于硬件有著較高的復(fù)雜性,其狀態(tài)空間規(guī)模也較大,有大量的學(xué)者致力于這方面的研究。為了及時地發(fā)現(xiàn)程序中潛在的問題,已經(jīng)有人提出將模型檢驗技術(shù)應(yīng)用到源代碼的分析中。建立模型和性質(zhì)檢驗是模型檢驗中的兩個重要的步驟,即第一步需要對待驗證的軟件進(jìn)行建立模型,然后在通過窮盡搜索軟件系統(tǒng)狀態(tài)的方法來檢驗性質(zhì)是否滿足。
[0004]模型檢驗是一種自動驗證有窮狀態(tài)系統(tǒng)的技術(shù),最早是由Clarke和Emerson在1981年提出的,模型檢驗方法可以在構(gòu)建系統(tǒng)前對系統(tǒng)的安全性和可靠性進(jìn)行驗證,以盡早發(fā)現(xiàn)錯誤。模型檢驗實質(zhì)是利用計算機的快速計算能力,通過窮舉被檢驗系統(tǒng)的狀態(tài)空間中的每一個狀態(tài)來驗證該系統(tǒng)滿足特定的形式描述。在模型檢驗中涉及兩種形式說明語言:一種是用于描述系統(tǒng)模型的模型描述語言,一般使用狀態(tài)機進(jìn)行表示,另一種是用于描述系統(tǒng)性質(zhì)的性質(zhì)說明語言,一般使用時序邏輯公式進(jìn)行表示。模型檢驗的基本思想是用狀態(tài)遷移系統(tǒng)(S)表示系統(tǒng)的行為,用模態(tài)/時序邏輯公式(F)描述系統(tǒng)的性質(zhì),這樣“系統(tǒng)是否滿足所期望的性質(zhì)”就轉(zhuǎn)化為數(shù)學(xué)問題“狀態(tài)遷移系統(tǒng)S是否公式F的一個模型”,用公式表示為S| = F?。對有窮狀態(tài)系統(tǒng),這個問題是可判定的,即可以用計算機程序在有限時間內(nèi)自動確定。模型檢驗已被應(yīng)用于計算機硬件、通信協(xié)議、控制系統(tǒng)、安全認(rèn)證協(xié)議等方面的分析與驗證中,取得了令人矚目的成功,并從學(xué)術(shù)界輻射到了產(chǎn)業(yè)界。
[0005]模型檢驗提供一個完整的系統(tǒng)屬性驗證框架,其優(yōu)點是模型檢驗?zāi)苓_(dá)到完全自動化的程度,只需用有窮狀態(tài)模型和邏輯公式分別將系統(tǒng)實現(xiàn)和待驗證的系統(tǒng)規(guī)范描述出來,之后的判斷過程則完全可以由模型檢驗工具自動完成,不需要人的參與;模型檢驗過程總會以“是”或“否”的結(jié)果中止,當(dāng)以“否”的結(jié)果中止時,說明設(shè)計或系統(tǒng)不滿足某個給定的性質(zhì)。此時一個違反性質(zhì) 的行為反例將會被給出,此反例將對理解錯誤的真正原因和修正錯誤提供線索。利用模型檢驗的優(yōu)點,對無線傳感器網(wǎng)絡(luò)的軟件或協(xié)議進(jìn)行驗證,找出其可能存在的威脅和隱患。
[0006]TinyOS操作系統(tǒng)是無線傳感網(wǎng)的主流操作系統(tǒng)。網(wǎng)絡(luò)協(xié)議、傳感器驅(qū)動、分布式服務(wù)器及數(shù)據(jù)識別工具是組成TinyOS的四個主要部分。良好的事件執(zhí)行模型是促成良好的電源管理的主要因素,因此,該模型也使得時序安排具有靈活性。TinyOS已被應(yīng)用于TinyOS的感應(yīng)板和多個平臺中的,且軟件的應(yīng)用也有了一定程度的發(fā)展,這與TinyOS系統(tǒng)本身的特征如事件驅(qū)動模式、組件化編程思想、輕量級線程技術(shù)以及主動消息通信技術(shù)等密切相關(guān)。然而,在傳感器網(wǎng)絡(luò)系統(tǒng)的深入研究就會發(fā)現(xiàn),這些技術(shù)可以幫助提高傳感器網(wǎng)絡(luò)的性能,更充分發(fā)揮硬件的特性,降低其功耗,并簡化應(yīng)用程序開發(fā)過程。
[0007]NesC語言是對C語言的擴(kuò)展,但與C語言不同的是它是組件化的且它的工作執(zhí)行模式是基于事件驅(qū)動的。NesC采用面向組件編程,并且支持在傳感網(wǎng)上的應(yīng)用開發(fā)。TinyOS是一種新型操作系統(tǒng),它是由NesC語言編寫的。大多數(shù)基于TinyOS操作系統(tǒng)的應(yīng)用軟件是用NesC,相比之前的編程語言NesC的傳感網(wǎng)的開發(fā)和應(yīng)用更方便。組件和接口分別是NesC語言中兩個基礎(chǔ)的概念。組件可以提供接口,與此同時,其他組件也可以使用這個組件的某些功能,其使用方法是通過引用相同接口聲明。不同的組件通過這種方式來實現(xiàn)組件間的相互調(diào)用。配件是組件的一種,配件實質(zhì)是用來描述不同組件接口之間的調(diào)用關(guān)系;模塊的組件另一種定義形式,其主要描述具體實現(xiàn),如組件中涉及到的接口定義等。以上就是NesC語言組件的兩種定義形式,其性質(zhì)和功能是不同的。而NesC中的接口與組件是不同的,它是組件的一個部分,接口可以理解為函數(shù),也可以是理解為發(fā)生的事件,或者是程序或系統(tǒng)的命令,組件是通過接口來實現(xiàn)組件之間的相互銜接和相互聯(lián)系。
【發(fā)明內(nèi)容】
[0008]技術(shù)問題:本發(fā)明提出一種基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法,該方法主要用來實現(xiàn)基于有界模型檢驗的無線傳感網(wǎng)代碼驗證,緩解模型檢驗中的狀態(tài)空間爆炸問題。
[0009]技術(shù)方案:本發(fā)明所述的一種基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法,該方法首先通過對無線傳感網(wǎng)軟件源代碼分析并建立動態(tài)查找表,然后建立軟件模型,該模型是無線傳感網(wǎng)軟件源代碼的靜態(tài)結(jié)構(gòu)和動態(tài)行為的抽象,在此基礎(chǔ)上定義模型轉(zhuǎn)換規(guī)則,實現(xiàn)軟件模型轉(zhuǎn)化向C語言的代碼轉(zhuǎn)化,最后使用有界模型檢驗工具對轉(zhuǎn)化后的代碼進(jìn)行有界模型檢驗。基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法具體步驟如下:
[0010]步驟1、對無線傳感網(wǎng)軟件源代碼中的每個節(jié)點進(jìn)行編號,執(zhí)行程序,并根據(jù)執(zhí)行的順序記錄節(jié)點編號和代碼行;
[0011]步驟2、提取代碼的控制流結(jié)構(gòu),用控制流程圖描述程序各分支語句,并定義對應(yīng)模塊;
[0012]步驟3、建立動態(tài)查找表,所述動態(tài)查找表是步驟2中提取的控制流與所記錄代碼行的對應(yīng)關(guān)系;
[0013]步驟4、對無線傳感網(wǎng)軟件源代碼建立對應(yīng)的軟件模型,所述軟件模型是無線傳感網(wǎng)軟件源代碼的靜態(tài)結(jié)構(gòu)和動態(tài)行為的抽象,用來描述節(jié)點以及節(jié)點之間的遷移關(guān)系;軟件模型的建立是通過相應(yīng)的無線傳感網(wǎng)軟件建模工具來完成的,該過程描述網(wǎng)絡(luò)拓?fù)浣Y(jié)構(gòu)固定情況下的軟件模型;[0014]步驟5、判斷上述軟件模型的正確性,若模型正確,則執(zhí)行步驟8,反之執(zhí)行步驟6 ;
[0015]步驟6、等待一隨機時間,重新執(zhí)行程序;
[0016]步驟7、判斷所記錄的節(jié)點編號和代碼行與上次相比,是否發(fā)生變化,若發(fā)生變化,則返回步驟4,反之退出整個流程;
[0017]步驟8、對無線傳感網(wǎng)軟件模型靜態(tài)結(jié)構(gòu)進(jìn)行抽象:
[0018]步驟81)用三元組的形式表示軟件模型,設(shè)置無線傳感網(wǎng)軟件模型為m =(t, n, r), m表示無線傳感網(wǎng)軟件模型,t表示網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu),η代表模型中的節(jié)點,r表示節(jié)點之間的遷移;
[0019]步驟82)將三元組對應(yīng)源代碼的具體結(jié)構(gòu),通過動態(tài)查找表將η對應(yīng)在代碼中是定義節(jié)點的結(jié)構(gòu)體,r對應(yīng)在不同模塊之間的調(diào)用關(guān)系;
[0020]步驟9、對無線傳感網(wǎng)軟件模型的動態(tài)行為進(jìn)行模擬分析,用來確定節(jié)點之間的調(diào)用關(guān)系以及執(zhí)行順序,啟動模擬器,使用模擬器模擬無線傳感網(wǎng)軟件模型的動態(tài)行為獲取各節(jié)點函數(shù)的執(zhí)行關(guān)系并記錄;啟動驗證器,執(zhí)行對模型的正確性分析與驗證來實現(xiàn)對無線傳感網(wǎng)軟件的分析;
[0021]步驟10、定義模型轉(zhuǎn)換規(guī)則,所述模型轉(zhuǎn)化規(guī)則是由用戶定義的模型與目標(biāo)語言之間的映射關(guān)系,根據(jù)這些關(guān)系將模型中的各個部分轉(zhuǎn)化為目標(biāo)代碼的形式之后,進(jìn)行有界模型檢驗;用戶定義模型轉(zhuǎn)換規(guī)則的過程為:首先,定義節(jié)點轉(zhuǎn)換規(guī)則,實現(xiàn)節(jié)點到目標(biāo)代碼的轉(zhuǎn)換;其次,定義節(jié)點遷移的轉(zhuǎn)換規(guī)則,將節(jié)點之間的調(diào)用關(guān)系對應(yīng)到目標(biāo)代碼;
[0022]步驟11、根據(jù)步驟10中定義的模型轉(zhuǎn)換規(guī)則,實現(xiàn)模型到目標(biāo)代碼的轉(zhuǎn)換,所述轉(zhuǎn)換過程是將模型中的各個結(jié)構(gòu)對應(yīng)于模型轉(zhuǎn)換規(guī)則,通過模型轉(zhuǎn)換規(guī)則中的定義實現(xiàn)目標(biāo)代碼;
[0023]步驟12、對轉(zhuǎn)換后的目標(biāo)代碼進(jìn)行有界模型檢驗,所述有界模型檢驗的過程是使用有界模型檢驗工具對轉(zhuǎn)換后的目標(biāo)代碼進(jìn)行有界模型檢驗,實現(xiàn)無線傳感網(wǎng)軟件代碼驗證,緩解模型檢驗中的狀態(tài)空間爆炸問題。
[0024]有益效果:本發(fā)明所述的一種基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法,分析與應(yīng)用相關(guān)的軟件是否滿足要求,分析能力強、可讀性高,能盡早發(fā)現(xiàn)軟件存在的缺陷和不正確性,其采用的形式化方法可以驗證復(fù)雜系統(tǒng)。具體來說,本發(fā)明所述的方法具有如下的有益效果:
[0025]1、本發(fā)明所述的種基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法包括對無線傳感網(wǎng)軟件進(jìn)行源代碼建模、對所得到的軟件模型進(jìn)行靜態(tài)結(jié)構(gòu)和動態(tài)行為的分析、定義模型轉(zhuǎn)換規(guī)則實現(xiàn)模型到目標(biāo)語言的轉(zhuǎn)化、使用有界模型檢驗工具進(jìn)行有界模型檢驗。
[0026]2、本發(fā)明所述對無線傳感網(wǎng)軟件進(jìn)行源代碼建模使用相應(yīng)的建模工具進(jìn)行建模,該過程的實現(xiàn)是自動化實現(xiàn)的,可以保證無線傳感網(wǎng)軟件模型的正確性。
[0027]3、本發(fā)明所述的對無線傳感網(wǎng)軟件的模型分析包括靜態(tài)結(jié)構(gòu)分析和動態(tài)行為分析,靜態(tài)結(jié)構(gòu)的分析主要用于確定模型中的節(jié)點以及節(jié)點之間的遷移關(guān)系,動態(tài)行為模擬分析用于確定模型中的節(jié)點的調(diào)用順序以及節(jié)點執(zhí)行關(guān)系。
[0028]4、本發(fā)明所述的對無線傳感網(wǎng)軟件的模型轉(zhuǎn)換規(guī)則是無線傳感網(wǎng)軟件模型到目標(biāo)代碼的映射關(guān)系,根據(jù)模型轉(zhuǎn)換規(guī)則,可以實現(xiàn)軟件模型向目標(biāo)代碼的轉(zhuǎn)化,進(jìn)而進(jìn)行有界模型檢驗。[0029]5、本發(fā)明所述的無線傳感網(wǎng)軟件代碼驗證方法是基于有界模型檢驗的,該方法是通過有界的方法來緩解狀態(tài)空間爆炸問題。
【專利附圖】
【附圖說明】
[0030]圖1是基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證過程流程圖,
[0031]圖2是BlinktoRadio程序的部分靜態(tài)分析圖。
【具體實施方式】
[0032]下面對本發(fā)明附圖的某些實施例作更詳細(xì)的描述。
[0033]根據(jù)圖1,本發(fā)明所述的是一種基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證過程,該方法建立在模型檢驗技術(shù)的基礎(chǔ)上,將算法應(yīng)用在無線傳感網(wǎng)中的BlinkToRadio協(xié)議上,并借助建模工具NesClgPAT和有界模型檢驗工具CBMC。協(xié)議源代碼是NesC語言,目標(biāo)代碼是C語言?!揪唧w實施方式】為:
[0034]1、給BlinkToRadio源代碼中每個節(jié)點進(jìn)行編號,且保證每個節(jié)點的編號是唯一的,執(zhí)行程序,并記錄BlinkToRadio在執(zhí)行過程中的節(jié)點編號和代碼行。
[0035]2、提取BlinkToRadio代碼的控制流,用控制流程圖描述程序各分支語句,并定義對應(yīng)模塊,建立動態(tài)查找表,該動態(tài)查找表記錄BlinkToRadio代碼控制流與所記錄代碼行的對應(yīng)關(guān)系。
[0036]3、建立BlinkToRadio的軟件模型,所述BlinkToRadio軟件模型是由傳感器節(jié)點以及網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu)共同組成。判斷該模型正確后,將無線傳感網(wǎng)軟件模型表示為Hl =(t, n, r)三元組的形式表示無線傳感網(wǎng)軟件模型,t表示網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu),這里是指Ring結(jié)構(gòu),η為BlinkToRadio模型中的節(jié)點,r表示節(jié)點之間的遷移。
[0037]4、對所得的BlinkToRadio軟件模型進(jìn)行分析。
[0038]41)軟件模型靜態(tài)結(jié)構(gòu)的分析。模型靜態(tài)結(jié)構(gòu)中的節(jié)點以及相應(yīng)的連接關(guān)系與源代碼的是一致的。所述的靜態(tài)結(jié)構(gòu)分析是指從編程語言本身出發(fā),確定程序結(jié)構(gòu)。BlinkToRadio是無線傳感網(wǎng)一個的應(yīng)用程序,其實現(xiàn)部分主要包含了三個節(jié)點、一個定時器、一個計數(shù)值,發(fā)送計數(shù)值,用NesC編寫的BlinkToRadio包含了三個子文件分別為BlinkToRadioC.nc、BlinkToRadi0.h、BlinkToRadioAppC.nc。BlinkToRadioC.nc 如圖 2。
[0039]42)軟件動態(tài)行為的模擬分析,用來確定節(jié)點之間的調(diào)用關(guān)系以及執(zhí)行順序。所述BlinkToRadio動態(tài)行為主要包含三個部分分別是建模、執(zhí)行分析和報告結(jié)果?;谀P蜋z驗的無線傳感網(wǎng)軟件源代碼分析是通過對無線傳感網(wǎng)軟件源代碼建模來實現(xiàn)軟件的分析,并通過對模型的正確性分析與驗證來實現(xiàn)對軟件的分析。對無線傳感網(wǎng)軟件源代碼的建模是基于工具NesOgPAT的,該工具能實現(xiàn)NesC代碼的編輯以及詞法分析、語法分析等。
[0040]5、定義模型轉(zhuǎn)換規(guī)則。所述模型轉(zhuǎn)化規(guī)則是定義模型與目的語言之間的映射關(guān)系,將模型中的各個部分轉(zhuǎn)化為目的代碼的形式,從而進(jìn)行有界模型檢驗。
[0041]51)模型中節(jié)點的接口轉(zhuǎn)換規(guī)則。接口具有雙重的性質(zhì),它能夠描述兩種不同的函數(shù),其中一種是接口的提供者提供的函數(shù),另一種是在接口的使用者所實現(xiàn)的函數(shù)。該內(nèi)容在C語言中則為函數(shù)的定義,定義了不同對象之間的信息的發(fā)送與接收。
[0042]52)模型中節(jié)點的組件轉(zhuǎn)換規(guī)則。其主要是利用接口與其他組件相互連接,這種連接是一種靜態(tài)連接,此方法有利于對程序進(jìn)行靜態(tài)分析,同時也會增加程序運行時的效率。在C語言中不同的組件則為不同的結(jié)構(gòu)體,其可以采用結(jié)構(gòu)體的形式表達(dá)。
[0043]53)模型中節(jié)點的模塊轉(zhuǎn)換規(guī)則。它模塊中主要包含了模塊使用和提供的接口描述以及模塊內(nèi)部的實現(xiàn)代碼兩大部分,其實現(xiàn)部分一般為C語言,其聲明部分則是自己模塊內(nèi)的函數(shù)聲明以及所需調(diào)用的其他模塊內(nèi)的函數(shù)的聲明的集合。
[0044]54)模型中節(jié)點的配置轉(zhuǎn)換規(guī)則。其可以映射為C語言中不同模塊之間的調(diào)用關(guān)系,配置文件在C語言中不必單獨存在,其調(diào)用關(guān)系可以通過不同模塊中的函數(shù)調(diào)用來實現(xiàn)。
[0045]55)模型中節(jié)點的命令轉(zhuǎn)換規(guī)則。命令是一種函數(shù),其關(guān)鍵字為co_and。command的實現(xiàn)是通過接口的提供者來完成的,其調(diào)用過程是由接口的使用者完成。command的語法結(jié)構(gòu)與C語言是一致的,在C語言所定義函數(shù)前面加關(guān)鍵字co_and,它實現(xiàn)可調(diào)用的命令,接口可以調(diào)用這些命令。
[0046]56)模型中節(jié)點的事件轉(zhuǎn)換規(guī)則。事件也是一種函數(shù),它是在程序的接口中定義的,其關(guān)鍵字為event。此函數(shù)與C語言一致,其定義中可以有函數(shù)參數(shù)、返回值等,它要求調(diào)用過程是由接口的提供者完成,實現(xiàn)是由接口的使用者來完成,在定義中前面須加關(guān)鍵字 event ο
[0047]57) Sensorl.App.call.AMControl.start O 是節(jié)點 Sensorl 的初始化函數(shù),節(jié)點被喚醒時需要調(diào)用此函數(shù),將其轉(zhuǎn)換為C語言中節(jié)點的變量初始值函數(shù),其執(zhí)行功能與C++中的構(gòu)造函數(shù)等同。
[0048]58)#assert語句是模型的動態(tài)執(zhí)行分析的判定語句,它用LTL語言描述。語句#assert SensorNetwork = [] (Sensorl.send-><> (Sensor2.rcv_msg));該語句具體解釋為Sensorl節(jié)點發(fā)送消息,判斷Sensor2是否接收。C語言支持assert O函數(shù),把需要判定的內(nèi)容以變量表達(dá)作為assert O函數(shù)的參數(shù)來判定。
[0049]6、根據(jù)模型轉(zhuǎn)換規(guī)則,實現(xiàn)模型到目標(biāo)代碼的轉(zhuǎn)換。所述轉(zhuǎn)換是將模型中的各個結(jié)構(gòu)對應(yīng)于模型轉(zhuǎn)換規(guī)則,通過模型轉(zhuǎn)換規(guī)則中的定義實現(xiàn)目標(biāo)代碼。
[0050]7、對轉(zhuǎn)換后的目標(biāo)代碼進(jìn)行有界模型檢驗。所述有界模型檢驗的過程是使用有界模型檢驗工具CBMC對轉(zhuǎn)換后的BlinkToRadio目標(biāo)代碼進(jìn)行有界模型檢驗,實現(xiàn)無線傳感網(wǎng)軟件代碼驗證,緩解模型檢驗中的狀態(tài)空間爆炸問題。
【權(quán)利要求】
1.一種基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法,其特征在于該方法首先通過對無線傳感網(wǎng)軟件源代碼分析并建立動態(tài)查找表,然后建立軟件模型,該模型是無線傳感網(wǎng)軟件源代碼的靜態(tài)結(jié)構(gòu)和動態(tài)行為的抽象,在此基礎(chǔ)上定義模型轉(zhuǎn)換規(guī)則,實現(xiàn)軟件模型轉(zhuǎn)化向C語言的代碼轉(zhuǎn)化,最后使用有界模型檢驗工具對轉(zhuǎn)化后的代碼進(jìn)行有界模型檢驗,基于有界模型檢驗的無線傳感網(wǎng)軟件代碼驗證方法具體步驟如下: 步驟1、對無線傳感網(wǎng)軟件源代碼中的每個節(jié)點進(jìn)行編號,執(zhí)行程序,并根據(jù)執(zhí)行的順序記錄節(jié)點編號和代碼行; 步驟2、提取代碼的控制流結(jié)構(gòu),用控制流程圖描述程序各分支語句,并定義對應(yīng)模塊; 步驟3、建立動態(tài)查找表,所述動態(tài)查找表是步驟2中提取的控制流與所記錄代碼行的對應(yīng)關(guān)系; 步驟4、對無線傳感網(wǎng)軟件源代碼建立對應(yīng)的軟件模型,所述軟件模型是無線傳感網(wǎng)軟件源代碼的靜態(tài)結(jié)構(gòu)和動態(tài)行為的抽象,用來描述節(jié)點以及節(jié)點之間的遷移關(guān)系;軟件模型的建立是通過相應(yīng)的無線傳感網(wǎng)軟件建模工具來完成的,該過程描述網(wǎng)絡(luò)拓?fù)浣Y(jié)構(gòu)固定情況下的軟件模型; 步驟5、判斷上述軟件模型的正確性,若模型正確,則執(zhí)行步驟8,反之執(zhí)行步驟6 ; 步驟6、等待一隨機時間,重新執(zhí)行程序; 步驟7、判斷所記錄的節(jié)點編號和代碼行與上次相比,是否發(fā)生變化,若發(fā)生變化,則返回步驟4,反之退出整個流程; 步驟8、對無線傳感網(wǎng)軟件模型靜態(tài)結(jié)構(gòu)進(jìn)行抽象: 步驟81)用三元組的形式表示軟件模型,設(shè)置無線傳感網(wǎng)軟件模型為m= (t,n,r),m表示無線傳感網(wǎng)軟件模型,t表示網(wǎng)絡(luò)的拓?fù)浣Y(jié)構(gòu),η代表模型中的節(jié)點,r表示節(jié)點之間的遷移; 步驟82)將三元組對應(yīng)源代碼的具體結(jié)構(gòu),通過動態(tài)查找表將η對應(yīng)在代碼中是定義節(jié)點的結(jié)構(gòu)體,r對應(yīng)在不同模塊之間的調(diào)用關(guān)系; 步驟9、對無線傳感網(wǎng)軟件模型的動態(tài)行為進(jìn)行模擬分析,用來確定節(jié)點之間的調(diào)用關(guān)系以及執(zhí)行順序,啟動模擬器,使用模擬器模擬無線傳感網(wǎng)軟件模型的動態(tài)行為獲取各節(jié)點函數(shù)的執(zhí)行關(guān)系并記錄;啟動驗證器,執(zhí)行對模型的正確性分析與驗證來實現(xiàn)對無線傳感網(wǎng)軟件的分析; 步驟10、定義模型轉(zhuǎn)換規(guī)則,所述模型轉(zhuǎn)化規(guī)則是由用戶定義的模型與目標(biāo)語言之間的映射關(guān)系,根據(jù)這些關(guān)系將模型中的各個部分轉(zhuǎn)化為目標(biāo)代碼的形式之后,進(jìn)行有界模型檢驗;用戶定義模型轉(zhuǎn)換規(guī)則的過程為:首先,定義節(jié)點轉(zhuǎn)換規(guī)則,實現(xiàn)節(jié)點到目標(biāo)代碼的轉(zhuǎn)換;其次,定義節(jié)點遷移的轉(zhuǎn)換規(guī)則,將節(jié)點之間的調(diào)用關(guān)系對應(yīng)到目標(biāo)代碼; 步驟11、根據(jù)步驟10中定義的模型轉(zhuǎn)換規(guī)則,實現(xiàn)模型到目標(biāo)代碼的轉(zhuǎn)換,所述轉(zhuǎn)換過程是將模型中的各個結(jié)構(gòu)對應(yīng)于模型轉(zhuǎn)換規(guī)則,通過模型轉(zhuǎn)換規(guī)則中的定義實現(xiàn)目標(biāo)代碼; 步驟12、對轉(zhuǎn)換后的目標(biāo)代碼進(jìn)行有界模型檢驗,所述有界模型檢驗的過程是使用有界模型檢驗工具對轉(zhuǎn)換后的目標(biāo)代碼進(jìn)行有界模型檢驗,實現(xiàn)無線傳感網(wǎng)軟件代碼驗證,緩解模型檢驗中的狀態(tài)空間爆炸問題。
【文檔編號】G06F11/36GK103970652SQ201410179163
【公開日】2014年8月6日 申請日期:2014年4月29日 優(yōu)先權(quán)日:2014年4月29日
【發(fā)明者】陳志 , 岳書珍, 岳文靜, 王東, 黨凱樂, 陳駿, 朱彥沛, 高陽陽, 高顯強 申請人:南京郵電大學(xué)