基于LPC2378的IAP功能的配變監(jiān)測(cè)終端遠(yuǎn)程更新方案設(shè)計(jì)
本文采用Philips公司的32位微處理器LPC2378進(jìn)行配變監(jiān)測(cè)終端的開(kāi)發(fā),并利用該芯片自帶的IAP功能實(shí)現(xiàn)了終端程序的遠(yuǎn)程更新。為了降低通信流量和終端的存儲(chǔ)空間,本文還將LZW壓縮算法應(yīng)用到程序更新中。
1 LPC2378芯片介紹
LPC2378是一款基于ARM7TDMI-S的32位處理器。它具有512 KB的片內(nèi)Flash程序存儲(chǔ)器、32 KB的靜態(tài)RAM(SRAM),以及在系統(tǒng)編程(In-System Programming,ISP)和在應(yīng)用編程(In-Application Program-ming,IAP)功能。由于程序?qū)?nèi)存需求比較大,所以外擴(kuò)了一片64 KB的SRAM。
通常,程序的下載可通過(guò)3種方式實(shí)現(xiàn):
①采用嵌入式實(shí)時(shí)操作系統(tǒng)。該方法加大了系統(tǒng)對(duì)存儲(chǔ)容量的要求,增加了硬件和軟件成本。
②采用增加外控制燒錄系統(tǒng)的方法。該方法同樣增加了系統(tǒng)的復(fù)雜度和成本,且降低了系統(tǒng)本身的可靠性。
③采用IAP技術(shù)。該方法充分利用芯片本身的功能,不增加外圍器件,是一種最佳的實(shí)現(xiàn)方案。
1.1 LPC2378的FIash扇區(qū)
IAP命令以“扇區(qū)”為單位進(jìn)行操作,操作時(shí)需要指定扇區(qū)號(hào)。LPC2378的扇區(qū)分布如表1所列。IAP、ISP和RealMonitor程序都位于Boot區(qū),Boot區(qū)位于地址0x000TE000~0x0007FFFF處。IAP命令不允許對(duì)Boot扇區(qū)執(zhí)行寫/擦除/運(yùn)行操作。
1.2 LPC2378的IAP功能
IAP程序是Thumb代碼,位于地址0x7ffffff1。IAP功能可用下面的C代碼來(lái)調(diào)用。
定義IAP程序的入口地址:
# define IAP_ENTER_ADR 0x7ffffff1
定義函數(shù)類型指針:
Typedef void(* IAP)(uint32[ ],uint32[ ])
IAP iap_entry;
設(shè)置函數(shù)指針:
Iap_entry=(IAP) IAP_ENTER_ADR;
使用下面的語(yǔ)句來(lái)調(diào)用IAP:
Iap_entry(command,result);
IAP功能主要通過(guò)調(diào)用iap_entry()函數(shù)來(lái)實(shí)現(xiàn)。IAP命令和定義的函數(shù)如表2所列。
在進(jìn)行片內(nèi)Flash修改時(shí),首先需要讀取器件的ID和Boot代碼命令版本;確認(rèn)無(wú)誤后,選擇準(zhǔn)備編程的扇區(qū);然后擦除扇區(qū)并執(zhí)行扇區(qū)查空,將RAM內(nèi)容復(fù)制到Flash中;最后進(jìn)行RAM內(nèi)容與Flash的比較,檢查是否復(fù)制成功。
2 遠(yuǎn)程更新的實(shí)現(xiàn)
2.1 程序分區(qū)
軟件開(kāi)發(fā)采用ADS1.2集成開(kāi)放環(huán)境。ADS全稱為ARM Developer Suite,是ARM公司推出的ARM集成開(kāi)發(fā)工具。在ADS鏈接選項(xiàng)ARM Linker中選擇Scattered方式后,通過(guò)修改.scf文件可以將程序編譯成應(yīng)用程序和更新程序兩部分。其中,應(yīng)用程序占用0~21扇區(qū),用于實(shí)現(xiàn)終端的功能;更新程序占用22~27扇區(qū),在終端出廠后不再進(jìn)行修改。當(dāng)進(jìn)行程序更新時(shí),利用IAP功能對(duì)應(yīng)用程序部分進(jìn)行擦除改寫,以實(shí)現(xiàn)終端應(yīng)用程序的更新。鏈接用的.scf文件定義如下:
在.scf文件中,RO表示程序代碼數(shù)據(jù)內(nèi)容,RW和ZI表示該程序部分中定義的通用數(shù)據(jù)變量和需進(jìn)行零初始化的數(shù)據(jù)變量。ROM_MAIN部分主要包括應(yīng)用程序部分和其定義的數(shù)據(jù)。ROM_EXEC是應(yīng)用程序的代碼區(qū)域,位于片內(nèi)Flash,地址從0開(kāi)始。IRAM中是程序運(yùn)行的堆棧,位于片內(nèi)RAM中。ERAM是應(yīng)用程序定義的數(shù)據(jù)變量,位于片外RAM中。LOADER部分是更新程序的代碼區(qū)域,位于片內(nèi)Flash,地址從0x78000開(kāi)始。程序編譯、鏈接完成后,ADS會(huì)生成兩個(gè)名為ROM_MAIN和LOADER的十六進(jìn)制文件。在需要程序更新時(shí),主站將完成二進(jìn)制提取的ROM_MAIN文件通過(guò)有線或無(wú)線的方式發(fā)送給終端,終端全部收到后調(diào)用更新程序進(jìn)行程序更新。但由于提取完的二進(jìn)制文件仍然比較大,需要對(duì)其進(jìn)行壓縮,以降低通信費(fèi)用。
評(píng)論