TMS320C6713的軟件自動(dòng)更新方案設(shè)計(jì)
摘要 通過(guò)對(duì)COFF文件和TMS320C6713引導(dǎo)過(guò)程的分析,本文提出了一個(gè)在基于TMS320C6713 DSP系統(tǒng)上實(shí)現(xiàn)自動(dòng)軟件更新的方案,本方案只需要在軟件更新時(shí)將CCS編譯和鏈接生成的COFF文件下載到DSP系統(tǒng),便可自動(dòng)完成更新;最后還簡(jiǎn)單介紹了方案在TMS320VC5409系統(tǒng)上的實(shí)現(xiàn)。
本文引用地址:http://www.ex-cimer.com/article/79811.htm關(guān)鍵詞 軟件自動(dòng)更新 COFF文件解析 兩級(jí)引導(dǎo)程序 TMS320C6713
引 言
目前市面上存在大量基于DSP的嵌入式系統(tǒng),隨著系統(tǒng)的完善和功能的增強(qiáng),幾乎所有的DSP系統(tǒng)都面臨著軟件更新的問(wèn)題,這時(shí),更新方法的簡(jiǎn)易和高效就顯得特別重要。在基于DSP(數(shù)字信號(hào)處理器)的嵌入式系統(tǒng)中,軟件更新通常需要借助仿真器將最新的程序下載到目標(biāo)板上,然后將程序?qū)懭敕且资痛鎯?chǔ)器中。同時(shí),由于新程序編譯、鏈接后生成的各段的大小和運(yùn)行空間會(huì)發(fā)生變化,系統(tǒng)引導(dǎo)程序也需要作相血的改動(dòng)。例如:上一個(gè)版本的程序?qū)?yīng)的.text段的運(yùn)行空間位于Ox80000000~0x80000100,而新程序?qū)?yīng)的.text段的運(yùn)行空間則位于Ox80001000~Ox80001110,.text段的運(yùn)行空間和長(zhǎng)度都發(fā)生了變化。另外,引導(dǎo)程序的任務(wù)之一是將.text段的數(shù)據(jù)從Flash中復(fù)制到其運(yùn)行空間,因此就必須重新修改引導(dǎo)程序,將.text段復(fù)制的起始地址由Ox80000000改為0x80001000,并將復(fù)制長(zhǎng)度改為OxllO,每一次軟件更新都會(huì)重復(fù)上面的步驟。在遠(yuǎn)程系統(tǒng)控制應(yīng)用中,這種更新方法就顯得非常不便;在需要同時(shí)對(duì)大量的DSP系統(tǒng)進(jìn)行軟件更新或經(jīng)常需要軟件更新的情況下,這種方法的效率也非常低下。
筆者通過(guò)對(duì)TMS320C6713 DSP系統(tǒng)引導(dǎo)過(guò)程的分析和COFF(公共目標(biāo)文件格式)文件格式的分析,提出了一個(gè)軟件自動(dòng)更新的方案,并在基于TI公司的TMS320C6713芯片與SST公司的SST39VFl601并行Flash芯片組成的硬件平臺(tái)上實(shí)現(xiàn);最后還簡(jiǎn)單介紹了本方案在TMS320VC5409系統(tǒng)上的實(shí)現(xiàn)。實(shí)現(xiàn)本方案的一個(gè)前提是DSP硬件系統(tǒng)上具有某種接口,可以從計(jì)算機(jī)中下載COFF文件到本地系統(tǒng)上,筆者使用的平臺(tái)是通過(guò)UART接口連接計(jì)算機(jī),使用Windows自帶的超級(jí)終端上具,通過(guò)Xmodem協(xié)議將COFF文件下載到目標(biāo)系統(tǒng)上,當(dāng)下載完成后更新就會(huì)自動(dòng)完成。DSP重新上電或復(fù)位后運(yùn)行的就是最新的程序。本方案主要包括兩個(gè)過(guò)程:一是通過(guò)解析COFF文件得到所需的數(shù)據(jù)并燒入Flash;二是系統(tǒng)上電后自動(dòng)根據(jù)Flash中最新的數(shù)據(jù)引導(dǎo)、運(yùn)行。下面詳細(xì)描述兩個(gè)過(guò)程的實(shí)現(xiàn)方法。
1 COFF文件解析
C或匯編程序在編譯后會(huì)生成很多段(如.text、.bss、.switch、.cinit、.data等),這些段又可以分為需要初始化的段和不需要初始化的段。這里,需要初始化和不需要初始化是針對(duì)系統(tǒng)引導(dǎo)來(lái)說(shuō)的。例如:.text為程序代碼數(shù)據(jù),系統(tǒng)上電后需要引導(dǎo)程序從Flash中復(fù)制到其運(yùn)行空間中,稱為“需要初始化的段”;.bss為初始化為0的數(shù)據(jù)空間,這個(gè)初始化為O的動(dòng)作在C語(yǔ)言環(huán)境建立時(shí)進(jìn)行,屬于系統(tǒng)程序的一部分,與引導(dǎo)程序無(wú)關(guān),稱為“不需要初始化的段”。這樣,只需要保存初始化的段到Flash中,而并不需要通過(guò)段的名稱來(lái)識(shí)別哪些段是需要初始化的段,哪些是不需要初始化的段,兩種類型可以通過(guò)COFF文件中的段信息表部分來(lái)區(qū)分。
1.1 COFF文件簡(jiǎn)介
COFF文件是DSP匯編器和鏈接器創(chuàng)建的目標(biāo)文件,通常為項(xiàng)目目錄下的Debug目錄里后綴為.out的文件。在COFF文件中包含文件頭、可選擇的頭信息、段信息表、每個(gè)初始化段的數(shù)據(jù)和重定位信息、符號(hào)表、字符串表。從中可以看出,COFF文件中包含了很多冗余的信息成分。為了節(jié)省空間、提高效率,在這里不直接將COFF文件燒進(jìn)Flash,而只保存所需的信息,即每個(gè)初始化段的數(shù)據(jù)和程序的入口地址。下面詳細(xì)描述如何從COFF文件中得到這些信息。
1.2 COFF文件格式
在COFF文件中,文件頭部分提供了該文件中包含的段的個(gè)數(shù),解析程序會(huì)根據(jù)段的個(gè)數(shù)掃描每個(gè)段的信息并保存初始化段的數(shù)據(jù);可選擇的頭信息包含了程序的入口地址,在系統(tǒng)引導(dǎo)結(jié)束后會(huì)直接跳轉(zhuǎn)到這個(gè)地址,系統(tǒng)就開(kāi)始正常工作。段信息表的格式說(shuō)明如表l所列。其中,段物理地址是該段的執(zhí)行地址,也就是程序運(yùn)行時(shí)該段所在的空間;原始數(shù)據(jù)文件指針指向段數(shù)據(jù)在COFF文件中的位置,如果該段為初始化段,那么從這里就可以得到需要寫入Flash的數(shù)據(jù)的位置。計(jì)算如下:
段數(shù)據(jù)地址=COFF文件起始地址+原始數(shù)據(jù)文件指針
標(biāo)志信息用于判斷該段是否為需要初始化的段,如表2所列。需要初始化的段標(biāo)志為Ox40和0x20,這樣就獲得所有需要引導(dǎo)程序復(fù)制的段數(shù)據(jù)。此時(shí)不能將這些數(shù)據(jù)直接燒入Flash,若直接燒入Flash,則引導(dǎo)程序?qū)o(wú)從知道段數(shù)據(jù)的起始位置、運(yùn)行空間地址和長(zhǎng)度。本方案設(shè)計(jì)了一個(gè)簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu)放在段數(shù)據(jù)前,稱為“段頭”。數(shù)據(jù)結(jié)構(gòu)如下:
1.3 Flash存儲(chǔ)空間安排
獲得所需的數(shù)據(jù)后,下一步就是將這些數(shù)據(jù)燒入Flash。Flash空間的數(shù)據(jù)格式如下:
除了保存段頭和段數(shù)據(jù),還需要記錄程序入口地址和后面所有段的個(gè)數(shù)。程序入口地址是目標(biāo)程序第一步開(kāi)始執(zhí)行的地址,當(dāng)引導(dǎo)程序復(fù)制完所有的數(shù)據(jù)后就直接跳到這個(gè)地址開(kāi)始運(yùn)行。段的個(gè)數(shù)用于引導(dǎo)程序判斷是否所有段的數(shù)據(jù)已復(fù)制完。
在燒寫Flash前還需要對(duì)Flash空間進(jìn)行劃分。以本系統(tǒng)為例,F(xiàn)lash空間為Ox90000000~Ox90400000,共4MB。劃分如下:
◆第一部分存儲(chǔ)的是第一級(jí)引導(dǎo)程序。對(duì)TMS320C6713系統(tǒng)來(lái)說(shuō),這部分代碼編譯后產(chǎn)生所有初始化段大小必須小于1KB(其詳細(xì)分析見(jiàn)后),所以這部分空間大小固定為1KB,即0x90000000~0x900003ff。
◆第二部分存儲(chǔ)的是第二級(jí)引導(dǎo)程序,這部分按照上述數(shù)據(jù)格式燒寫。其長(zhǎng)度沒(méi)有特別限制,只需根據(jù)保存第二級(jí)引導(dǎo)程序所需的最大空間安排。由于Flash每個(gè)扇區(qū)的大小為8KB,為了便于對(duì)上一部分的擦除操作,將第二部分的起始地址延長(zhǎng)到Flash第二個(gè)扇區(qū)的起始地址,其空間為Ox90002000~0x90003fff,共8KB。
◆第三部分為系統(tǒng)程序,其長(zhǎng)度根據(jù)保存系統(tǒng)程序所需最大空間安排。數(shù)據(jù)格式與第二部分相同,對(duì)應(yīng)地址為0x90004000~Ox90103fff,共1MB。剩余的Flash空間作其他用途。
整個(gè)Flash空間劃分如圖1所示。注意:以上3個(gè)部分一旦規(guī)劃好,每個(gè)部分的位置就不能改動(dòng)。對(duì)于第二部分,只要第二級(jí)引導(dǎo)寫好,這部分需要的空間也就確定了;而第三部分在每次軟件更新時(shí)都要同時(shí)更新,因此需要預(yù)留足夠大的空間。
整個(gè)COFF文件解析流程如圖2所示。
2 系統(tǒng)引導(dǎo)程序設(shè)計(jì)
TMS320C6713支持3種引導(dǎo)方式:主機(jī)引導(dǎo)、仿真引導(dǎo)和EMIF引導(dǎo)。本方案采用EMIF引導(dǎo),在此模式下,位于外部存儲(chǔ)空間CEl的Flash中的1 KB代碼通過(guò)EDMA拷貝到片內(nèi)RAM地址0處。由于大多數(shù)引導(dǎo)程序代碼大于1 KB,因此本方案采用兩級(jí)引導(dǎo)方式。編寫引導(dǎo)程序的目的就是,將所有初始化段的數(shù)據(jù)從Flash中拷貝到其對(duì)應(yīng)的運(yùn)行時(shí)的存儲(chǔ)空間。
2.1 第一級(jí)引導(dǎo)程序設(shè)計(jì)
對(duì)于基于TMS820C6713的系統(tǒng),第一級(jí)的引導(dǎo)程序大小被嚴(yán)格限制在l KB內(nèi),因此只能用匯編語(yǔ)言編寫程序。在系統(tǒng)上電后第一級(jí)的引導(dǎo)程序由EDMA從Flash拷貝lKB到片內(nèi)RAM并開(kāi)始執(zhí)行,因此第一級(jí)引導(dǎo)程序編譯后所有韌始化段的長(zhǎng)度不能大于1 KB。對(duì)于筆者提供的程序,這段程序編譯后產(chǎn)生的初始化段只有.text段。其任務(wù)是根據(jù)數(shù)據(jù)格式找到段數(shù)據(jù)并拷貝到對(duì)應(yīng)的物理地址中,然后跳到第二級(jí)引導(dǎo)程序入口處。第一級(jí)引導(dǎo)程序流程如圖3所示。
2.2 第二級(jí)引導(dǎo)程序設(shè)計(jì)
第二級(jí)引導(dǎo)程序大小沒(méi)有限制,因此本方案使用C語(yǔ)言來(lái)實(shí)現(xiàn)。在本硬件系統(tǒng)中,系統(tǒng)程序在SDRAM中運(yùn)行,因此在第二級(jí)引導(dǎo)程序拷貝段數(shù)據(jù)之前還需要初始化EMIF。如果在硬件上還用到了其他外設(shè),也可以在這里完成初始化。初始化完成后就開(kāi)始拷貝數(shù)據(jù)的過(guò)程,這與第一級(jí)引導(dǎo)程序的拷貝過(guò)程是完全相同的。第二級(jí)引導(dǎo)程序流程如圖3所示。
這里用簡(jiǎn)單的例子來(lái)解釋系統(tǒng)引導(dǎo)程序如何工作的。在Flash空間中,所有的段頭和段數(shù)據(jù)都是緊湊安排的。也就是說(shuō),上段頭后面緊接著段數(shù)據(jù),本段數(shù)據(jù)結(jié)束后就是下一段的段頭。這種安排是必須的,否則,引導(dǎo)程序在復(fù)制完上一個(gè)段的數(shù)據(jù)后就無(wú)法我到下一個(gè)段頭的地址。以第一級(jí)引導(dǎo)程序復(fù)制Flash中第二級(jí)引導(dǎo)程序?yàn)槔f(shuō)明。第二級(jí)引導(dǎo)程序的各段數(shù)據(jù)在Flash中的起始地址為0x90002000,首先從頭兩個(gè)字中讀出程序入口地址、所有數(shù)據(jù)大小和段個(gè)數(shù);然后讀取段頭,段大小用于確定本段數(shù)據(jù)長(zhǎng)度;跳過(guò)本段數(shù)據(jù)區(qū)為下一段頭開(kāi)始位置,段物理地址則說(shuō)明了段數(shù)據(jù)復(fù)制的目的地址。若復(fù)制的段個(gè)數(shù)等于開(kāi)始讀出的段個(gè)數(shù),則表明所有數(shù)據(jù)復(fù)制均已完成,然后跳轉(zhuǎn)到程序入口地址。從這個(gè)過(guò)程中可以看出,引導(dǎo)程序的復(fù)制過(guò)程完全是根據(jù)段頭的信息來(lái)的。當(dāng)軟件更新時(shí),段頭信息也會(huì)相應(yīng)更新,與引導(dǎo)程序無(wú)關(guān)。因此,引導(dǎo)程序可以自適應(yīng)新程序段的變化,而不需要重新修改引導(dǎo)程序。
3 在TMS320VC5409系統(tǒng)上的實(shí)現(xiàn)
大多數(shù)DSP系統(tǒng)的引導(dǎo)過(guò)程都大同小異,筆者也將本方案應(yīng)用在基于TMS320VC5409的硬件平臺(tái)上。對(duì)于COFF文件的解析,兩種平臺(tái)沒(méi)有區(qū)別,解析得到的段數(shù)據(jù)也同樣是加上段頭后燒進(jìn)Flash。TMS320VC5409與TMS320C6713唯一的區(qū)別在于其引導(dǎo)過(guò)程。TMS320VC5409的引導(dǎo)方式較多,對(duì)本方案的實(shí)現(xiàn)也多種多樣,這里只簡(jiǎn)單介紹筆者所使用的方法。
將MP/MC引腳拉高,使TMS320VC5409為微處理器模式。這樣程序空間0xff80~0xffff映射到外部,同時(shí)硬件上將Flash空間連接到DSP的0x8000~0xfff程序空間上。DSP上電復(fù)位后,PC從程序空間的0xff80開(kāi)始執(zhí)行,需要做的是在0xff80對(duì)應(yīng)的Flash空間中寫入一個(gè)跳轉(zhuǎn)語(yǔ)句,將DSP跳轉(zhuǎn)到引導(dǎo)程序開(kāi)始的位置??梢钥闯?,由于引導(dǎo)程序沒(méi)有長(zhǎng)度限制,因此采用一級(jí)程序引導(dǎo)。注意:此時(shí)的引導(dǎo)程序并沒(méi)有復(fù)制到片內(nèi)RAM中,而是直接在Flash上執(zhí)行,所以在編譯引導(dǎo)程序時(shí)要注意鏈接文件的書(shū)寫。當(dāng)引導(dǎo)程序開(kāi)始執(zhí)行后,直接在預(yù)先設(shè)定好的Flash空間中根據(jù)1.2小節(jié)中的結(jié)構(gòu)體尋找段數(shù)據(jù)并復(fù)制,復(fù)制完成后跳轉(zhuǎn)到系統(tǒng)程序入口處。
編者注:實(shí)現(xiàn)代碼見(jiàn)本刊網(wǎng)站www.mesnet.cm.cn。
4 結(jié)論
本文介紹了一種基于TMS320C6713系統(tǒng)的軟件自動(dòng)更新方案。該方案具有實(shí)現(xiàn)簡(jiǎn)單、效率高的優(yōu)點(diǎn),且一旦實(shí)現(xiàn)后,每次軟件更新時(shí)無(wú)須改動(dòng)引導(dǎo)程序。目前該方案已應(yīng)用在國(guó)家自然科學(xué)基金項(xiàng)目自動(dòng)指紋識(shí)別系統(tǒng)中,收到了非常好的效果。實(shí)踐表明,本方案具有很好的可移植性,可以在TI公司的多種DSP平臺(tái)上得到應(yīng)用。
評(píng)論