C8051F单片机的软件IAP技术

发布时间:2010-4-6 10:33    发布者:李宽
关键词: IAP , 单片机 , 技术 , 软件
引言

C8051Fxxx系列高速SoC单片机是由美国Cygnal公司开发的完全集成的混合信号系统级芯片,具有与8051兼容的微处理器内核。C8051Fxxx单片机有大容量的Flash存储器,用于存储程序代码和非易失性数据,可在应用编程。以 C8051F120为例,C8051F120x 和C8051F13x 系列MCU 内部有128 KB(C8051F12x 和C8051F130/1)或64 KB(C8051F132/3)的在应用可编程Flash 存储器,用于程序代码和非易失性数据存储;另外还有256字节的Flash页,可以用于数据存储。可以通过JTAG接口对Flash存储器进行在应用编程,或由应用软件使用MOVX 指令编程。用C8051F120 MCU做成的产品到了用户处之后,用软件通过串口就可以为产品进行Flash程序的更新。笔者通过实验,在用户操作界面的PC机及C8051F120的单片机控制系统之间,通过串行口进行C8051F120 单片机控制程序的自动升级及程序加密。用户只要从互联网上下载控制程序,即可实现单片机程序的自动升级。该方案解决了升级过程意外中断、远程升级传输误码等关键技术问题,避免了传统固件升级需要更换主机、主板或芯片等问题,节约了人力和资金等资源,已在实际系统中应用并受到用户好评。以下以64 KB Flash为例,简要介绍单片机目标程序的准备及自动升级的制作过程。

1  自动升级的实现方法

C8051Fxxx系列单片机将Flash程序区按512字节为一页(page)来组织。在删除控制程序区时,首先屏蔽所有中断,使能程序删除位 PSEE(PSCTL.1),同时使能PSWE(PSCTL=0x03, 即PSWE = 1, PSEE = 1,页擦除模式) ,用C51语言的一个指针指向Falsh程序区。如:

  char xdata * data address=0x0000;

每擦除一页地址指针加512,依此操作可删除所有的程序页。删除部分程序如下:

  while(address<0x0F800) {//0xF800=62KB
    *address = 0x00; //向扇区空写,启动擦除操作
    for (i=0;i<10;i++);
    address =address +512;
  }

这样就把62 KB的Flash的旧程序删除了。实际上就是应用汇编语言中MOVX指令在每一页的任一地址写0FFH,就可以将该页的所有字节都置为0FFH,从而实现了该页的删除。

擦除掉所选的区域后要关掉对Flash的写操作,否则可因其他环境造成程序的丢失:

  PSCTL &= ~0x03;// PSWE = 0; PSEE = 0
  FLSCL&=~0x01;//关闭Flash写/擦除

1.1  更新程序的方法

在接收新程序部分,写入一握手程序块,以保证程序的可靠性。握手的协议可自己定义,其中包括一些需要知道的信息,如长度、头部、尾部等。

同样,“char xdata *data address=0x0000;”指向要写的区域。

   FLSCL |= 0x01;//使能Flash写/擦除
  PSCTL |= 0x01; // PSWE = 1

然后通过串口用查询的方法获得新的程序代码。

  while(len--) {
    *address++= Get_COM_Code();
  }
  PSCTL=00; // PSWE = 0; PSEE = 0
  FLSCL =00;

1.2  运行新程序

在更新完程序后,有两种方法可以重新运行程序;断电再上电和软件复位。 C8051F120内部有复位寄存器,通过使能该寄存器,可以实现软件复位。

   RSTSRC=0x10;//实现软件复位
  Jmpmain();

对RSTSRC的写操作均用直接赋值方式完成(如RSTSRC = 0x02),不能用读/写指令(如ORL或ANL)来完成。例如,代码“RSTSRC |= 0x02”就是非法的。为保证完美的复位,在设置了复位寄存器后笔者还添加了汇编复位程序,以做到万无一失。

  Jmpmain:
  LJMP 0000H
  RET

这样通过一条长跳转指令跳到程序区最开始的位置。在C中调用汇编程序的方法请参考其他文档。

2  引导区的编译

作为程序引导区的程序,平时不参与主程序的执行。而主程序主要用于和用户操作界面PC 机部分进行握手,当接收到PC 机部分要进行软件升级的命令时,程序跳至引导程序区,执行如下流程:

发送准备升级字节到PC 机→删除Flash 程序区→发送开始下载命令到PC 机→接收且放到相应地址。

1.gif
图1  主程序流程

主程序流程如图1所示。引导区的程序要固定在一个位置,并单独编译,由 JTAG下载到MCU中。引导区的程序不能编译分配Flash地址。笔者使用的Keil编译器是一个很简单、易用的编译器。在Keil中,定位升级程序位置的实现方法非常简单,通过修改其Project菜单下的Options for target一项就可以了。

在本程序中,引导区的程序定义在62 KB之后的位置。

编者注: 硬件接口和主从机程序见本刊网站www.mesnet.com.cn

3  注意的问题

① 使用内部振荡器,这样能提高系统时钟的抗干扰能力。
② 使用Flash时会限制执行写操作的速度。完成1个字节的操作最长需要40 μs ,所以最好选用9 600的波特率。
③ 减少将PSWE置1的指令操作。理想的情况是只有2个操作会将PSWE置1,即写1个Flash字节和擦除1个Flash字节。
④ 将Flash写/擦除指针指向data或idata区。
⑤ 引导区的程序应该以512字节为边界。
⑥ 升级用的HEX程序必须由PC机上的软件转化为BIN文件。
⑦ C8051F120 MCU程序的操作最大特点是:在配置寄存器时能切换到该寄存器所在的页。
⑧ 引导区的程序在擦除或者写时,不可以开中断,且要关掉所有中断。

结语

本文中的软硬件模块已被嵌入到相关的应用系统之中,提高了系统的性价比。该方案解决了升级过程中的一些关键技术问题,节约了资源,将会在一些高端控制中得到更为广泛的应用。软件IAP 技术不但适用于C8051F单片机,而且对使用其他单片机的产品设计也具有重要的参考价值。

参考文献

[1] 姜晓梅,李祥和.基于ARM的IAP在线及远程升级技术[J].计算机应用,2008(2):519521.
[2] 周立功,张华.深入浅出ARM7[M].北京:北京航空航天大学出版社, 2005: 426438.
[3] 刘忆辉,魏银库,等.片外Flash存储器IAP的一种方案[J].单片机与嵌入式系统应用, 2006(2).
[4] 王飒.用C8051F020的SPI接口扩展大容量数据存储器[J].微计算机信息, 2006(22).
[5] 李光飞,阳富民,楼然苗.基于K9F2808UOC的FAT16文件系统[J].浙江海洋学院学报:自然科学版,2006(6).
[6] K9F2808UOC datasheets[OL]. http: //www. samsung. com /Prod?ucts/datasheets. htm.

作者:广东技术师范学院 向丹  杨永
来源:单片机与嵌入式系统应用 2009 (3)
本文地址:https://www.eechina.com/thread-10189-1-1.html     【打印本页】

本站部分文章为转载或网友发布,目的在于传递和分享信息,并不代表本网赞同其观点和对其真实性负责;文章版权归原作者及原出处所有,如涉及作品内容、版权和其它问题,我们将根据著作权人的要求,第一时间更正或删除。
您需要登录后才可以发表评论 登录 | 立即注册

厂商推荐

相关在线工具

相关视频

关于我们  -  服务条款  -  使用指南  -  站点地图  -  友情链接  -  联系我们
电子工程网 © 版权所有   京ICP备16069177号 | 京公网安备11010502021702
快速回复 返回顶部 返回列表