历史上的今天

今天是:2024年09月14日(星期六)

正在发生

2020年09月14日 | MSP43F149系列单片机的IAP功能设计

发布者:心灵清澈 来源: elecfans关键字:MSP43F149系列  单片机  IAP功能 手机看文章 扫描二维码
随时随地手机看文章

  TI公司的MSP430系列单片机是具有很高实用性价值的产品,在许多领域得到广泛的应用,特别是它的超级低功耗特性,是目前所有其他单片机无法比拟的。IAP(InApplicaTIon Programming)是用户自己的程序在运行过程中对用户Flash的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产品中的固件程序进行更新升级。


  要实现IAP功能,通常需要在设计固件程序时编写两个项目代码:第一个项目程序不执行正常的功能操作,而只是通过某种通信管道(如USB、USART、一些无线设备)接收程序或数据(可执行HEX文件),执行对第二部分代码的更新;第二个项目代码才是真正的功能代码。这两部分项目代码同时烧录在用户Flash中,当芯片上电后,首先是第一个项目代码开始运行,再去更新第二段代码。


  根据IAP的特性,以及MSP430系列没有自带IAP功能的特点,必须自行编写IAP程序来进行片内Flash的烧写,这样才能达到升级的目的。以下将详细介绍如何进行IAP升级设计。


  系统设计的总体构想是,通过无线的方式,将需要升级的二进制文件直接下载到相应的地址空间,然后让单片机系统自动执行IAP升级。


  这里的重点是要编写一个“蚂蚁搬家”代码,因为它不是在MSP4 30F149片内Flahs区里运行的,而是在设定的RAM区运行。RAM空间有限,所以用汇编代码编写(推荐,也可以用C语言写,然后再精简为汇编语言),不能有堆栈的操作,代码不能超过2 KB。


  1 硬件设计

  (1)系统主芯片的内部结构

  首先简单介绍一下MSP430F149的内部存储地址结构图,如图1所示,这样有助于对它进行IAP的升级设计。

MSP430F149的内部存储地址结构图

  由图1可以看出,ROM和RAM同一个地址空间,寻址空间为64 KB,采用冯·诺依曼结构,使用一组地址数据总线,地址为0000H~FFFFH,RAM地址区域为0200H~09FFH,代码区ROM为1000H~FFFF。


  (2)外扩的Flash芯片结构

  为了能够将要升级的文件(一般是IAR编译出来后,要经过第三方软件换为二进制文件)先保存在一个地方,系统必须外扩1片Flash(当然也可是其他介质)。由于MSP430F149系列单片机的SPI接口有2个,因此选择了具有SPI接口的Flash芯片,如SST25VF016(16 Mb)等系列。该芯片电压为2.7~3.6 V,刚好符合MSP系列单片机低功耗电压的要求,操作指令非常简单。外扩Flash硬件框图如图2所示。根据保存数据的要求,可以设计为多片,使保存的空间更多。在软件设计时,设计好存放升级文件的首地址和该文件的大小。在MSP430F149系列中,该文件一般大小为64 KB。

外扩Flash硬件框图

  (3)存储空间地址划分

  为了能详细清晰的说明,可以把HEX文件保存在SST25VF016的开头地址上,即地址从0x000000~0x010000即可。当然也可以根据项目要求,自定义空间地址。


  2 通信传输

  对于如何将编译好的可执行文件(BIN文件)从第三方下载到相应的外扩存储空间里,这里主要推荐几款无线远程升级方案:

  ①无线GPRS方案,优点是可以远程控制下载;缺点是GPRS需要收费,而且是一卡对应一设备(在即将解决费用问题的同时,这也许是未来发展的趋势)。

  ②红外线方案,现在很多的PDA都带有该功能,在该单片机的系统加接一个红外模块,并且在PDA上写个小软件,就可以轻松地将升级文件下载到外扩的Flash指定的位置;缺点是需要人员到现场作业。

  ③蓝牙技术方案,这个技术和红外线技术类似,优点是数据传输没有方向性,速度较红外线快得多。


  其他不一一介绍,希望读者能有更多的升级方案。为了简要说明,这里用红外线方案作为下载升级软件的媒体介质,其他无线或者有线的媒体介质,其原理都一样,读者可以根据自己的项目自行选择。


  3 软件设计

  首先假设已经将要升级的文件下载到相应的外扩Flash中了,对于整个IAP程序的设计,分为两个部分:第一,先编写“蚂蚁搬家”程序,即一字节一字节地从相应的外扩Flash地址(事先已经定义好了)中搬移到片内Flash中(从0x1100开始至0xFFFF);第二,编写引导程序(COPY程序),将“蚂蚁搬家”程序拷贝到相应的RAM空间(0x0200)中,并将PC指向0x0200。系统升级程序流程如图3所示。

系统升级程序流程

  注意:从片外的Flash拷贝到片内Flash中时,一定要将60 KB全部拷贝完毕,否则系统将为不正常。最后要开启看门狗,复位,即PC从0x0000开始。“蚂蚁搬家”程序流程如图4所示。

“蚂蚁搬家”程序流程

  图4中必须注意:

  ①必须先固定该程序的入口地址,这样引导程序才能将之拷贝到RAM中,大小要控制在2 KB之内。该程序比较小,一般不超过2 KB 。


  ②必须将Flash状态锁住,这样在写的时候不容易出错。

  ③在读取60 KB数据后,打开看门狗。IAP升级系统是根据看门狗不喂狗来自动复位重启系统的。


  用户只要根据上面的流程进行编程,就很容易实现IAP升级(这里是重点,也是一个难点)。引导程序流程如图5所示。


  图5说明:声明一个入口函数,便于外部程序升级时调用。这个引导程序比较简单。由于在片内执行,所以使用汇编语言(mov指令)很容易就可以把蚂蚁搬家程序导入到RAM中。


  由于IAR编译出来的最终文件为*.a43文件,建议使用类似(HexToBin.exe)软件将*.a43文件转化成二进制文件,就可直接下载了。


  4 注意事项

  这段代码必须在RAM里运行,所以暂时不使用SP来“RET”。也就是说,不可以使用CALL指令,也不可以使用压栈处理(如PUSH或者POP等指令),所以这里将不可以开设堆栈区。通过某种无线手段执行代码(BIN文件),然后根据自定义无线协议,将该可执行代码下载并保存到片外的Flash相应地址空间,最后启动升级程序。最后通过启动看门狗并复位来启动系统。


  结 语

  通过长期的实践证明,本方案具有非常高的可靠性。这里虽然只介绍了MSP430系列产品的IAP升级方法,但对于其他没有自带IAP功能单片机的升级,其设计思路却都一样。这里提醒广大的开发爱好者,对于一串串的二进制文件数据,我们不要害怕;只要独立思考,抓住单片机的特性,灵活应用,只有想不到,没有做不到。祝大家共同进步!

关键字:MSP43F149系列  单片机  IAP功能 引用地址:MSP43F149系列单片机的IAP功能设计

上一篇:基于MSP430单片机设计的超低功耗的空间定向测试仪
下一篇:如何构建长距离通信网络使用RS485协议

推荐阅读

指导单位:国家商务部国家科技部国家工业和信息化部国家发展和改革委员会 组织单位:北京亚太瑞斯会展服务有限公司振江国际展览(北京)有限公司 支持单位:中国电子器材总公司中国汽车工业协会中国机械工业联合会中国线缆行业协会 【展会背景】 连接器及线束是当今电子化、信息化时代行业中发展最快,市场需求量最大,安装最为方便的产品之一。从普...
有网友在雪球上向步步高集团董事长段永平吐槽一加,他称:“从一加1用到3T,刚换一加7Pro,真的问题太多了,有点失望”。段永平回复他说:“我也买了一个,会转给刘作虎。”不知道刘作虎对段永平关于用户使用一加7 Pro的吐槽会作何处理,从以往段永平关于刘作虎的评价看,刘作虎应该会妥善处理的。我们来了解一下网友吐槽的一加7 Pro:据悉,一加7 Pro...
TIM2作master;TIM3,TIM4作slave定时器2事件更新被用作触发输出TRGO从定时器TIM3,TIM4工作在从模式:门控模式触发选择设为:ITR1,这样TIM2的TRGO就连到了TIM3和TIM4的内部触发输入ITR1上,经过一系列选择器之后TIM2的TRGO就是TIM3和tim4的TRGI;这样一来就可以通过控制TIM2的period和Pulse来控制TIM3和TIM4输出一定的脉冲个数;
具体实现功能系统由STC89C52单片机电路+GPS模块电路+GSM模块SIM800A+指示灯电路+电源电路组成。具体实现功能:1、系统上电后,系统向特定手机号码发送短信,短信内容为系统的当前经纬度信息。40s左右发一次。2、如果需要立刻发送经纬度信息,直接按板载按键即可立刻发送经纬度数据,不用等待40s。3、短信发送及初始化有状态指示灯指示。设计背景人类的第一...

史海拾趣

问答坊 | AI 解惑

台湾交大IC设计文章twIC_carry_lookahead

台湾交大IC设计文章twIC_carry_lookahead…

查看全部问答∨

请问大哥们有没有关于pcb设计类的论文啊

本帖最后由 paulhyde 于 2014-9-15 09:45 编辑 请问大哥们有没有关于pcb设计类的论文啊,正在搞论文,不晓得做啥  …

查看全部问答∨

急求EPM3256ATC144的引脚图

如题  或者EPM1270的也可以 最好能给个能直接用它的IO口的原理图出来 谢谢~!…

查看全部问答∨

vhdl奇偶校验电路中信号和变量的问题

在下面的程序里面,我个人感觉tmp应该被定义为变量,而不能被定义为信号.因为变量赋值是没有延时的,而信号赋值有延时.造成tmp <= tmp XOR a(n);无法执行,因为没有初值.但是书中却定义为信号.请问各位,应该定义为什么呢. LIBRARY IEEE; USE I ...…

查看全部问答∨

无法定位程序输入点……于动态链接库wgapi.dll上

    电脑中毒了,总是跳出某一块内存(一串数字标出来的)can\'t read,而且只要我打开无线链接,同寝室的网都一下子卡住了,似乎特别的敏感(我原来一直都是用无线上网的,也从来没有出现过这种情况),我查看资源管理器,发现资源管理 ...…

查看全部问答∨

电子产品研发需要哪些实验设备呀?希望大家踊跃发言!!!

公司是个电子设备公司,最近要采购一些设备。研发部目前只有万用表,示波器。 还需要什么设备?电子产品抗干扰能力该用什么设备测试呢?…

查看全部问答∨

WINCE5.0如何更改点击触摸屏声音?

在wince 5.0下如何更改点击触摸屏的声音. 请帮忙,谢谢。…

查看全部问答∨

VHDL,有个题目不知怎么入手,高手给点提示

VHDL,有个题目不知怎么入手,高手给点提示,cycloneII的fpga,坐立不安中…

查看全部问答∨

收一块AVR学习板  带视频的

收一块AVR学习板  带视频的…

查看全部问答∨

大家IAR都用什么字体?怎么添加新字体呢?

新手请教,我在网上看到有用Comic Sans MS的字体,挺好看的,但是IAR自带的那里好像没有,能另外添加么?好像不能像word里添加那么简单......,求助!…

查看全部问答∨
小广播
设计资源 培训 开发板 精华推荐

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

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

更多往期活动

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved