基于GPRS的嵌入式系统软件的远程在线升级

时间:2022-05-02 04:15:13

基于GPRS的嵌入式系统软件的远程在线升级

摘 要:针对大型分布式监控系统远程终端的嵌入式系统软件远程在线升级和维护问题,提出一种基于通用无线分组业务(General Packet Radio Service,gprs)的嵌入式系统软件远程在线升级方案,该方案采用GPRS、应答机制与断点续传技术,保证数据远程无线传输的准确性和可靠性,应用RAM分区技术和IAP技术实现系统软件的在线升级。实践证明,该设计方案具有在线升级成功率高、速度快的特点,已成功应用于南京航道局的航标自动监测系统中。

关键词:GPRS;在线升级;远程终端;嵌入式系统

中图分类号:TP368 文献标识码:B 文章编号:1004-373X(2009)04-047-03

Remote On-line Upgrade of Embedded System′s Software Based on GPRS

PENG Jinghua1,CAI Shengzhen2,WU Yunping1,CHEN Conghui1

(1.Department of Electronic Engineering,Fujian Normal University,Fuzhou,350007,China;

2.Faculty of Software,Fujian Normal University,Fuzhou,350108,China)

Abstract:The remote upgrade and maintenance of the remote terminal′s embedded system′s software of large-scale distributional control system are difficult,a plan that the remote on-line upgrade of embedded systems software based on GPRS is proposed,it uses the technologies of GPRS,the reply mechanism and resume broken transfer to ensure the accuracy and reliability of the data remote and wireless transmission,it uses the technologies of RAM partition and IAP to realize the on-line upgrade of system′s software.The practice proves that this design project has the characteristics of on-line upgrade successfully with high ratio and quick speed,and the design project is applied successfully in the navigation observation systems of Waterway Bureau of Nanjing.

Keywords:GPRS;on-line upgrade;remote terminal;embedded systems

0 引 言

随着电子技术、计算机技术和通信技术的迅猛发展,嵌入式系统已经广泛应用于工业、军事、通信、信息家电等领域,但是面对新技术的不断涌现和对系统功能、性能以及规模要求的不断提高,开发者必须能够针对客户的需求及时对系统进行升级或维护,以延长系统使用周期,改善系统性能,增强系统适应性[1,2]。

传统的嵌入式系统升级方式通常由维护人员到达设备现场,开箱重写或者更换FLASH存储部件,当设备数目庞大并且分布范围广泛时,这种升级维护方式的工作量将非常大,而且耗费的时间长、成本高[3,4]。近年来通过以太网和在FLASH上建立TFFS文件系统的方法,能很好地解决批量升级的问题,但对于野外偏远地区或海上等有线网络无法到达的地方,此方法也难以实现。

在此提出基于GPRS的嵌入式系统软件的远程在线升级方案,利用GPRS网络无需现场布线和“实时在线”、“按量计费”、“快捷登录”、“高速传输”的特点[5],只要远程终端在移动公网覆盖的范围内,均可实现升级数据的远程传输;为了克服无线网络相对有线网络因地形或环境等因素造成误码或掉线的不足,采用应答机制与断点续传技术,确保数据传输的准确性和可靠性;通过对嵌入式芯片内部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存储器中另外一段程序进行读/写操作,甚至可以控制对某段、某页的读/写操作,为数据存储和固件的自动升级带来了极大的灵活性[6]。该方案通过GPRS网络传输升级文件的程序代码,利用ARM内部的FLASH存储器及其IAP编程,实现终端的嵌入式系统软件的远程无线在线升级。有关IAP的命令码、状态码和命令详解以及IAP功能的详细应用见参考文献[7-9]。

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修改用户代码跳转区的指令,使远程终端运行新的升级代码[10]。

3 服务器端的软件设计

3.1 升级文件传输的数据格式

为了达到快速准确升级的目的,首先对原始的升级代码(Intel Hex文件)进行打包,然后加入相应的数据包ID号和校验码,并定义数据包长度≤256个字节,以适应GPRS通信方式对数据包长度的要求,避免出现频繁掉线和发送不出去的问题[6]。具体的数据包格式如下:数据包格式:PackID+起始地址+长度+数据+校验码;PackID:一个完整的数据包为一个记录,下一个数据包的记录号自动加1;

起始地址:烧写数据的FLASH首地址。即数据部分中包含的第一条数据的记录地址+线性扩展地址;长度:该包数据部分的字节数;

数据:同一 个扩展线性地址记录内且地址连续的数据记录的数据域。当读到一个扩展线性地址记录号后,将此扩展线性地址记录号内的数据区域打包成256个字节之内的数据包,超过256个字节或读到下一个扩展线性记录号时则另起一个新的数据包;校验码:CRC循环冗余校验码。

3.2 服务器端主要程序流程

服务器端主要程序流程图如图4和图5所示。服务器先把升级文件的路径配置完毕,并将要升级的目标程序代码按照第3.1节所示的数据包格式进行打包,并对每个数据包进行编号。

接着如图4所示,服务器发送升级指令,并通过GPRS网络透明传输到远程终端。如果当前运行的用户程序代码在1区,则将2区升级数据发送给远程终端,否则将2区升级数据发送给远程终端。由于地形和环境因素的影响,GPRS网络在远程通信过程中可能出现阻塞或断开的情况[6]。

如果服务器在一定的时间内没有收到远程终端的应答信号,则重发,如果三次重发失败则保存成功接收到的数据块ID号和数据校验码,进入断点续传。升级文件传输完毕则发送跳转指令,使远程终端执行新的程序代码。

3.3 服务器端配置表

服务器端升级配置表中重要字段的配置如下:

这些字段将服务器和远程终端紧密地联系起来,使得编程思路更加清晰,UpdateID标志了用户程序目前所在存储区;UpdateUserZone为升级做好文件配置准备工作,LastOrder为断点续传做好准备,保证整个程序的紧密性以及可靠性。

4 结 语

该方案采用应答机制、断点续传、CRC校验等技术,充分利用ARM芯片内部FLASH存储

器资源,通过GPRS网络,实现对ARM嵌入式终端的系统软件进行远程在线升级,解决了大型分布式监控系统远程嵌入式终端系统软件的在线升级和维护问题。该方案已经成功地应用在南京航道局的航标自动监测系统中,该系统有600多盏安装有嵌入式终端的航标灯,对该系统进行在线升级仅耗时20 min,且一次性升级成功。实践证明,该方案的实施可有效降低工程复杂度,缩短升级时间,节约升级、维护成本,同时具有升级成功率高和升级速度快的特点。

参 考 文 献

[1]何幸杰,彭维.基于ARM7的在线升级系统的设计与实现[J].现代机械,2006(3):55-57.

[2]邱丽芳.基于以太网的远程升级嵌入式系统的设计[J].现代电子技术,2006,29(23):101-103,106.

[3]王子健,张军,罗喜伶.基于TFFS的嵌入式系统在线升级设计与实现[J].计算机工程,2006,32(13):257-259.

[4]徐遥令,罗大庸,张航.基于GIS的多点嵌入式系统远程在线升级[J].计算机测量与控制,2006,14(3):383-385.

[5]王晓兰,任晓芳.基于GPRS的远程监控系统集中器的设计[J].微计算机信息,2007(29):30-32.

[6]韦文祥,朱志杰,车琳娜,等.基于LPC2124的一个远程系统软件升级方案[J].单片机与嵌入式系统应用,2006(5):46-49.

[7]王飞,李振国,梁伟.ISP在线更新技术在RS 485网络中的应用[J].科学咨询(决策管理),2008(11):53.

[8]陈屹,马殿光.基于CAN总线的一种系统远程升级功能的实现[J].自动化仪表,2008,29(3):35-37.

[9]佚名.Philips LPC2000系列ARM 的FLASH存储器系统和编程使用指南\.周立功单片机,2003.

[10]梅亮,林辉.TMS320F2812代码在线升级的研究与设计[J].电气传动,2006,36(7):62-64.

作者简介

彭井花 女,1983年出生,硕士研究生。

上一篇:开关电流电路主要误差的改善 下一篇:S波段耦合腔行波管非线性注-波互作用方程组的...