《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計應(yīng)用 > 基于Windows平臺VxWorks交叉編譯工具的設(shè)計
基于Windows平臺VxWorks交叉編譯工具的設(shè)計
電子科技
陳家駿,鄭 明 西安交通大學(xué)
摘要: 本文生成的i586-wrs-vxworks交叉編譯工具鏈通過了大量的工程實踐與測試,可以良好地運行在基于Windows操作系統(tǒng)的PC機平臺上,編譯和鏈接基于Vx-Works平臺的程序,從而滿足了VxWorks商業(yè)軟件嵌入式應(yīng)用的開源化,能為客戶節(jié)約不少經(jīng)濟開銷,但是改進GCC對代碼的優(yōu)化還有待進一步的研究。
Abstract:
Key words :

摘要:在開發(fā)VxWorks嵌入式平臺時,開發(fā)廠商會推出一整套交叉編譯工具鏈來配合自身的嵌入式產(chǎn)品,但是這些由商業(yè)公司提供的工具鏈,都不會附有工具鏈相關(guān)的源代碼和制作方法,靈活性不足,并且它們一般都與整套開發(fā)系統(tǒng)捆綁銷售使用,成本較高。為了更好地理解這種技術(shù)和降低成本,使用了國際開源組織GNU開發(fā)的工具鏈作為產(chǎn)品開發(fā)的工具,提供了更好的使用靈活性。
關(guān)鍵詞:VxWorks;嵌入式平臺;交叉編譯;GCC;工具鏈

1 交叉編譯工具鏈功能說明
    交叉編譯技術(shù),就是一種在一個異構(gòu)平臺上編譯出目標(biāo)平臺程序的技術(shù)。比如在PC平臺(X86 CPU)上編譯出能運行在以VxWorks為內(nèi)核的CPU平臺上的程序,編譯得到的程序在X86 CPU平臺上是不能運行的,必須放到VxWorks CPU平臺上才能運行。
    每一個軟件在編譯的過程中都要經(jīng)過一系列的處理,才能從源代碼變成可執(zhí)行的目標(biāo)代碼。這一系列處理包括預(yù)編譯、高級語言編譯、匯編、鏈接及重定位。這一套流程里面用到的每個工具和相關(guān)的庫組成的集合,就稱為工具鏈(tool chain)。以GNU的開發(fā)工具GCC為例,它就包括了預(yù)編譯器CPP、C編譯器GCC、匯編器AS和鏈接器LD等。在GNU自己對工具鏈定義中,還加進了一套額外的用于處理二進制包的工具包Binutils,整個工具鏈應(yīng)該是GCC+Binutils+Glibc。對于i586-wrs-vxworks工具來說,因為在生成VxWorks交叉編譯工具鏈時,用到的C庫文件是從Tornado開發(fā)軟件中提取出來的,所以生成的實際交叉編譯工具鏈應(yīng)該是GCC+Binutils+Tornado(C庫文件)。GCC(GNU C Compiler)是一個C語言編譯器。隨著眾多自由開發(fā)者的加入和GCC自身的發(fā)展,如今的GCC已經(jīng)是一個包含眾多語言的編譯器了。其中包括C、C++、Ada、Object C和Java等。所以,GCC也就變?yōu)镚NU Compiler Collection,也就是GNU編譯器集合。當(dāng)然,如今的GCC借助其特性,具有了交叉編譯器的功能,所以又將GCC稱為交叉編譯工具鏈。

2 i586-wrs-vxworks交叉編譯工具鏈制作背景
    現(xiàn)在市場上有很多公司的PLC選用的是基于WindRiver(風(fēng)河)公司的Vxworks系列產(chǎn)品。
    一般說來,在開發(fā)VxWorks嵌入式的平臺時,開發(fā)廠商會推出一整套交叉編譯工具鏈來配合自身的嵌入式產(chǎn)品,但是這些由商業(yè)公司提供的工具鏈,都不會附有工具鏈相關(guān)的源代碼和制作方法,靈活性不足,并且它們一般都與整套開發(fā)系統(tǒng)捆綁銷售使用,成本較高。為了更好地理解這種技術(shù)和降低成本,我們使用了國際開源組織GNU開發(fā)的工具鏈作為產(chǎn)品開發(fā)的工具,提供了更好的使用靈活性。

3 交叉編譯工具鏈設(shè)計
    要構(gòu)建出一個交叉工具鏈,需要解決3個問題:
    ①這個工具鏈必須是可以運行在原工作站平臺上的。
    ②需要更換一個與目標(biāo)平臺對應(yīng)的匯編器,使得工具鏈能產(chǎn)生對應(yīng)的目標(biāo)代碼。
    ③要更換一套與目標(biāo)平臺對應(yīng)的二進制庫,使得工具鏈在連接時能找到正確的二進制庫。
    根據(jù)這樣的思路,采取了如下幾個步驟:
3.1 確定宿主機平臺、目標(biāo)機平臺及開發(fā)工具
    根據(jù)項目要求,GCC交叉編譯工具要能工作在基于Windows構(gòu)架的平臺,編譯生成的可執(zhí)行代碼要能夠滿足基于X86結(jié)構(gòu)的VxWorks嵌入式平臺。編譯時選用的開發(fā)平臺為Windows XP,開發(fā)工具為Cygwin。
    Cygwin當(dāng)初首先對GCC、GDB、GAS等開發(fā)工具進行了改進,使它們能夠生成并解釋W(xué)in32的目標(biāo)文件。然后,他們要把這些工具移植到Wi-ndows平臺上去。一種方案是基于Win32 API對這些工具的源代碼進行大幅修改,這樣顯然需要做大量工作。因此,采取了一種不同的方法——寫一個共享庫(cygwin.dll),把Win32 API中沒有的Unix風(fēng)格的調(diào)用(如fork、spawn、signals、select、sockets等)封裝在里面,也就是說,基于Win32 API寫了一個Llnix系統(tǒng)庫的模擬層。這樣,只要把這些工具的源代碼和這個共享庫連接到一起,就可以使用Unix主機上的交叉編譯器來生成可以在Windows平臺上運行的工具集。
    a.JPG
3.2 選擇開發(fā)資源包
    GCC、Binutils文件均有各自的版本號,不是任意組合都可以編譯成功并最終建立一個交叉編譯環(huán)境的?;诜€(wěn)定性方面考慮,這里選用的GCC和Binutils版本較老一點,但是大多數(shù)工程人員推薦的版本(Binutils-2.10,GCC-2.95.3)。
3.3 建立環(huán)境變量
    該步驟的目的是方便重復(fù)輸入路徑,直接輸入絕對路徑也是可行的。聲明以下環(huán)境變量的目的是在之后編譯工具庫的時候會用到,方便輸入,尤其是可以降低輸錯路徑的風(fēng)險。
    
    c.JPG
3.4 生成Binutils二進制庫
    Binutils是GNU工具之一,它包括鏈接器、匯編器和其他用于目標(biāo)文件和檔案的工具,是二進制代碼的處理維護工具。安裝Binutils工具包含的程序有addr2line、ar、as、c++filt、gprof、ld、am、objcopy、objdump、ranlib、readelf、size、strings、strip、libiberty、libbfd和libopcodes。
    首先安裝二進制工具,使用主機的GCC進行編譯。生成的交叉二進制工具i586-wrs-vxworks-ar、i586-wrs-vxwor-ks-as、i586-wrs-vxworks-ld等是編譯其他交叉程序的基礎(chǔ),所以必須放到第一步進行。編譯過程如下:
    d.JPG
    編譯完成以后,將會生成Binutils工具,對這些工具作用的解釋略——編者注。
3.5 生成i586-wrs-vxworks交叉編譯工具鏈
    配置參數(shù)如下:
    e.JPG
    執(zhí)行完編譯,安裝命令之后,將會在$PREFIX/bin/文件夾中生成工具。至此,一個完整的基于VxWorks的GCC交叉編譯工具鏈就建立起來了。

5 結(jié)論
    本文生成的i586-wrs-vxworks交叉編譯工具鏈通過了大量的工程實踐與測試,可以良好地運行在基于Windows操作系統(tǒng)的PC機平臺上,編譯和鏈接基于Vx-Works平臺的程序,從而滿足了VxWorks商業(yè)軟件嵌入式應(yīng)用的開源化,能為客戶節(jié)約不少經(jīng)濟開銷,但是改進GCC對代碼的優(yōu)化還有待進一步的研究。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。