基于IAP的ARM7程序在线更新设计

发布者:alpha12最新更新时间:2011-06-17 关键字:IAP  ARM7  程序在线更新 手机看文章 扫描二维码
随时随地手机看文章

    ARM处理器是一种高性能、低成本、低功耗的RISC微处理器,是目前最为流行的微处理器之一。ARM7作为ARM微处理器系列中的一员,广泛应用于工业控制、网络应用、消费电子和安全产品等。实际应用中往往需要对产品的程序进行升级以提升性能或消除缺陷,如何对已经投入使用的产品进行方便可靠的程序在线升级,是产品设计初期必须考虑的问题。尽管目前绝大多数基于Flash结构的ARM7芯片具备ISP功能,但是这需要特定的烧写软件支持和专业人员操作。烧写软件由芯片厂商提供,不便于集成到产品的主机端软件中。在产品软件功能中添加简单易用的程序升级功能十分必要,文中以NXP公司的ARM7芯片LPC2132为例,为具有IAP功能的ARM7芯片提出一个稳定的在线升级方案。


1 IAP功能介绍
    在应用编程IAP(In-Application Programming)是应用在Flash程序存储器的一种编程模式。它可以在应用程序正常运行的情况下,通过调用特定的IAP程序对另外一段程序Flash空间进行读/写操作,甚至可以控制对某段、某页甚至某个字节的读/写操作,这为数据存储和固件的现场升级带来了更大的灵活性。LPC2132的IAP程序位于芯片的BootBlock中,芯片出厂时由厂家写入,不可修改。IAP程序是Thumb代码,位于地址0x7FFFFFFO(重映射后地址)处。IAP功能函数可以通过如下代码方便的调用。
    void(*IAP)(unsigned int parameter[], un-signed int result[]);//定义函数指针变量IAP,//IAP指向的函数的参数为两个unsinged int数组
    IAP=(void(*)())0x7fff_fff1//设置函数指针,因为是Thumb代码,地址最低位设定为1
    unsigned int parameter_in;//通过设定parame-ter_in各成员的值,实现各种IAP功能
    usingned int result_out;
    (*IAP)(parameter_in,result_out);//调用特定功能的函数,执行结果存入result_out中
    //IAP的命令码、状态码和命令。


2 程序更新流程
    LPC2132有64 kB的Flash存储器,16 kB的RAM。Flash分为8个扇区,每个扇区4 kB空间,整个Flash存储器占用的地址空间为0x0000_0000-0x0000_ffff。为了实现用户程序运行过程中的程序更新,可以设计一段特定的驻留代码,专门用于接收来自主机新的代码,将其烧写到相应的Flash空间,完成后跳转到新的代码去执行新的程序,用户程序接收到来自主机的更新命令后跳转到这段驻留代码。驻留代码通过串口接收命令,调用IAP函数烧写Flash,代码比较少,编译生成的映像文件<4 kB,通过JTAG口将这段代码烧写到第一个4 kB扇区,每次系统上电或重启后先执行驻留代码,其运行流程为:
    (1)初始化串口,查询接受缓冲区,检测是否受到主机发来的4 bit数据包0x55 0xaa 0xff 0xff,其中前2 bit 0x55 0xaa为命令头;第3 bit 0xff为命令,表示需要更新;第4 bit为命令和校验。整个查询过程持续100 ms,如果在100 ms内没有收到此命令包,跳到应用程序入口执行旧程序,如收到该命令包,返回0xff,通知主机收到命令,执行下一步;
    (2)接受主机发来的数据包,其格式如表1所示。

    将接收到的4 kB数据存入SRAM,接收的同时计算数据载荷的8位校验和,对比校验和,如果校验和不对,给主机返回0x00表示接收不成功,主机会将当前包重发一遍;如果正确通过调用擦除IAP函数擦除当前需要写入的扇区,再调用写入IAP函数将RAM中的4 kB数据一次写入对应的扇区(通过配置上面提到的IAP函数参数parameter_in实现擦除和写入功能),给主机返回0xff,表示操作成功;[page]

    (3)如果上一步接受的数据包中标识指定其为最后一包,在执行步骤(2)写入操作后,跳到0x0000_1000处,即用户程序区,执行新的用户程序。通过下面的内嵌汇编代码可以十分方便的实现该跳转功能。
    相应的用户程序设计时应该能从串口接收主机的命令,当接收到4 bit数据包0x55 0xaa 0xff0xff后跳转到0x0000_0000处,执行驻留代码,由驻留代码完成用户程序的更新。用户程序设计时加上该功能后,其余与普通代码设计没有区别。主机端软件在用户点击更新程序后,读取ARM7映像。bin文件,识别其大小,将其分成以4 kB字节为单位的若干段,按照上面与驻留代码的通信协议,将映像文件给驻留代码,并给用户提示是否成功信息。
    在ARM应用系统中软件一般采用C语言进行编程,为了能进行系统初始化,通常会用一段汇编文件作为启动代码,实现异常向量表的定义,堆栈初始化、系统变量初始化、中断系统初始化、I/O初始化、地址重映射等。ARM7的异常向量位于地址0x0000_0000开始的32 bit内,当异常发生时程序从异常向量表取指令进行跳转。异常向量表位于Flash的第一个4 kB空间,用户程序运行时遇到异常时,也会到0x0000_0000开始的32 bit异常向量表中取出相应的指令。按照前面的设计,ADS编译器会将用户代码异常向量表运行地址设为从0x0000_1000开始,为了能让用户程序实现正确的异常处理,驻留程序的启动汇编代码需要将相应的跳转设为0x0000_1000开始的真正的用户异常向量处,这样驻留代码不能使用中断功能,实际上驻留代码完全可以采用查询方式进行串口通信。驻留程序的启动汇编代码示例如下:
AREA vectors,CODE,READONLY

    ENTRY

    CODE32
Reset
LDR PC,ResetInit;复位跳到驻留代码初始化程序ResetInit
    B 0x000010004;跳到用户异常向量UndefinedAddr
    B 0x000010008;跳到用户异常向量SWI_Addr
    B 0x00001000c;跳到用户异常向量PrefetchAddr
    B 0x000010010;跳到用户异常向量DataAbortAddr
NOP
    B 0x000010018;跳到用户异常向量IRQ_Addr
    B 0x00001001c;跳到用户异常向量FIQ_Addr
ResetInit


3 注意事项
    为了让用户代码运行地址从0x0000_1000开始,在ADS的ARM Linker选项卡将RO Base设为0x0000_1000。因为处理器要切换到Thumb指令执行IAP代码,需要将ARM C Compiler下的ARMThumb Interwoking选项勾上。另外IAP函数使用了RAM空间的高32 bit空间,因此用户程序不应该使用该空间,用户堆栈栈顶要设定为小于RAM顶端地址减32。


4 结束语
    实验结果显示按照上面的方法编写的驻留程序,能够稳定的接受主机发来的新程序,并成功烧写进Flash区,实现程序的更新。文中虽然以LPC2132为例实现,对于具有IAP功能的其他公司的ARM7芯片的在线程序更新也有借鉴意义。

 

关键字:IAP  ARM7  程序在线更新 引用地址:基于IAP的ARM7程序在线更新设计

上一篇:德州仪器推出新型 ConcertoTM 双核微控制器
下一篇:基于ARM-Linux的MiniGUI的仿真与移植

推荐阅读最新更新时间:2024-03-16 12:37

ARM7 LPC2138数字频率计的设计源码与报告
1.1、设计原理 频率就是周期性信号在单位时间(1s)内变化的次数。若在一定时间间隔T内测得这个周期性信号的重复变化次数为N,则其频率可表示为f=N/T。其中f为被测信号的频率,N为计数器所累计的脉冲个数,T为N个脉冲所产生的时间。计数器所记录的结果就是被测信号的频率计数法又称测频法,是将被测信号通过一个定时闸门加到计数器进行计数的方法,如果闸门打开的时间为T,计数器得到的计数值为N1,则被测频率为f=N1/T。改变时间T,则可改变测量频率范围。设在T期间,计数器的精确计数值应为N,根据计数器的计数特性可知,N1的绝对误差是N1=N+1,N1的相对误差为ΔN1=(N1-N)/N=1/N。由N1的相对误差可知,N的数值愈大,相对误
[单片机]
<font color='red'>ARM7</font> LPC2138数字频率计的设计源码与报告
STM32F103c8t6通过串口实现IAP在线升级固件
STM32f103c8t6 IAP在线升级 设计思路:(自己理解的哈,如果有问题,欢迎大家提出来,一起学习哈) 首先程序每次执行都会从基地址0x0800 0000开始执行。IAP程序升级最重要的就是写BOOTLOADER程序,进行引导升级,加载,跳转app程序。每次上电后进入bootloader判断是否升级如果需要升级,就就收bin文件进行升级,如果不升级直接跳入原app程序执行。 bootloader和app程序的FLASH大小根据实际情况自己确定分配就可以了 下面是我自己画得一个流程图:主要介绍整个大的流程 bin文件的生成方法可以百度一下,网上很多的 代码:(我是根据正点原子的例程改的,代码只贴了重要部分,如果有需要
[单片机]
STM32F103c8t6通过串口实现<font color='red'>IAP</font><font color='red'>在线</font>升级固件
ARM7单片机(学习ing)—(五)、实时时钟(RTC)—01
一曲熟悉的音乐~~ Rihanna~~我的手机铃声~~ 今天就是实时时钟(RTC)~~ 我决定了~~ 把ARM7的资料整理完以后不会整理这些资料了~~ 网上还是很多的~~ 不过我还是会更新自己学习的心得的~~ 去了学校~~ 大三下学期了~~ 也没有这么多的时间和精力了~~ 记住这个时刻~~ Califunia King Bed~~ 五、实时时钟(RTC) 五—(01)、实时时钟相关应用和寄存器的介绍~~ 1、特性 2、描述 3、结构 4、寄存器描述 5、RTC中断 6、混合寄存器组 a、中断位置(IIR—0XE0024000) b、时钟节拍计数器(CTC—0XE0024004)
[单片机]
<font color='red'>ARM7</font>单片机(学习ing)—(五)、实时时钟(RTC)—01
采用Keil4为ARM7 (LPC2103)创建工程 及J-link调试
采用Keil4为ARM7创建工程,采用J-LINK调试,具体步骤如下: 在菜单里的Project里选择New uVision project...,选择正确的路径并命名保存; 在弹出来的对话框中选择CPU,NXP(founded by philips)- LPC2103; 在弹出的对话框按“yes”复制LPC2100启动文件到工程; 在Project里面选择Option for Target'Target 1'...,Target里面的IROM1要配置正确(0x0 0x8000),一般采用默认值就可以了;Output选择里面的Name of Executable的命名不能用点号;Debug里面的选择
[单片机]
μC/OSII下的ARM7中断过程分析及优化方法
引言 目前,在嵌入式处理器芯片中,以ARM7为核心的处理器是应用较多的一种。它具有多种工作模式,并且支持两种不同的指令集(标准32位ARM指令集和16位Thumb指令集)。μC/OSII是专为嵌入式应用设计的抢占式、多任务实时操作系统,可用于各类8位、16位和32位单片机或DSP。μC/OSII向ARM7移植具有得天独厚的优点,所以“μC/OSII+ARM7”成为广泛应用的一款平台。 不管是哪种型号的ARM处理器,也无论该嵌入式系统中是否有操作系统,在计算机与外界实时交互的过程中,中断技术都是一项关键的技术。当外部事件发生时,CPU必须及时响应中断以实现对相应事件的处理,因此能否中断嵌套是影响嵌入式系统实时性能的主要因素。
[单片机]
μC/OSII下的<font color='red'>ARM7</font>中断过程分析及优化方法
ARM7与CORTEX M3内核高速度下的真实性能分析
刚才在 STM32 的相关文档中找到了可以在 RAM 中跑代码的描述。因此,下面对 STM32 的一些描述内容是错误的。STM32 是可以在 SRAM 中跑指令代码的。为了不让网友对后面其他的跟帖产生误解,原文不做修改。 当有些厂家的 ARM7 内核可以跑到75MHz 的时候,这种高速度真的让人很兴奋:32bit 的 MCU 价钱仅仅在 25 元人民币左右,集成了各种外设的整体性能却直逼当年的 80486 PC 整机,让人感慨万千。 但是,在高速的背后,却有些鲜为人知的细节。在看完厂家的产品说明书后,有人不禁产生了一个疑问:集成的 MCU 真的可以跑这么快吗?那些存储器的等待周期怎么来理解呢? ---------------
[单片机]
ARM全解析 ARM8/ARM7/A9/A15等区别
Cortex-A50是继Cortex-A15之后的又一重量级产品,将会直接影响到主流PC市场的占有率。围绕该话题,我们今天不妨总结一下近几年来手机端较为主流的ARM处理器。    以由高到低的方式来看,ARM处理器大体上可以排序为:Cortex-A57处理器、Cortex-A53处理器、Cortex-A15处理器、Cortex-A9处理器、Cortex-A8处理器、Cortex-A7处理器、Cortex-A5处理器、ARM11处理器、ARM9处理器、ARM7处理器,再往低的部分手机产品中基本已经不再使用,这里就不再介绍。 ● Cortex-A57、A53处理器    Cortex-A53、Cortex-A5
[单片机]
ARM全解析 ARM8/<font color='red'>ARM7</font>/A9/A15等区别
LPC1768 IAP升级解析及例程分享
1、IAP介绍 IAP即 in applicatin programming 在应用编程的缩写,指MCU可以在系统中获取新代码并对自己重新编程,即改变应用程序。它与我们所熟悉的ISP编程不同, LPC1768 的ISP编程接口为串口1,如果使用其他的串口或其他总线则不能对其进行编程。而我们这里所说的IAP通过下载一段引导程序Bootloader程序,如果我们想要从串口2或网口更新应用程序,在Bootloader中初始化相应的串口或网口,使其接收应用程序,将接收到的应用程序写入到Flash里面,IAP完成后跳转到应用程序入口执行应用程序。所以现在的IAP程序涉及到两个概念:Bootloader和应用程序。 Bootloader:B
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved