电子工程师的网站
首 页 |  新闻资讯 | 最新产品 | 解决方案 | 技术参数
设计应用
电路图 | 技术资料 | 芯片资料 | 技术论坛
  现在位置: 首页 > 设计应用 > 接口/总线/驱动 > 详细信息
接口/总线/驱动:MSP430程序升级方式探讨
来源:   时间: 2007-5-30 19:43:29    
对MSP430系列单片机进行编程的方式有以下3种:利用JTAG接口,利用BSL固件和利用用户自定义的升级固件。由于利用自定义升级固件进行程序升级的方式比较灵活,且用途广泛,因此本文将对其作重点介绍。

  1 利用JTAG接口

  MSP430系列的单片机都集成了JTAG接口,该接口实现了遵循IEEE STD1149.1规定的测试访问端口状态机(TAP Controller)。它使用一个4线串行接口(TEST用于引脚较少的芯片)。数据或指令从TDI(测试数据输入)移入;串行数据从TDO(测试数据输出)移出;TCK(测试时钟)作为时钟信号输入;TMS(测试模式选择)信号控制TAP控制器的状态。利用该接口可移入指令和数据,从而控制目标芯片的地址线和数据线,达到读/写目标芯片Flash和仿真调试的目的。另外,TI公司推出了新型的调试接口——SPY-BI-WIRE。它采用两线制,一根为数据线(双向),另一根为时钟线。

  利用该接口的优点是,无须设计额外的电路和程序,采用仿真器即可下载程序。缺点是一旦用户为了保证代码的安全,烧断了JTAG的熔丝,那么就永久性地破坏了该接口,也就不能再
 
使用该接口了。

  2 利用BSL固件

  BSL是Bootstrap Loader的缩写,中文名称是“程序装载器”。它实质是固化在芯片中的一段通信程序(占用OC00h~1000h的地址空间),利用它可实现对Flash的擦除和读/写。由于它是固化在芯片中的,因此不必担心被更改或丢失。

  该接口使用5根线:GND、TX(P1.1/P1.0)、RX(P2.2/P1.1)、RST和TCK(TEST)。在RST和TCK(TEST)上加特定的电平时序信号,即可启动BSL程序,从而实现与目标芯片的通信。通信的字符格式是8个数据位、1个停止位和1个偶校验位。起始波特率为9 600 bps(BSL 1.6版本可更改为38 40O bps)。BSL协议要求首先接收一个80h字符用于同步时钟;然后发送应答字符90h;最后接收8个字符,并根据命令跳转到相应的处理例程。BSL程序的C语言描述如下:

程序

  其实现细节可能因版本不同而有所变化。若用户想利用它来实现程序升级,则可见参考文献[2]和[3]。利用BSL程序进行升级,优点是节省代码空间,用户无须实现自己的升级固件,而且现在已有很多现成的BSL升级工具;缺点是须预留BSL接口,且需要现场接线。

  3 利用用户自定义升级固件

  MSP430系列单片机的Flash存储器模块是一个可独立操作的物理存储单元。全部模块安排在同一个线性地址空间中,存储器被分为多个512字节的段(信息段大小为128/64字节)。各段可单独擦除,并且在正常工作电压下程序可对Flash进行擦写操作,因此特别适合在线程序升级(In Systerrl Programming)。

  自定义升级固件就是在程序中内置一段用于升级应用程序的代码,即可利用现有通信接口进行远程代码的升级。其实现原理是在目标芯片中放置两段代码:一段为应用程序;另一段为升级程序。两者的地址段不重叠,这样就可以利用升级程序擦除应用程序,并写入新的代码。

  3.1 引导程序

  复位后先进入引导程序,由它来决定进入升级程序或应用程序。引导程序的意义在于当应用程序不存在或出现错误时能直接进入升级程序,从而保证若升级不成功则可进行再次升级。

  引导程序的描述如下:

程序

  其中:ResetVectorvalid()函数用于检测应用程序是否存在或是否有效。实现可以检测EnterApplication的入口地址是否合法,一种简单的实现是:

  #define ResetVectorValid() (RcsctVector!=FFFF)

  其中:ResetVetor为应用程序的入口地址,该地址通常放在一个固定的地址中,升级程序后再修改该入口地址。Application()为应用程序,它若正常执行则不会返回,只有在接收到升级指令后才返同。可在Application()中使用return语句进入升级程序。

  Updata()为升级程序,其入口处必须加检测指令,以确认正常进入升级程序。进入升级程序后,通信端应先发送擦除指令,擦除原有代码;然后发送升级代码更新Flash。如果具有外部扩展存储器或用户程序较小,那么可先接收整个程序段,若校验正确再写入,这样可靠性会更高。

  这里有个策略就是,最先擦除包含ResetVector的块,最后写入Resetvector的值,这样可以尽量保证不会进入不完整的应用程序。

3.2 应用程序的编写

  应用程序的编写投有大的变化,只需在通信协议中加入自定义的一个升级命令,以进入升级程序。另外,须更改链接文件(*.XCL),指定应用程序的地址范围。地址范围为2500h~F7DCh的应用程序如下(用//注释掉的为默认设置):

程序

  修改完毕后将该文件添加到工程中。编译后的代码即可作为升级代码。

  3.3 升级程序的编写

  新建一个工程,按上述方法将升级代码定位到与应用程序不重叠的区域(如F800h~FFFFh),此时不修改:一Z(CONST)INTVEC=FFE0-FFFF

  在升级程序中,将除复位中断外的所有中断映射到应用程序中。一种方法是嵌入汇编,采用汇编的定位指令ORG;另一种是写15个中断映射函数。例如:

  //重新映射中断向量地址

程序

  另外也可采用动态确定中断入口地址的方法,即将中断向量地址放入约定好的RAM中。例如:

程序

  然后在应用程序中进行中断向量的映射,例如:mtvecl[TIMERA0_VECTOR/2]=Timer_A_O;即在TIMERA0中断时执行Timer_A_0()函数。这样做的优点是可在运行时动态决定中断函数的入口,如高级语言中的虚函数(Virtual Function)。

  这两个函数块编写完毕后即可进行工程测试。

  3.4 应用程
 
序与升级程序同时完成

  如果需要两个函数在一个工程里完成,那么除了修改链接文件外,还须注意以下几点:

  ①将升级程序的所有函数定位到升缴程序空间,即在甬数前面加如下定位指令:

  #pragma locanon="UPDATECODE"            //UPDATECODE为升级程序所在段的名称

  ②修改函数返回调用的例程。当函数返回时会调用弹出寄存器的默认例程,而这些例程可能并不在升级程序的地址空问内。一种解决方法是利用编译环境生成的LST文件(汇编代码),逐个修改函数返回时调用的弹出寄存器例程,即可保证两者代码独立。这样做的缺点是每次更改C语言代码后,须重新修改汇编代码,比较繁琐。另一种方法是考虑到升级程序的工作就是接收和发送数据,一般无须使用中断。这样就可以在升级函数前加入一monitor编译指令.指明该函数为原子操作。这类函数入口处先压入SR并禁止中断,返回时使用RETI返回。此时编译器并不调用例程弹出保存的寄存器,而是根据进栈情况逐个弹出寄存器。

  ③更改switch语句。使用switch语句时编译器也会产生默认例程调用。很难屏蔽掉,故只有将switch修改为多个判断语句。

  结语

  本文对MSP430列单片机的升级方案进行了详细介绍,读者只须按照一定步骤,即可轻松实现远程程序升级,这在实际应用中具有重要意义;而且本文的升级方法并不仅限于MSP430系列,也可应用到类似的单片机系列中。

相关信息
发表评论
打印本页 关闭本页
MSP430单片机的加密熔断器设计
  引 言   MSP430系列单片机是德州仪器(TI)公司推出的一款16位超低功耗单片机。它能够在1.8~3.6 V电压、1 MHz频率的条件下运行,耗电电流在0.1~400μA。在运算速度上,MSP430系列单片机能在8 MHz晶振的驱动下,实现125 ns的指令周期。16位的数据宽度、125 ns的指令周期以及多功能的硬件乘法器相配合,能实现数字信号处理的某些算法(如FFT等)。  在整合方面,MSP430系列单片机将大量...
>>详细内容
基于MSP430的卫星通信车载站手持监控设备的设计
    摘要:本文介绍了一种基于MSP430FG4618单片机的卫星通信车载站的手持监控设备,该设备可完成对天线控制器、卫星MODEM的监控,实现各类参数的设置、工作模式选择和系统状态的监视。关键词:车载站;手持监控设备;MSP430FG4618 引言  车载式卫星通信地球站是安装在汽车上的卫星通信站,它利用汽车的快速机动性,可以迅速赶到事件现场,构成高速信息信道,以满足实时通信的需求。为...
>>详细内容
基于由MSP430和CC1100构成的无线传感器网络
    无线传感器网络是由大量微型传感器节点通过无线自组织方式构成的网络。它集成了传感器、微机电和无线通信三大技术,能够实时地感知、采集和处理网络覆盖范围内的对象信息,并发送给观察者;具有覆盖区域广、可远程监控、监测精度高、布网快速和成本低等优点,在军事、环保、医疗保健、空间探索、工业监控、精细农业等领域均有非常良好的应用前景。   1 无线传感器网络结构   ...
>>详细内容
基于MSP430F2012和IA4420的主动式RFID标签设计
  概述   射频识别(RFID)是近年来成长最快的无线技术之一,它将条形码及无线技术的优势带入资产管理、产品跟踪、海运及运输识别、库存控制和定位检测中。大多数RFID系统采用通过RF从阅读器获取电源的被动式标签。这样有利于减小标签尺寸和降低成本,但是会限制读取范围和数据存储能力。带电池的主动式标签可以提供较大范围的读取能力和更强的可靠性,不过其尺寸较大,也更贵一些。采用最...
>>详细内容
MSP430单片机中的WDT研究
  引 言   软件的可靠性一直是一个关键问题。任何使用软件的人都可能会经历计算机死机或程序跑飞的问题,这种情况在嵌入式系统中也同样存在。由于单片机的抗干扰能力有限,在工业现场的仪器仪表中,常会由于电压不稳、电弧干扰等造成死机。在水表、电表等无人看守的情况下,也会因系统遭受干扰而无法重启。为了保证系统在干扰后能自动恢复正常,看门狗定时器(Watchdog Timer)的利用是很有价值...
>>详细内容
基于MSP430F149的无线环境监测传感器系统设计
    摘要: 为了提高环境参数采集的自动化水平, 提升效率, 设计了无线传感器系统。本系统运用了传感器技术、通信技术和单片机技术, 实现了对环境温度、湿度、光照度以及可燃性气体浓度等参数的检测。它能够实时地与上位机进行无线通信, 满足对环境参数实时监测的要求。   关键字: MSP430F149; 温度; 湿度; 光照强度 引言   传感器技术与通信技术、计算机技术相结合构成的智能...
>>详细内容
已有(
)位对此新闻感兴趣的网发发表了看法 >>更多评论
内 容:
     
 
热点新闻
一周排行
关于我们 | 服务项目 | 付款方式 | 广告服务 | 联系我们 | 友情链接 | 投诉 建议 合作 | 网站地图 | 加入收藏
Copyright © 2007-2008 WEEQOO.COM Corp.All Rights Reserved. 版权所有 经营许可证编号:浙B2-20050339 法律声明
维库电子旗下网站:维库电子市场网 | ChinaICMart | 维库电子开发网 | 维库电子人才网
总部:杭州市下城区朝晖路182号国都发展大厦1号楼80A
电话:0571-85889139-8007 QQ:303939539 | MSN:zh1226@hotmail.com |  邮箱:laz8258@163.com dzsc51@163.com