|
嵌入式學(xué)習(xí)目標(biāo)_可重定目標(biāo)的嵌入式集成開發(fā)平臺(tái)設(shè)計(jì),
引 言
嵌入式應(yīng)用軟件的開發(fā)與通用計(jì)算機(jī)軟件開發(fā)不同,由于受資源約束,嵌入式軟件開發(fā)一般需要在專門的開發(fā)平臺(tái)上進(jìn)行交叉開發(fā)(cross developing)。
同時(shí),由于嵌入式系統(tǒng)的開發(fā)及嵌入式軟件的調(diào)試也非常復(fù)雜,因而迫切需要強(qiáng)有力的集成開發(fā)平臺(tái)(Integrated Development En-vironment,IDE)作為支持,以保證程序執(zhí)行的實(shí)時(shí)性、可靠性,保障軟件質(zhì)量,并縮短開發(fā)時(shí)間。因而,對MCU系統(tǒng)開發(fā)平臺(tái)和開發(fā)環(huán)境的研究近年來備受重視,出現(xiàn)了比較著名的嵌入式開發(fā)軟件,如ImageCraft公司的IC-CAVR、Freescale公司的CodeWarrior等。
當(dāng)前,在我國高等院校及嵌入式系統(tǒng)產(chǎn)品的研發(fā)企業(yè)中,絕大多數(shù)都使用國外的嵌入式系統(tǒng)集成開發(fā)平臺(tái)。原因很簡單:MCU絕大多數(shù)是進(jìn)口的,國外集成開發(fā)平臺(tái)功能完善、穩(wěn)定。另外,由于嵌入式系統(tǒng)集成開發(fā)平臺(tái)具有芯片相關(guān)性,這就為我國研制嵌入式系統(tǒng)集成開發(fā)平臺(tái)增加了難度。因此,開發(fā)具有自主知識(shí)產(chǎn)權(quán)的嵌入式系統(tǒng)集成開發(fā)平臺(tái)是一件很有意義且具有挑戰(zhàn)性的工作。從2001年開始,蘇州大學(xué)在Motorola M68HC08系列MCU上嘗試開展這一工作,并開發(fā)了MT-HC08/S08型嵌入式集成開發(fā)平臺(tái),命名為“MT-IDE For Motorola HC08/S08”。
為了克服開發(fā)平臺(tái)適用范圍的局限性,通過實(shí)驗(yàn)確定,開發(fā)平臺(tái)模塊可分為“與芯片無關(guān)”和“與芯片有關(guān)”兩大部分,這樣就可徹底地分割開來,實(shí)現(xiàn)可重定目標(biāo)。因而,在先前研究的基礎(chǔ)上又成功研發(fā)了可重定目標(biāo)的集成開發(fā)平臺(tái)(SdIDE),且已成功應(yīng)用于Freescale HC08/S08/S12、M*Core、C*Core、ColdFire及ARM等系列MCU芯片。本文主要介紹這項(xiàng)成果,并對開發(fā)平臺(tái)的可重定性和通用性的關(guān)鍵技術(shù)給出必要的闡述。
1 設(shè)計(jì)思路
考慮到GNU Tools是開源軟件,且完全覆蓋編譯開發(fā)工具(如gcc等)、調(diào)試工具(如gdb)等)和軟件工程工具(如make等),可有效地開發(fā)嵌入式系統(tǒng)。因而,選擇GNU Tools作為IDE的交叉開發(fā)工具,會(huì)有較好的推廣前景。在設(shè)計(jì)過程中,重點(diǎn)考慮以下三個(gè)方面。
1.1 編程調(diào)試器方案的確定
在早期的MCU開發(fā)中,程序固化于EPROM中,擦除時(shí)間較長,操作繁瑣,程序調(diào)試?yán)щy。為解決此問題,仿真器技術(shù)得以較快發(fā)展,用軟件來模擬目標(biāo)系統(tǒng)中MCU的運(yùn)行情況,但是使用仿真器往往把目標(biāo)硬件與軟件獨(dú)立開來,難以實(shí)現(xiàn)100%的硬件模擬。
片內(nèi)Flash 儲(chǔ)器的使用,使得嵌入式系統(tǒng)的開發(fā)可以不再使用仿真器,而是直接調(diào)試目標(biāo)系統(tǒng)。Flash存儲(chǔ)器雖然有寫入、擦除次數(shù)、壽命方面的限制,但一般都可以達(dá)到10萬次以上,故開發(fā)過程中不必顧及Flash的壽命問題。目前單片機(jī)內(nèi)Flash都是可以在線編程的,即在線寫入、擦除,在線調(diào)試程序。由此可見,如今嵌入式系統(tǒng)的開發(fā)可以徹底脫離仿真器方式。所以,本文設(shè)計(jì)的編程調(diào)試器是充分利用Flash存儲(chǔ)器特點(diǎn),直接面向目標(biāo)系統(tǒng)的編程調(diào)試方式(如BKGD模式)。
1.2 開發(fā)平臺(tái)的通用性
一般嵌入式集成開發(fā)平臺(tái)都與具體的單片機(jī)相關(guān),很多集成開發(fā)平臺(tái)只能針對一種MCU芯片,移植起來非常不方便。本文在開發(fā)平臺(tái)的通用性上做了較深入研究,使其便于移植。在硬件相關(guān)部分盡可能對GNU Tools開發(fā)工具所支持的系列MCU通用,與MCU有相關(guān)性的參數(shù)由PC機(jī)方的IDE軟件處理,使IDE與MCU相對獨(dú)立?紤]到許多筆記本電腦沒有串行口,編程調(diào)試器與PC機(jī)的接口采用USB,以提高適用性。本文給出嵌入式系統(tǒng)集成開發(fā)平臺(tái)SdIDE,把系列MCU的下載與調(diào)試接口設(shè)計(jì)在一塊評估板上,可以適用于多種MCU型號(hào),對新型號(hào)也給出了加入方法。
1.3 開發(fā)平臺(tái)的可移植性
嵌入式開發(fā)平臺(tái)一般針對某一廠商生產(chǎn)的MCU,或針對某一系列MCU。但其中運(yùn)行于PC方的IDE在工程管理、編輯功能上具有公用性,編譯設(shè)置、下載與調(diào)試等功能雖然與硬件相關(guān),但可以通過調(diào)用參數(shù)數(shù)據(jù)庫的方式,用軟件的方法避免其直接與硬件打交道,提高IDE的可移植性。一種嵌入式開發(fā)平臺(tái)可以盡可能地做到對某一系列MCU通用,但很難做到適用所有的MCU。因而,沒計(jì)一個(gè)可以方便移植到其他系列MCU平臺(tái)上的IDE是很有意義的。本文在IDE可移植性方面做了大量的研究工作,并成功地將其移植到Freescale HC08/S08/S12系列微控制器、M*Core核的MMC2107微控制器、C*Core核的CCM3118微控制器、ColdFire核的MCF5271微控制器和ARM核的AT91RM9200微控制器上。
2 SdIDE集成開發(fā)平臺(tái)的軟件功能設(shè)計(jì)
可重定目標(biāo)集成開發(fā)平臺(tái)SdIDE是一個(gè)高度集成的標(biāo)準(zhǔn)的Win32界面,包含編輯器、編譯匯編鏈接器、調(diào)試器、工程管理、Flash在線編程及程序下載等交叉工具,采用Visual C++MFC編寫。該集成開發(fā)平臺(tái)包含工程管理、編輯、編譯、鏈接、程序下載與調(diào)試等功能,為了使其具有可重定目標(biāo)的特性,因而在其功能模塊上將其劃分為公共模塊和私有模塊兩大部分。下面具體介紹各個(gè)模塊的功能及其軟件設(shè)計(jì)思想。
2.1 SdIDE公共模塊
這里公共模塊是指與編譯器和目標(biāo)MCU無關(guān)的模塊,實(shí)現(xiàn)工程管理與編輯功能。設(shè)計(jì)時(shí),一定要把它們與整個(gè)系統(tǒng)切割開來,便于移植。
2.1.1 源文件編輯模塊
提供源文件編輯,支持剪切、復(fù)制、查找、替換,完全支持中文和語法高亮顯示(Syntax Highlight)。此部分主要的技術(shù)難點(diǎn)是語法高亮顯示,以及如何解決半個(gè)漢字問題。使用MFC的RichEdit控件可以解決此問題,但沒有語法高亮功能。作者在RichEdit的基礎(chǔ)上編寫了語法高亮類,使用效果較好。
2.1.2 工程管理
在SdIDE集成開發(fā)平臺(tái)中,工程是一個(gè)非常重要的概念,它是用戶組織一個(gè)應(yīng)用的所有源文件、設(shè)置編譯鏈接選項(xiàng)、生成調(diào)試信息文件和最終目標(biāo)文件的一個(gè)基本結(jié)構(gòu);提供對源文件、庫文件以及其他輸入文件的管理,并含有編譯與鏈接等設(shè)置。
2.2 SdIDE私有模塊
私有模塊是指與編譯器和目標(biāo)MCU相關(guān)的模塊,實(shí)現(xiàn)編譯、鏈接、程序下載與調(diào)試等功能。為了滿足可移植性,采用數(shù)據(jù)耦合的方式設(shè)計(jì)。
2.2.1 交叉編譯模塊
包括C/C++編譯器、匯編器、鏈接器、目標(biāo)文件格式轉(zhuǎn)換工具等。編譯模塊根據(jù)選用的MCU型號(hào)調(diào)用GNU移植過來的m68hcll、m68k、arm、mcore或ccore等編譯器,編譯成功后生成標(biāo)準(zhǔn)的Motorola S-record文件或Bin文件等。匯編器將匯編語言程序轉(zhuǎn)換為可重定位目標(biāo)代碼(如Elf格式,執(zhí)行時(shí)鏈接文件格式),易于定位和鏈接。鏈接器根據(jù)鏈接定位信息,將可重定位的目標(biāo)模塊鏈接成一個(gè)單一的、絕對定位的目標(biāo)程序,鏈接后的目標(biāo)程序可以包含調(diào)試信息。
2.2.2 程序下載模塊
在PC方編寫下載界面,通過設(shè)定MCU的環(huán)境變量及公用參數(shù),分析S格式文件后通過TBDML寫入頭,把數(shù)據(jù)下載到空白芯片。
2.2.3 調(diào) 試
與過去的仿真方式不同,本開發(fā)環(huán)境的調(diào)試是通過BDM頭直接對MCU中的程序進(jìn)行調(diào)試。BDM頭除實(shí)現(xiàn)Flash寫入、擦除功能外,還可以在應(yīng)用程序運(yùn)行時(shí),動(dòng)態(tài)地獲取CPU、存儲(chǔ)器等瞬態(tài)信息。BDM調(diào)試工具與單片機(jī)的通信通過雙向的BKGD引腳實(shí)現(xiàn)。調(diào)試模式有兩種:單步調(diào)試和斷點(diǎn)調(diào)試。
3 SdIDE可重定目標(biāo)的技術(shù)要點(diǎn)
3.1 GCC編譯器的基本特點(diǎn)及其調(diào)用的方法
該開發(fā)環(huán)境使用的是由GNU移植的GCC編譯器。GCC是由美國自由軟件基金(FSF)開發(fā)和維護(hù)的軟件,它是一個(gè)跨平臺(tái)的C語言編譯器,完全兼容ANSIC,支持目前大多數(shù)CPU體系,具有開放的開發(fā)模式,且性能優(yōu)異。SdIDE通過建立子進(jìn)程的方式調(diào)用該編譯器,具體方法如下:把GCC所支持的所有編譯器目錄放在該開發(fā)環(huán)境的安裝目錄下,采用線程管道的方法來捕獲由“make.exe-f”命令對makefile腳本文件(是針對GCC編譯器支持的所有MCU而編寫的較通用的腳本文件)進(jìn)行編譯的輸出信息流,并顯示在SdIDE的信息輸出窗口中。如果捕獲的編譯輸出信息出現(xiàn)任何錯(cuò)誤,包括源文件語法錯(cuò)誤和其他錯(cuò)誤,則編譯、鏈接操作立刻終止,并在輸出窗的Build子窗口中提示錯(cuò)誤。若是語法錯(cuò)誤,則用戶可以通過雙擊錯(cuò)誤提示行來定位引起錯(cuò)誤的源文件行,并且用語法高亮顯示。
3.2 更換編譯器的設(shè)計(jì)
為了實(shí)現(xiàn)SdIDE可重定目標(biāo)的特性,最主要的是要安排好如何編寫較通用的makefile腳本文件,這樣SdIDE開發(fā)環(huán)境可根據(jù)所選定的MCU型號(hào)來調(diào)用一個(gè)新的編譯器工具集。因而,在makefile中所有使用編譯器名的地方都用同一個(gè)變量來代替。更換編譯器時(shí),只需修改變量定義的地方,其他所有引用這個(gè)變量的地方不用改變。makefile是編程人員和make之間的接口,本設(shè)計(jì)通過寫makefile文件來說明各模塊的依賴關(guān)系。makefile文件要嚴(yán)格按其書寫規(guī)則來編寫,其中的內(nèi)容大致可分成宏定義區(qū)和基于依賴關(guān)系的指令區(qū)兩大部分。宏定義區(qū)主要是定義一些變量,可以在makefile的任何地方被引用;在建立makefile之后,就可以使用make命令來完成所需的編譯工作。
在SdIDE開發(fā)環(huán)境中更換編譯器的軟件設(shè)計(jì)思路如下:
① 把GCC支持的編譯器目錄全部放在開發(fā)環(huán)境的安裝目錄下,以便程序調(diào)用。
② 把Cygwin.dll復(fù)制SYSTEM32目錄下。為了在Windows平臺(tái)上構(gòu)建GNU工具鏈,需要安裝Cygwin。Cygwin是一個(gè)基于DLL的Unix仿真層(位于Win32之上)。它提供了Unix風(fēng)格的環(huán)境,包括Bashe外殼和GNU工具,這樣就可以建立交叉編譯器工具。
③ 在選定目標(biāo)平臺(tái)(即目標(biāo)芯片)后,程序自動(dòng)確定所需要調(diào)用的編譯器,把編譯器名賦給一個(gè)全局變量 |
|