历史上的今天
返回首页

历史上的今天

今天是:2025年08月13日(星期三)

正在发生

2020年08月13日 | MSP430程序升级方案

2020-08-13 来源:elecfans

  对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系列,也可应用到类似的单片机系列中。

推荐阅读

史海拾趣

Cressall Power Resistors公司的发展小趣事

随着国内市场的饱和,Cressall开始将目光投向国际市场。公司积极参与国际电子行业的展会和交流活动,与国际同行建立了广泛的联系。通过与国外企业的合作,Cressall不仅引进了先进的技术和管理经验,还成功打开了多个海外市场。同时,公司还加强了与国际知名企业的战略合作,共同开发新产品,进一步提升了公司的国际竞争力。

晨晶电子(Chenjing Electronics)公司的发展小趣事

在追求经济效益的同时,晨晶电子也积极履行社会责任,致力于绿色环保事业。公司通过了ISO14001环境管理体系认证,严格遵守环保法规,实施清洁生产。同时,晨晶电子还积极推广环保理念,倡导绿色消费,为保护环境、促进可持续发展做出了积极贡献。

这五个故事不仅展示了晨晶电子在电子行业中的发展历程和成就,也体现了其不断创新、追求卓越的企业精神。在未来的发展中,晨晶电子将继续秉承这一精神,努力成为电子行业的佼佼者。

Cardinal Components公司的发展小趣事

2003年,Cardinal推出了首款可编程振荡器,这一创新产品为客户提供了更多的灵活性和定制性。随着技术的不断进步,公司在2006年引入了现场编程能力,进一步提升了产品的竞争力。这些技术创新不仅推动了公司的发展,也为整个电子行业带来了新的机遇。

Emhiser Research Inc公司的发展小趣事

随着全球对环保和可持续发展的关注度不断提高,Emhiser Research也积极承担起自己的环保责任。公司采用环保材料和生产工艺来降低产品对环境的影响;同时,公司还积极推广绿色电子产品的理念,帮助客户实现更加环保和可持续的生产方式。这些努力不仅提升了公司的社会责任感,也为公司的长期发展注入了新的动力。

北京人民电器厂公司的发展小趣事

北京人民电器厂有限公司,作为北方地区最大的低压电器制造企业,于1995年成功研发出全球首台高分断微型直流断路器。这一创新成果不仅填补了国内空白,更在国际上展现了中国在低压电器领域的研发实力。该断路器的诞生,标志着北京人民电器在直流断路器技术领域迈出了坚实的一步,为后续的产品研发和市场拓展奠定了坚实的基础。

Brite-Led Optoelectronics Inc公司的发展小趣事

随着市场竞争的加剧,Brite-Led意识到单凭自身力量难以持续保持领先。于是,公司积极寻求与其他企业和研究机构的合作研发机会。通过与一家知名高校的合作,Brite-Led成功开发出一种新型的LED封装技术,大幅提高了产品的可靠性和耐用性。这一合作不仅加强了Brite-Led的技术实力,也为其带来了更多的商业机会和合作伙伴。

问答坊 | AI 解惑

PLC控制系统设计要点(绝对很有用) 

自动控制可编程序控制器系统设计、应用    在现代化的工业生产设备中,有大量的数字量及模拟量的控制装置,例如电机的起停,电磁阀的开闭,产品的计数,温度、压力、流量的设定与控制等,工业现场中的这些自动控制问题,可编程控制器(PLC)已成 ...…

查看全部问答>

车载传感器的应用与分类

将当今的汽车说成是电子产品毫不过分,而且有人预言今后还会在安全、环保和信息化这三个领域加速实现电子化。这一趋势今后肯定只会加速而不可能停滞。因为汽车厂商在安全、环保和信息化这三个领域里早就提出了加速实现电子化的方针。而其中最值得关 ...…

查看全部问答>

saa7113h有人用过吗?

我想问下saa7113h 这个设备应该被视为主设备 还是从设备呢 还有就一般有什么办法来区分主设备 和 从设备吗 …

查看全部问答>

ce下的ReadFile()读串口时,是立刻返回,还是等待?

对这个问题比较迷惑,当使用ReadFile(),读串口时,如果没有数据过来,它是立刻返回还是在哪儿等待,如果等待,等多长时间?如果立刻返回,当数据过来时,我如何得到那个数据?…

查看全部问答>

用GSOAP做ARM+uclinux的web service

因为gsoap可以生成C,不知有谁做过类似的移植。 是否可行?对gsoap需要哪些改动吗? 望交流email:xia_1029@tom.com qq:173160851…

查看全部问答>

RC全波整流滤波计算

   最近手头碰到一个利用RC对全波整流滤波的电路,电路看上去很简单,用Pspice仿真很容易出来相应的值,但是考虑用数学方程表述时却不是那么简单了,一般我们见的RC不是理解为积分就是电容的瞬态响应再者用低通理解,可是全试了一遍,几 ...…

查看全部问答>

请教FSMCIO设置问题

在F103ZE是这样设置的:  /* NOE and NWE configuration */ //读写线   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4 |GPIO_Pin_5;  GPIO_Init(GPIOD, &G ...…

查看全部问答>

具有 6 位点校正功能的 16 通道 12 位 PWM LED 驱动器

你想知道大屏幕视频是怎样成功驱动成千上万个小LED的吗?德仪DC/DC转换器应用主管Michael Day为您展示具有 6 位点校正功能的 16 通道 12 位 PWM LED 驱动器,更多信息请访问http://focus.ti.com.cn/cn/docs/prod/folders/print/tlc5946.html…

查看全部问答>

M4开发工具

M4使用iar还是keil亦或者是ccs开发比较好呢?仿真器使用 那个呢?…

查看全部问答>

关于IC板游戏开发疑问

本人虽用vs2008 c#基于电脑应用程序开发也有很长时间了,但类似环境下的IC板游戏开发一无所知,目的是想像市面上的IC板类的游戏(如:猜色子点数大小 游戏)自己能开发一套类似的游戏出来运行在IC板上。列举问题如下:1、IC板的硬件是否也有一个类似 ...…

查看全部问答>