日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 工業(yè)控制 > 電子設(shè)計自動化
[導(dǎo)讀]本文介紹一種通過分析和修改GCC編譯工具,實現(xiàn)程序插裝的新方法。該方法具有批量自動插裝,插裝與編譯連接緊密結(jié)合,適用語言廣泛等優(yōu)點。最后具體討論了如何在ARM嵌入式程序中實現(xiàn)程序插裝,并給出修改GCC的源代碼。

本文介紹一種通過分析和修改GCC編譯工具,實現(xiàn)程序插裝的新方法。該方法具有批量自動插裝,插裝與編譯連接緊密結(jié)合,適用語言廣泛等優(yōu)點。最后具體討論了如何在ARM嵌入式程序中實現(xiàn)程序插裝,并給出修改GCC的源代碼。

引 言

程序插裝(Program Instrumentation)概念最先是由J.G.Huang教授提出,是借助往被測程序中插入操作(稱為“探針”),以便獲取程序的控制流和數(shù)據(jù)流信息,從而實現(xiàn)測試目的的方法。在軟件動態(tài)測試中,程序插裝是一種基本的測試手段,應(yīng)用廣泛,是覆蓋率測試、軟件故障注入和動態(tài)性能分析的基礎(chǔ)技術(shù)。

GCC(GNU Compiler Collection)是一個高度優(yōu)化,高度可移植,廣泛使用的編譯系統(tǒng)。它能處理多種語言,包括C/C++、Fortran、Java和Pascal等多種語言前端,而且后端支持幾乎所有的處理器結(jié)構(gòu)。GCC作為源碼開放的軟件,人們可以自由修改和使用;加入插裝模塊后,在GCC所支持的語言中都可插入相應(yīng)的測試代碼(這里只介紹C語言的插裝模塊)。本文將詳細(xì)敘述如何修改GCC,使其在編譯每個C函數(shù)時,分別將各個形式參數(shù)連同該函數(shù)名傳遞給一個指定函數(shù)。該指定函數(shù)的返回值賦予原來的形式參數(shù),從而可以人為控制被插裝函數(shù)的每個參數(shù)實際值,進而完成各種規(guī)則下的測試。

1 GCC編譯流程分析

編譯器的工作是將源代碼(通常使用高級語言編寫)翻譯成目標(biāo)代碼(通常是低級的目標(biāo)代碼或者機器語言)。在現(xiàn)代編譯器的實現(xiàn)中,這個工作一般是分為兩個階段來實現(xiàn)的:

第一階段,編譯器的前端接收輸入的源代碼,經(jīng)過詞法、語法和語義分析等得到源程序的某種中間表示方式。

第二階段,編譯器的后端將前端處理生成的中間表示方式進行一些優(yōu)化,并最終生成在目標(biāo)機器上可運行的代碼。

GCC編譯器以一個函數(shù)為單位對經(jīng)過預(yù)處理的輸入源文件進行編譯處理。根據(jù)GNU Bison(一個類似YACC但功能更強大的文法分析工具)生成的語法分析程序,前端完成語法、語義分析,建立語法樹,并轉(zhuǎn)換成中間代碼。GCC內(nèi)部使用了一種能對實際的體系結(jié)構(gòu)做一種抽象的,與硬件平臺無關(guān)的語言,這個中間語言就是RTL(Register Ttansfer Language)。通過修改源程序的RTL,可以改變、刪除源程序,包括插入所需要的代碼,由GCC后端處理并最終輸出對應(yīng)硬件平臺的匯編碼,源程序無需手工修改便可實現(xiàn)插裝功能。

GCC的入口點main函數(shù)在文件main.c中。此函數(shù)非常簡單,只有一條直接調(diào)用toplev_main函數(shù)的語句。toplev_main函數(shù)是在toplev.c文件中定義的,以下我們只關(guān)心與編譯有關(guān)的源碼,其他的暫時忽略。toplev_main中最重要的是調(diào)用了do_complile函數(shù),這個函數(shù)從名字看就是做編譯工作的;而在此之后,toplev_main函數(shù)就返回了。dD_compile函數(shù)也是在tokv.c中定義的,其中真正進行編譯工作的是調(diào)用compilte_file函數(shù)。compik_file函數(shù)最終調(diào)用了一個鉤子函數(shù)來分析(parse)整個輸入文件:

(*lang_hooks.parse_file)(set_yydebug);

這里的lang_hooks是一個全局變量,不同語言的前端對此賦以不同的值。對C語言來說,這條語句相當(dāng)于調(diào)用了c-opts.c中的c_common_parse_file函數(shù)。c_com-mon_parse_file中調(diào)用了c-parse.c中的c_parse_file函數(shù);在此函數(shù)中又調(diào)用了同文件中的yyparse函數(shù),該函數(shù)負(fù)責(zé)解析C語言源文件,并轉(zhuǎn)化為特殊的語法樹結(jié)構(gòu)。該函數(shù)是GNU bison將YACC轉(zhuǎn)變?yōu)镃語言而自動生成的,所以這段代碼閱讀起來比較困難,但我們并不關(guān)心語法分析的細(xì)節(jié)。在完成函數(shù)體的分析后,利用已經(jīng)建立的tree結(jié)構(gòu)生成RTL,優(yōu)化后最終輸出匯編碼;自此C函數(shù)的編譯就算結(jié)束了,這些是由yyparse調(diào)用finish_function函數(shù)完成的。finish_function函數(shù)中最重要的函數(shù)是tree_rest_of_compilation(定義在tree_optimize.c中),它是真正實現(xiàn)上述功能的函數(shù)。為了說明它所做的具體事情,我們將該函數(shù)做了刪減,保留了關(guān)鍵的地方。

將函數(shù)各個部分展開成RTL形式后,調(diào)用函數(shù)rest_of_compilation將RTL輸出為匯編碼。至此,得到了一張清晰的GCC編譯時的函數(shù)調(diào)用路線。

2 基于GCC的程序插裝技術(shù)

根據(jù)插裝測試的要求,需要在函數(shù)開始時為每個參數(shù)調(diào)用鉤子函數(shù),并用鉤子函數(shù)的返回值更新參數(shù)的值;同時,將被插裝函數(shù)的名稱壓入函數(shù)本地棧內(nèi),作為該函數(shù)的一個匿名本地變量,只用于傳遞給鉤子函數(shù)。從上面列出的tree_rest_of_compilation函數(shù)源碼得知,負(fù)責(zé)建立被編譯函數(shù)參數(shù)和返回值的函數(shù)是expand_function_start,定義是在文件function.c中。expand_function_start中處理函數(shù)參數(shù)和返回值的函數(shù)是assign_parms,這是需要特別關(guān)注的函數(shù)。

斜體加粗的部分是增加的代碼。在for循環(huán)前,獲得當(dāng)前編譯的函數(shù)名(見源碼中①位置);但暫時不能輸出到函數(shù)的RTL鏈中,因為本地棧要在所有參數(shù)傳遞完畢才完全建立起來。在for循環(huán)體結(jié)束前,記錄下函數(shù)參數(shù)的一份拷貝(見②),最后調(diào)用。insert_function_name_local函數(shù),將當(dāng)前函數(shù)名插入本地棧,并且修正棧指針(見③)。經(jīng)過以上修改,得到了插裝所需的所有信息,包括函數(shù)參數(shù)和函數(shù)名稱的RTX表示。GCC將函數(shù)編譯后生成的RTX表示以鏈表形式組織,最后一次性把這個RTX鏈表輸出為后端平臺的匯編碼。完成這項工作的是rest_of_compilation函數(shù),所以在調(diào)用rest_of_complilation函數(shù)前插入我們的RTX,最終完成插裝,由函數(shù)inject_rtl負(fù)責(zé)完成。

3 APCS與程序插裝實現(xiàn)

編譯器必須以一套統(tǒng)一的方法編譯函數(shù)的定義和調(diào)用過程,才能確保不同語言編寫的函數(shù)能相互調(diào)用。規(guī)定這些細(xì)節(jié)的便叫作“函數(shù)調(diào)用規(guī)范(Procedure Call Stand-ard)”。ARM體系結(jié)構(gòu)定義了自己的函數(shù)調(diào)用規(guī)范——ARM函數(shù)調(diào)用標(biāo)準(zhǔn)(ARM Procedure Call Standard,APCS)。雖然APCS不是強制性的,但實現(xiàn)APCS并不困難,而且可獲得統(tǒng)一的二進制兼容的好處,所以大部分的編譯器都實現(xiàn)了APCS,其中包括GCC。

APCS中函數(shù)傳遞參數(shù)的定義如下:

◇前4個整數(shù)實參(或者更少)被裝載到r0~r3。前4個整數(shù)實參(或者更少)被裝載到r0~r3。

◇前4個浮點實參(或者更少)被裝載到f0~f3。

◇如果參數(shù)為雙字(8字節(jié)),就必須從偶數(shù)寄存器開始放置。

◇如果一個參數(shù)不能完全放入寄存器中,則超過的那部分拷貝到棧中。

其他任何實參(如果有的話)存儲在內(nèi)存中,用進入函數(shù)時緊接在sp值上面的字來指向。換句話說,其余的參數(shù)被壓入棧頂。所以,要想簡單,最好定義接受4個或更少的整數(shù)參數(shù)的函數(shù)。

本文所述的插入函數(shù)只有兩個整型形參,所以調(diào)用時只需將兩個實參分別傳入ro和rl。GCC提供emit_li-brary_call函數(shù)用來生成函數(shù)調(diào)用的RTL碼,GCC將按照APCS產(chǎn)生正確的函數(shù)調(diào)用匯編碼。

4 實 例

為便于檢查插裝效果,用經(jīng)過修改的GCC編譯一段簡單的C語言程序。該程序為一個獨立函數(shù)foo,接受兩個整數(shù)類型的參數(shù)。

從GCC輸出的匯編碼可以看到,foo函數(shù)的兩個參數(shù)都經(jīng)過鉤子函數(shù)pt_hook_partns的處理更新;在pt_hook_parms函數(shù)內(nèi),可以根據(jù)測試算法返回不同的邊界值,從而達(dá)到測試的目的。依照此方法,一個實際程序經(jīng)過插裝后,在ARM模擬器上順利運行,并取得預(yù)期的測試效果。

結(jié)語

本文詳細(xì)地論述了修改GCC增加插裝功能的實現(xiàn)方法。按照這樣的思路,成功地實現(xiàn)了基于ARM7芯片的嵌入式系統(tǒng)的動態(tài)參數(shù)邊界測試,達(dá)到了預(yù)期的效果。本文所述的插裝函數(shù)比較簡單,沒有區(qū)分參數(shù)的類型,所有參數(shù)均按照一個字大小來處理;下一步的工作是細(xì)分參數(shù)不同類型,插裝不同的處理函數(shù)。作為一種通用的插裝方法,在此摹礎(chǔ)上.通過識別不同的插裝點和插裝不同的函數(shù),可以實現(xiàn)函數(shù)調(diào)用棧檢查,程序覆蓋率測試,獲取函數(shù)實際執(zhí)行時間等需要插裝技術(shù)作為基礎(chǔ)的功能。



來源:ks990次

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

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當(dāng)下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉