扒一扒单片机串口IAP原理

发布时间:2023-02-01  

一、什么是IAP?

IAP是In Application Programming的首字母缩写,IAP是用户自己的程序在运行过程中对User Flash的部分区域进行烧写,目的是为了在产品发布后可以方便地通过预留的通信口对产品中的固件程序进行更新升级。


在重新编程过程中可以使用任意类型的通信协议,如UART、I2S、SPI等。这篇笔记分享的是使用UART方式IAP。


二、串口IAP实验

先理一理流程(本实验是以STM32F103ZET6为例):

1、实验说明

做这个实验需要准备两个keil工程,一个工程用于编写IAP程序,另一个工程用于编写我们的应用程序(要实现某些功能的程序),这里我们以一个点灯程序为例。最终,两份工程编译出来的可执行文件都需要烧写到芯片的FLASH中。只不过需要烧写到不同的地址,简单的示意图如下:



这里使用的STM32型号为STM32F103ZET6,其FLASH大小是512KB,0x08000000为其FLASH被映射的地址,程序被烧写到的就是这个地址。此处,我们的IAP程序烧写到这个地址,根据IAP程序的大小,我们在keil里可以设置合适的IAP结束地址。

注意:在没有IAP程序的情况下,0x08000000这个地址就是应用程序烧写的地址。

2、工程说明

本实验用到的两个工程可按照文末的方式获取,其中IAP工程移植至ST官方例程。下面对两个工程进行简单的说明。

IAP工程:

(1)需要在target选项卡里设置我们IAP程序的起始地址与大小,如:



这里我们的IAP程序起始地址设为0x08000000,大小设为0x3000,即IAP所能用的FLASH空间为12KB。其中IAP所能占的占空间的大小可根据IAP的实际大小进行修改。

(2)需要修改程序中我们需要跳转到的应用程序的地址(即IAP程序的结束地址):



LED工程:

(1)需要在target选项卡里设置我们LED程序的起始地址与大小,如:



这里我们的LED程序起地址设为0x08003000,大小设为0x10000,即LED所能用的FLASH空间为64KB。其中结束地址可根据LED应用程序的实际大小进行修改。

(2)生成对应的.bin文件。这需要在User选项卡里添加如下命令(即编译后执行的命令):



其中,fromelf.exe是我们keil安装目录下的一个可执行程序,可以把.axf文件转换成.bin文件。要在keil中直接调用fromelf命令,必须要把fromelf.exe所在目录添加到环境变量中。添加环境变量的方法如下(该方法来自于《【野火】零死角玩转STM32—F429挑战者V2.pdf》):

本文以 Win7 系统为例添加工具链的路径到 PATH 环境变量,其它系统是类似的。

(1) 右键电脑系统的计算机图标,在弹出的菜单中选择属性 ,如图:



(2) 在弹出的属性页面依次点击高级系统设置 ->环境变量,在用户变量一栏中找到名为PATH的变量,若没有该变量,则新建一个。编辑PATH变量,在它的变量值中输入工具链的路径,如本机的是;D:workkeil5ARMARMCCbin,注意要使用分号;让它与其它路径分隔开,输入完毕后依次点确定,如图:



(3) 打开 Windows 的命令行,点击系统的开始菜单,在搜索框输入cmd,在搜索结果中点击cmd.exe即可打开命令行,如图:



(4) 在弹出的命令行窗口中输入fromelf回车,若窗口打印出 formelf 的帮助说明,那么路径正常,就可以开始后面的工作了;若提示不是内部名外部命令,也不是可运行的程序…信息,说明路径不对,请重新配置环境变量,并确认该工作目录下有编译工具链。

这个过程本质就是让命令行通过“PATH”路径找到fromelf.exe程序运行 。

学会配置fromelf.exe,也就学会配置了MinGW。MinGW是一个工具集,包含编译C与C++的gcc、g++,使用它就可以在Windows命令行下编译C程序。

3、IAP源码说明

(1)主函数:

int main(void)
{
  FLASH_Unlock();	/* FLASH解锁 */
  KEY_Init();		/* 按键初始化 */
  IAP_Init();		/* IAP初始化 */
	
  /* 按键按下则进入主菜单开始更新程序(注意:需要按下复位键的同时按下该按键触发程序更新) */
  if (GPIO_ReadInputDataBit(GPIOE,GPIO_Pin_2)  == 0x00)
  {
    SerialPutString("rn======================================================================");
    SerialPutString("rn=              (C) COPYRIGHT 2010 STMicroelectronics                 =");
    SerialPutString("rn=                                                                    =");
    SerialPutString("rn=     In-Application Programming Application  (Version 3.3.0)        =");
    SerialPutString("rn=                                                                    =");
    SerialPutString("rn=                                   By MCD Application Team          =");
    SerialPutString("rn======================================================================");
    SerialPutString("rnrn");
    Main_Menu ();
  }
  /* 保持运行用户应用程序 */
  else
  {
    /* Test if user code is programmed starting from address "ApplicationAddress" */
    if (((*(__IO uint32_t*)ApplicationAddress) & 0x2FFE0000 ) == 0x20000000)
    {
      /* Jump to user application */
      JumpAddress = *(__IO uint32_t*) (ApplicationAddress + 4);
      Jump_To_Application = (pFunction) JumpAddress;
      /* Initialize user application's Stack Pointer */
      __set_MSP(*(__IO uint32_t*) ApplicationAddress);
      Jump_To_Application();
    }
  }

  while (1){}

  return 0;
}

可见,我们按下复位的同时按下PE2对应的按键即可触发应用程序更新操作,否则跳转到应用程序的起始地址执行应用程序(断点重启也是默认执行应用程序),这里的ApplicationAddress就是我们上面设置的0x08003000。

(2)主菜单函数Main_Menu

这个函数里就是该IAP程序的功能,根据其中的打印信息:



可以知道,该IAP有三个功能(分别输入键盘上的数字1、2、3进行选择):一是下载程序(电脑->STM32);二是上传程序(STM32->电脑);三是执行新程序(即刚下载完成的程序)。

(3)下载程序功能函数SerialDownload

首先,上位机使用Ymodem协议进行数据下发,STM32根据协议解析数据,拿到有用的数据,并把这些数据写入FLASH对应的地址中,即ApplicationAddress。关于Ymodem协议及SerialDownload函数这里不展开讨论。

4、下载验证

(1)下载IAP程序

可以使用J-link等调试器进行下载,也可用串口ISP进行下载,我们选用的是串口ISP进行下载,借用的工具是FlyMcu:



这里下载的是.hex文件,如果下载.bin文件,则会提示如下错误:



程序文件不是0x8000000和0x20000000区域的

使用ISP方式下载需要进行的硬件操作是:BOOT0引脚拉高,BOOT1引脚接地。即系统存储器被选为启动区域:



在点击开始编程按钮后,需要按下板子上的复位键,即可下载程序。

(2)通过IAP程序引导下载LED程序

上面提到下载程序使用的是Ymodem协议,所以得选用带有Ymodem协议传输方式的上位机软件来把应用程序下载到板子里。可以选用SecureCRT,也可以选用超级终端。这里选用的是超级终端:



首先,按下数字键1触发下载程序操作,此时会不断打印CCCCC...。然后点传送->发送文件,选择要下载的.bin文件及Ymodem协议。下载完成后按下数字3即可执行新下载得应用程序:



终于,LED闪烁起来了,点灯项目成功


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    51单片机与计算机进行通信的实现方法;51单片机与计算机通信 首先我们先来了解一下51单片机与计算机进行通信的实现方法。先来看一个实现这个功能的基本电路。 图中的P1就是仿真用的一个串口......
    **需要一个串口,上报又需要另一个串口,这就要求单片机具有双串口的功能,或者做点阵驱动时,又需上机位串口。但我们知道一般的51系列只提供一个串口,那么另一个串口只能靠程序模拟。 本文所说的模拟串口......
    的数据码显示在电脑上,如可以使用一个按键,当按下它时使某一个字母如:AA,通过单片机的串口将它发送到电脑上显示,起到仿真器的某些功效,站长在开发数据采集设备时就是通过串口来检查数据正确与否的。 51单片机有......
    如何使用51单片机实现串口通信;STC51单片机一般带有1个串口,有的带有2个串口串口一般用于下载程序和串口通信。串口通信特别适合控制设备,所以工控机的电脑上一般都带有串口51单片机的串口......
    基于单片机和AD678芯片实现数字电压表的整机设计;数字电压表的设计和开发,已经有多种类型和款式。传统的数字电压表各有特点,它们适合在现场做手工测量,要完......
    电平。Max232芯片起电平转换的功能,使单片机的TTL电平与PC的RS232 电平达到匹配。 串口通信的RS232接口采用9针串口DB9,串口传输数据只要有接收数据针脚和发送针脚就能实现:同一个串口......
    51单片机有关晶振的问题总结;前言 学51单片机的时候,总是伴随很多有关于晶振的问题,其实晶振就是如同人的心脏,是血液的脉搏,把单片机的晶振问题搞明白了,51单片机的其他问题迎刃而解……有关51单片机有......
    有关51单片机有关晶振的问题总结(干货);在初学51单片机的时候,总是伴随很多有关于晶振的问题,其实晶振就是如同人的心脏,是血液的脉搏,把单片机的晶振问题搞明白了,51单片机......
    扰场合,成为继51单片机后一个全新系列单片机。 特性 1、下载烧录程序用串口方便好用,容易上手,拥有大量的学习资料及视频,最著名的要属于昌晖仪表网的那个视频了,好多对单片机有......
    5个中断源(2个外中断、2个定时/计数器中断和1个串行中断)。 (8)时钟电路:8051单片机有时钟电路,只需外接晶振和震荡电容,用于产生时序脉冲供整个单片机运行。 5、MCS-51系列单片机......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>