基于GPRS的嵌入式系統軟件的遠程在線升級
隨著電子技術、計算機技術和通信技術的迅猛發展,嵌入式系統已經廣泛應用于工業、軍事、通信、信息家電等領域,但是面對新技術的不斷涌現和對系統功能、性能以及規模要求的不斷提高,開發者必須能夠針對客戶的需求及時對系統進行升級或維護,以延長系統使用周期,改善系統性能,增強系統適應性。
傳統的嵌入式系統升級方式通常由維護人員到達設備現場,開箱重寫或者更換FLASH存儲部件,當設備數目龐大并且分布范圍廣泛時,這種升級維護方式的工作量將非常大,而且耗費的時間長、成本高。近年來通過以太網和在FLASH上建立TFFS文件系統的方法,能很好地解決批量升級的問題。但對于野外偏遠地區或海上等有線網絡無法到達的地方,此方法也難以實現。
在此提出基于GPRS的嵌入式系統軟件的遠程在線升級方案,利用GPRS網絡無需現場布線和“實時在線”、“按量計費”、“快捷登錄”、“高速傳輸”的特點,只要遠程終端在移動公網覆蓋的范圍內,均可實現升級數據的遠程傳輸;為了克服無線網絡相對有線網絡因地形或環境等因素造成誤碼或掉線的不足,采用應答機制與斷點續傳技術,確保數據傳輸的準確性和可靠性;通過對嵌入式芯片內部FLASH存儲器的存儲空間進行劃分和升級文件傳輸的數據格式進行定義,再利用IAP技術實現系統軟件的在線升級,較好地解決了數量龐大并且分布范圍較廣的設備在線升級或維護的問題。
1 系統結構
系統結構如圖1所示,由服務器和遠程終端組成,其中遠程終端包括基于ARM內核的嵌入式控制芯片(以下簡稱ARM芯片)和GPRS Modem模塊,兩者之間通過RS 232總線連接;服務器與遠程終端通過GPRS進行通信。用戶需要升級遠程終端時,首先將服務器端的升級標志位置1,通過GPRS將升級標志位傳給遠程終端,遠程終端上電后將自動檢測升級標志位,若標志位為1表示需要升級,否則不升級。然后,服務器將升級文件通過GPRS透明的下載到遠程終端,實現數據的傳輸及更新,從而達到遠程終端的嵌入式系統軟件的在線升級的目的。
2 遠程終端軟件升級的關鍵技術
2.1 FLASH存儲器編程
遠程終端的升級主要是對ARM芯片內部FLASH存儲器的數據進行擦除及下載,目前很多ARM芯片支持多種方式對FLASH進行編程,ARM芯片內部FLAsH存儲器的編程有JTAG,ISP和IAP三種方式:JTAG編程主要用于產品開發期的調試;ISP需要提供一定的硬件資源和中止應用軟件的運行,適用于便攜式設備的升級;IAP與ISP非常相似.主要區別是IAP允許在應用程序正常運行的情況下,對FLASH存儲器中另外一段程序進行讀/寫操作,甚至可以控制對某段、某頁的讀/寫操作,為數據存儲和固件的自動升級帶來了極大的靈活性。該方案通過GPRS網絡傳輸升級文件的程序代碼,利用ARM內部的FLASH存儲器及其IAP編程,實現終端的嵌入式系統軟件的遠程無線在線升級。有關IAP的命令碼、狀態碼和命令詳解以及IAP功能的詳細應用見參考文獻。
2.2 遠程終端的程序設計
為了在線升級,將ARM芯片內部FLASH存儲器按圖2所示劃分為啟動區、用戶代碼跳轉區、用戶代碼1區和用戶代碼2區。其中啟動區用于存放系統初始化和啟動代碼,用戶代碼跳轉區用于存放跳轉到相應用戶代碼區的指令.用戶代碼1區和用戶代碼2區用于交替存放當前終端正在執行的用戶代碼和升級的用戶代碼。若當前終端執行的用戶程序存放在1區,則將接收到的升級程序存放到2區;待升級程序接收結束后,更改用戶代碼跳轉區的指令,使其指向升級程序,即用戶代碼2區;此后用戶代碼2區的程序成為當前終端指向的用戶程序,而用戶代碼1區則用于下次升級代碼的存放區。
遠程終端上電后首先進入啟動區進行系統的初始化;接著終端從片外的E2PROM中讀取升級配置,包括升級標志位、已接收到的最后一個數據包的ID等。若終端處于升級狀態,則如圖3所示,向服務器發所要升級數據的指令,而且指令中將包含終端上次已接收到的最后一個數據包的ID,這樣可以避免已接收的數據包的重復發送,并實現續傳的功能。終端從GPRS網絡接收數據包后對數據包進行解析和校驗判斷,并與服務器形成一問一答的應答機制。FLASH中進行數據編程的最小單位是頁(512個字節),當接收到的升級數據達到1頁后.通過IAP進行編程。如果當前運行的用戶程序代碼在1區,則把升級數據保存到2區,否則保存到1區。編程成功后,將最后一條數據包的ID保存到E2PROM中。所有升級數據發送結束并編程成功后,通過IAP修改用戶代碼跳轉區的指令,使遠程終端運行新的升級代碼。
存儲器相關文章:存儲器原理
評論