0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

基于GPRS的远程IAP系统方案的终端产品设计

电子设计 来源:郭婷 作者:电子设计 2019-01-02 10:02 次阅读

引 言

IAP即在应用中编程,对于嵌入式产品,指在不影响产品正常运行的情况下实现应用程序的更新。许多ARM芯片都提供该操作接口,相对于ISP(在系统编程)方式,具有方便灵活且不需要借助专用boot装载程序或工具的特点,而且在不影响嵌入式产品正常运行的情况下即可完成应用程序的动态升级。在工业控制领域尤其是电力系统控制领域中,嵌入式产品必须保证连续、稳定、可靠地运行,由各种原因导致的应用程序的更新都必须在产品正常运行过程中完成,因此许多用户对相关产品的IAP功能都有明确的要求。IAP是用户自己的程序在运行过程中对User Flash的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产品中的固件程序进行更新升级。 通常在用户需要实现IAP功能时,即用户程序运行中作自身的更新操作,需要在设计固件程序时编写两个项目代码,第一个项目程序不执行正常的功能操作,而只是通过某种通信管道(如USB、USART)接收程序或数据,执行对第二部分代码的更新;第二个项目代码才是真正的功能代码。

LPC2214是Philips公司推出的一款32位ARM7TDMI-S工业微控制器。内置25 6 KB高速Flash,128位宽度接口/加速器可以实现60 MHz的操作频率;配置有2个UART接口、4个外部片选,支持8、16、32外部总线;片内boot下载程序可以实现在系统编程(ISP)和在应用中编程(IAP)。由于该芯片的内置Flash速度很快,并且支持128位宽度接口/加速,应用程序存储并运行在片内Flash中可以获得较快的执行速度。 LPC2124基于一个支持实时仿真和跟踪的16/32位ARM7TDMI-SCPU,并带有236 KB嵌入的高速Flash存储器和16 KB RAM。对于内嵌Flash存储器支持JTAG、ISP、IAP等多种编程方式。LPC2124具有非常小的64脚封装、极低的功耗、多个32位定时器、4路10位ADC、PWM输出、46个GPIO以及多达Array个外部中断,且内置了宽范围的串行通信接口,使它们特别适用于工业控制中。因为用电监控终端对硬件资源要求高,软件功能复杂,实时性强,所以采用LPC2124可以提高产品的性价比。

1 嵌入式产品应用程序启动方式

在嵌入式产品中,应用程序可以运行在RAM或Flash中。对于中高端产品,由于要求较高的执行速度和效率,一般采用Coldfire、x86、PowerPC、ARM9等CPU。此类CPU一般都有DRAM控制器,支持DRAM操作,为了获得较快的执行速度,将应用程序从代码Flash中复制到DRAM的代码空间后才开始执行。对于x86模式,应用程序以文件方式保存在硬盘或电子盘上。在不同的嵌入式操作系统上,应用程序在DRAM上的展开方式存在一定差异。

对于低端产品,由于成本的严格控制,在满足产品功能需求的前提下一般采用性价比较高的CPU,如8位、16位、低端ARM等。此类CPU一般有内部RAM、内部Flash,由于采用内部高速总线,内部Flash具有较高的执行速度。在外部RAM中运行的产品,执行速度较快,但是由于启动过程较为复杂,导致时间较长(尤其是。x86系统,启动过程可能需要半分钟以上);而在Flash上直接运行的产品,即使CPU具有较高的主频,执行速度也会受到Flash速度的限制,但是此类产品启动较快,一般可以在几秒钟内完成启动。

嵌入式产品应用程序的启动方式决定了应用程序动态更新的方式。对于代码在外部RAM执行的情况,正常情况下更新Flash中的代码不会影响系统正常运行,实现起来较为简单。对于代码在Flash上直接执行的情况,由于应用程序正常运行过程中会不断从Flash上读取指令,给在线更新程序带来一定困难,如果不借助一定手段或方法,很难保证应用程序的可靠升级。

2 硬件实现方案

本产品为电力负荷用电管理终端,用来实现对厂矿、企业、机关等电力用户的用电监测和控制,提高用电质量。终端产品通过GPRS/CDMA无线通信接口完成与电力局远方调度主站的信息交互。由于终端产品分散分布在一个区域的各个位置,调度主站必须通过GPRS/CDMA方式实现对终端产品应用程序的在线升级,因此产品在线升级的可靠性会对电力用户造成很大的影响。终端产品采用图1所示的硬件方案。考虑到LPC2214片内Flash的特点,应用程序固化在内部Flash中并在其中执行。LPC2214通过数据线、地址线与RAM、外部Flash、LCD、扩展串口芯片连接,通过串行总线与A/D转换器通信。LPC2214本身提供的2路UART接口可以分别实现本地维护接口和GPRS/CDMA无线网络接口,扩展串口芯片可以扩展出2路UART,实现本地红外维护和RS485方式的抄表功能。基于LPC2124的以上3种编程方法的分析,IAP实现对终端程序升级自然是最佳选择方案。下面介绍一种基于GPRS的远程IAP系统方案,系统框图如图2所示。

基于GPRS的远程IAP系统方案的终端产品设计

AT45DB08081B,8Mb串行Flash存储器,兼有ROM的掉电数据保存和RAM的读/写速度,最快支持20MHz的时钟频率,擦写次数达10000次,内置2个264字节SRAM缓冲器,使得对主存储体的编程可以连续进行,省去编程等待时间。AT45DB081B采用CASON-8封装,支持2.5~3.6 V低电压,操作功耗低,支持模式O和3的SPI总线接口,与MCU接口简单,稳定可靠,非常适用于数字语音、图像、程序代码和数据的存储应用中。在本设计中采用模式0与LPC2124通信,速度可达MCU主频的1/8。GPRS模块使用Wavecom公司生产的Q2406B,双频GPRS/GSM模块(EGSMArray00/1800 MHz,EGSMArray00/lArray00 MHz),内置TCP/IP,与标准AT指令完全兼容;其设计开发符合ETSI GSM Phase 2+标准。

为了确保应用程序的在线更新,片外RAM和Flash除了满足应用程序的正常使用外,还必须满足应用程序更新时临时备份代码的需求。

3 应用程序IAP实现方案

如图2所示,需要更新的应用程序代码通过GPRS/CDMA无线网络接口或本地维护接口下载到RAM的程序代码缓存区中。经过校验检查正确后,导入到外部Flash的应用程序代码区。导入成功后,设置相关标志,再通过LPC2214的IAP接口功能函数,将应用程序代码保存到CPU内部Flash中。IAP技术是从结构上将Flash存储器映射为两个存储体,当运行一个存储体上的用户程序时,可对另一个存储体重新编程,之后将控制从一个存储体转向另一个。ISP的实现一般需要很少的外部电路辅助实现,而IAP的实现更加灵活,通常可利用单片机的串行口接到计算机的RS232口,通过专门设计的固件程序来编程内部存储器。

存储器

由于应用程序运行在CPU内部的高速Flash上,因此产品正常运行过程中无法完成内部Flash中代码的更新。为了解决上述问题,采用“应用boot:”的方式加以实现。将内部Flash分为2个区域:应用boot和应用程序代码区。应用boot为一个简单的应用程序,实现从外部Flash导入应用程序代码以及向应用程序代码区入口跳转的功能。应用boot存放在CPU内部Flash的开始部分,一旦写入后不再修改。产品上电或复位后,CPU的PC指针首先指向应用boot的入口,应用boot开始执行。一旦检测到外部Flash中有完整的用户代码需要更新,则通过LPC2214的IAP接口将应用程序代码导入到内部Flash的应用程序代码区,并跳转到应用程序代码的入口处执行新的应用程序;如果没有应用程序需要更新,boot程序会直接跳转到当前应用程序代码的入口处执行。

在整个应用程序在线升级过程中,应用程序代码正常写入片外Flash之前都不影响产品的正常运行。正确写入片外Flash后,应用程序自动复位,然后启动应用boot,通过应用boot将新的应用程序写入内部Flash。

4 应用boot设计

应用boot是应用代码更新的关键,它不但解决了在线升级的问题,而且提供了一种异常防护机制。即使在内部Flash的应用程序代码区写入失败的情况下,由于boot可以正常运行,仍然可以通过boot程序的功能重新更新应用程序。boot程序基本功能包括:内部Flash更新、向应用程序跳转以及本地下载更新应用程序。为保证该软件的可靠性,同时考虑硬件配置情况,采用μC/OS-II嵌入式操作系统。通过对该操作系统的合理裁剪和软件优化,可以将boot程序代码控制在12 KB以内,从而为应用程序代码提供了足够的片内Flash存储空间。boot程序的启动部分非常重要,会直接影响整个系统的运行情况。启动代码首先初始化CPU总线控制器;然后初始化RAM和外部Flash片选,将boot程序代码复制到RAM中并在RAM中执行;最后初始化堆栈和基本系统后进入主程序入口。它提供了一个真正的由MCU本身自动下载和更新(采用读/写同时“Read-While-Write”进行的方式)程序代码的系统程序自编程更新的机制。利用AVR的这个功能,可以实现在应用编程(IAP)以及实现系统程序的远程自动更新的应用。 IAP的本质就是,MCU可以灵活地运行一个常驻Flash的引导加载程序(Boot Loader Program),实现对用户应用程序的在线自编程更新。引导加载程序的设计可以使用任何的可用的数据接口和相关的协议读取代码,或者从程序存储器中读取代码,然后将代码写入(编程)到Flash存储器中。

基于GPRS的远程IAP系统方案的终端产品设计

基于GPRS的远程IAP系统方案的终端产品设计

boot程序的IAP实现,主要包括两个接口函数:CPU内部Flash扇区的擦除和写入。对于擦除操作,按照IAP提供的操作方式即可实现,注意发送完擦除指令后需要一段时间的延时,并借助指令检查擦除是否成功。对于写入操作,需要根据IAP操作的相关要求,将数据首先复制到CPU的内部RAM中;然后通过相应的IAP写入命令将其写入到内部Flash中;写入操作完成后,需要进行一定的延时并检查写入是否成功。为了保证上述操作过程的完整性,对于μC/OS-II操作系统,需要借助OS_ENTER_CRITICAL函数进行必要的保护。引导加载程序有能力读写整个Flash存储器,包括引导加载程序所在的引导加载区本身。引导加载程序还可以对自身进行更新修改,甚至可以将自身删除,使系统的自编程能力消失。引导加载程序区的大小可以由芯片的熔丝位设置,该段程序区还提供两组锁定位,以便用户选择对该段程序区的不同级别的保护。

5 异常情况应对措施

对于嵌入式产品的在线升级过程,突发的在线升级过程异常中止、装置停电或异常复位,以及更新程序代码错误等情况会导致严重后果,而本产品的IAP在线升级方案完全解决了上述问题,可以保证产品的可靠升级。

①在线升级过程异常中止的情况。外部无线网络或人为原因都可能导致代码下载中断的发生。而对于本产品,下载中止只会导致本次下载失败,再次开始下载即可;而且由于采用了断点续传的软件技术,后续下载可以从上次下载失败处继续进行,从而提高了下载效率。

②装置停电或异常复位的情况。当停电或复位发生在下载到外部RAM过程中时,只会导致本次下载失败,重新启动装置可以再次下载;发生在代码从外部RAM向外部Flash导入过程中时,也只会导致本次下载失败,不会影响产品的正常运行;发生在代码从外部Flash向CPU内部Flash导入过程中时,内部Flash的应用程序代码区被破坏,应用程序无法正常运行,但是boot程序可以继续工作,可以在boot程序中完成应用程序的更新工作。

③更新程序代码错误的情况。例如由于人为原因下载了一个错误版本的应用程序,导致产品循环异常复位无法正常运行。应用程序中加入了复位监测机制,当异常复位连续达到一定范围时会自动进入boot程序运行状态,可以在boot程序中完成应用程序的更新修复工作。

结 语

采用本IAP设计方案的终端产品,经过上千个用户现场的应用程序在线升级的实际应用检验,完全达到了快速、稳定、可靠的使用要求。该方案为现场服务人员和用户提供了一种简单、可靠的产品维护手段,对于其他嵌入式产品的设计和开发也具有一定的指导和借鉴意义。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 微控制器
    +关注

    关注

    48

    文章

    7565

    浏览量

    151574
  • 存储器
    +关注

    关注

    38

    文章

    7507

    浏览量

    163963
  • GPRS
    +关注

    关注

    21

    文章

    984

    浏览量

    129480
  • 定时器
    +关注

    关注

    23

    文章

    3251

    浏览量

    114962
收藏 人收藏

    评论

    相关推荐

    基于GPRS远程医疗系统终端的设计与实现

    本文介绍了基于GPRS远程医疗系统中数据采集终端的设计方法。该系统主要由四部分组成:体温采集、心电采集、主控电路和蓝牙通信模块。
    发表于 04-09 13:46 3383次阅读
    基于<b class='flag-5'>GPRS</b>的<b class='flag-5'>远程</b>医疗<b class='flag-5'>系统</b><b class='flag-5'>终端</b>的设计与实现

    基于GPRS远程数据采集系统设计

    ),利用短消息传输来实现远程数据采集系统方案。全文由GPRS 业务的概述、远程数据采集系统的功
    发表于 12-08 09:57

    揭秘基于GPRS远程信息采集控制系统的设计方案

    一.信息采集控制系统的设计思想在远程采集终端下设一个核心控制芯片,该核心控制芯片负责管理下面的多个信息采集点,信息采集点先将采集的信息发送到核心控制芯片,然后核心控制芯片以标准的电气通讯模式,按一定
    发表于 12-23 16:36

    GPRS RTU在水源井远程监控系统应用方案

    ``  GPRS RTU在水源井远程监控系统应用方案  一、项目背景  近些年来随着社会的进步、经济科技的发展,人们生活、工作和生产水平有了很大的提高。人们对生产、生活提出了更高的要求
    发表于 03-15 10:35

    怎么实现基于GPRS的无线远程IAP功能?

    怎么实现基于GPRS的无线远程IAP功能?
    发表于 05-28 06:05

    芯片方案应用于终端产品时需要哪些技术支持和保障?

    在芯片方案应用于终端产品时,客户可能会遇到三大类问题:一是芯片本身的质量缺陷;二是芯片与终端系统软硬件联合调试及验证;三是终端生产。启英泰伦
    发表于 09-07 10:24

    GPRS城市燃气远程监控系统应用方案

    本文介绍的是GPRS城市燃气远程监控系统应用方案
    发表于 04-09 17:07 33次下载

    GPRS电力远程抄表系统应用方案

    本文主要介绍的是GPRS电力远程抄表系统应用方案
    发表于 04-10 09:40 24次下载

    基于GPRS-Internet 的城市路灯远程监控终端实现I

    本文介绍了基于GPRS-Internet的城市路灯远程监控系统组成、通信以及远程监控终端的软硬件实现。
    发表于 06-01 13:23 46次下载

    基于GPRS远程心电实时监护终端

    基于GPRS远程心电实时监护终端:针对现代医疗的新要求, 设计了一种基于GPRS远程心电实时监护
    发表于 08-25 18:29 13次下载

    GPRS远程自动抄表系统解决方案

    GPRS远程自动抄表系统解决方案      一、概述    《GPRS
    发表于 02-25 10:51 870次阅读
    <b class='flag-5'>GPRS</b><b class='flag-5'>远程</b>自动抄表<b class='flag-5'>系统</b>解决<b class='flag-5'>方案</b>

    看联网家居解决方案如何优化你的终端产品

    看联网家居解决方案如何优化你的终端产品 非常实用的技术文档 免费下载
    发表于 05-12 15:30 0次下载

    车载终端产品设计及生产

    本文详细地介绍了基于物联网的车载终端产品设计及生产等环节的技术问题,对于相关技术人员很有参考价值!
    发表于 06-23 17:21 21次下载

    ARM和GPRS远程监测终端设计

    ARM和GPRS远程监测终端设计
    发表于 10-15 10:51 12次下载
    ARM和<b class='flag-5'>GPRS</b>的<b class='flag-5'>远程</b>监测<b class='flag-5'>终端</b>设计

    基于运营商大数据的终端产品运营系统设计

    为了充分利用运营商大数据来支撑终端产品运营,设计了一种基于运营商大数据的终端产品运营系统,主要包括终端监控子系统
    发表于 11-02 15:30 16次下载
    基于运营商大数据的<b class='flag-5'>终端产品</b>运营<b class='flag-5'>系统</b>设计