LZW壓縮算法在終端程序遠(yuǎn)程更新中的應(yīng)用
2.2 程序更新的實(shí)現(xiàn)方法
程序運(yùn)行流程如圖1所示。終端在程序啟動(dòng)時(shí),先檢查是否需要程序更新,如果不需要?jiǎng)t正常進(jìn)入main()函數(shù)運(yùn)行。在運(yùn)行過(guò)程中,當(dāng)遇到主站發(fā)過(guò)來(lái)的壓縮程序包時(shí),首先需要對(duì)壓縮程序包進(jìn)行檢查,如果無(wú)誤,則將其存到對(duì)應(yīng)位置的外部Flash中。當(dāng)收到主站的程序更新命令時(shí),終端需要對(duì)接收到的全部壓縮程序包進(jìn)行檢查,確認(rèn)無(wú)誤后置位程序更新標(biāo)志,保存當(dāng)前數(shù)據(jù)并復(fù)位。當(dāng)終端程序再次啟動(dòng),發(fā)現(xiàn)有程序更新標(biāo)志時(shí),則調(diào)用更新程序。在更新程序中,首先從外部Flash中取出壓縮的程序包,然后對(duì)其進(jìn)行解壓縮,并將壓縮后的程序復(fù)制到對(duì)應(yīng)的內(nèi)部Flash扇區(qū)中。當(dāng)所有的壓縮程序包都解壓復(fù)制后,清除程序更新標(biāo)志,然后復(fù)位。終端再次啟動(dòng)后,運(yùn)行的就是更新之后的應(yīng)用程序了。
2.3 解壓縮算法在更新程序里的實(shí)現(xiàn)
在程序編譯、鏈接完后,對(duì)應(yīng)用程序生成的ROM_MAIN.hex文件進(jìn)行二進(jìn)制提取。雖然可以使文件大大減小,但所生成的文件仍然很大,需要進(jìn)一步壓縮。本文采用LZW壓縮算法對(duì)其進(jìn)行壓縮,LZW(Lempel-Ziv-Welch)壓縮算法是一種串表式無(wú)損壓縮技術(shù),支持流式解壓縮,可以根據(jù)內(nèi)存大小選擇合適的最大字典串長(zhǎng)。表3顯示了對(duì)ROM_MAIN.hex文件(940 KB)進(jìn)行二進(jìn)制提取,以及提取后對(duì)其進(jìn)行LZW壓縮各階段的文件大小。
當(dāng)需要進(jìn)行程序更新時(shí),將壓縮后的文件發(fā)送給終端。終端收到全部程序壓縮包并確認(rèn)無(wú)誤后,進(jìn)行復(fù)位并調(diào)用更新程序。在更新程序中,由于內(nèi)存的限制,每次從外部Flash讀取1 024字節(jié)進(jìn)行解壓縮。當(dāng)解壓出的字節(jié)數(shù)達(dá)到512時(shí),調(diào)用IAP功能函數(shù),并將這512個(gè)字節(jié)復(fù)制到內(nèi)部Flash中,繼續(xù)進(jìn)行解壓縮。之前讀取的1 024個(gè)字節(jié)解壓完畢后,再重新從外部Flash進(jìn)行讀取解壓,直到對(duì)應(yīng)用程序完全解壓并復(fù)制完為止。
結(jié) 語(yǔ)
本文介紹了基于LPC2378的IAP功能實(shí)現(xiàn)配變監(jiān)測(cè)終端程序遠(yuǎn)程更新的方法,并將LZW壓縮算法應(yīng)用于程序更新中。該產(chǎn)品投入運(yùn)行一年多以來(lái),取得了良好的運(yùn)行效果。此項(xiàng)技術(shù)具有一定普遍性,略加修改可以應(yīng)用到其他同類(lèi)產(chǎn)品中。
評(píng)論