单片机学习小组
登录
直播中
尤立虔
8年用户
1008经验值
擅长:控制/MCU
私信
关注
怎样去实现IAP功能的逻辑与程序的编写呢
开启该帖子的消息推送
嵌入式
单片机
IAP
IAP功能实现的原理是什么?
怎样去实现IAP功能的逻辑与程序的编写呢?
回帖
(1)
崔丹
2022-1-18 10:03:10
我们在开发与生产过程中烧录程序主要是用J-link、ST-link等设备通过串口进行烧录。一款设备在出厂后由于各种原因不方便被用户拆壳,但程序有时需要升级该怎么?这个时候就需要用到我们今天讨论的话题——IAP在线升级功能了。
一. 首先是IAP功能实现的原理,简单来说IAP其实就是对FLash的操作,我们只要懂得对FLash的读、写、跳转与重映射中断向量表就可以满足编写IAP功能程序需要了。完整的IPA功能需要两部分代码:Bootloader+APP(为了方便书写下面的BootLoader我就全部用BOOT代替了)。其中APP程序就是我们用来实现设备各种功能的程序,而BOOT的作用就是在Flash中对APP程序的读、写与跳转功能了。
二. 接下来我们来讨论一下实现IAP功能的逻辑与程序的编写。
1.首先我们要确定BOOT与APP程序存储在Flash的什么位置,以STM32L4为例。首先我们要留出足够的空间存放BOOT的程序与各种标志,并且设备上电后要先进入BOOT中进行"跳转到APP/更新APP"的判断,所以一般BOOT要在中断向量表默认的起始地址0x08000000,APP地址为0x08001000(假设BOOT代码大小为3K,留出1K大小的FLash空间存储各种标志)。
2.检测更新标志。在BOOT主循环中需要检测是否有更新APP标志SET_FLAG_DATA,如果检测到标志就更新APP;如果没有检测到更新APP标志SET_FLAG_DATA,则直接进行第6步跳转APP程序。
3.擦除Flash。擦除APP程序在Flash中存储的位置(注意:只有擦除后才能写入,所以一般是擦除APP存储的位置到Flash结束的位置),并且配置页擦除中Flash页的大小FLASH_PAGE_SIZE,不同型号的开发板每页的发小不一样,本文中所用开发板Flash页的大小为128字节。
4.写Flash。需要把APP的程序写入到Flash中(本文写在地址0x08010000—0x08020000之间)如何获取APP程序本文就不加以赘述,下面看代码。
5.如果Flash写入成功就擦除更新APP标志SET_FLAG_DATA,如果写入失败就从第2步开始在做一遍。下面是擦除更新标志的程序:
6.接下来就可以跳转APP程序了,具体程序如下:
7.这一步开始操作需要在APP程序的工程中进行,首先是设备自身的功能这里就直接跳过。在这里我们首先要设置接到上位机命令后在FLASH_UPDE_ADDR(更新标志所在地址)位置写入更新APP标志SET_FLAG_DATA,并重启设备或是跳转到BOOT所在地址:0x08000000。
注意:
APP的中断向量表要重映射到APP程序所在的起始地址,本文为0x08010000
。
8.最后分别把BOOT程序和APP程序分别烧录到设备的0x08000000与0x08010000地址就完成了。
注:
另外有的朋友用标准库实现IAP功能,如果开发板是Cortex M0内核的话可能会发现不能像Cortex-m3/m4内核的单片机那样通过设置SCB->VTOR 寄存器的值来实现中断向量表的重映射。
我们在开发与生产过程中烧录程序主要是用J-link、ST-link等设备通过串口进行烧录。一款设备在出厂后由于各种原因不方便被用户拆壳,但程序有时需要升级该怎么?这个时候就需要用到我们今天讨论的话题——IAP在线升级功能了。
一. 首先是IAP功能实现的原理,简单来说IAP其实就是对FLash的操作,我们只要懂得对FLash的读、写、跳转与重映射中断向量表就可以满足编写IAP功能程序需要了。完整的IPA功能需要两部分代码:Bootloader+APP(为了方便书写下面的BootLoader我就全部用BOOT代替了)。其中APP程序就是我们用来实现设备各种功能的程序,而BOOT的作用就是在Flash中对APP程序的读、写与跳转功能了。
二. 接下来我们来讨论一下实现IAP功能的逻辑与程序的编写。
1.首先我们要确定BOOT与APP程序存储在Flash的什么位置,以STM32L4为例。首先我们要留出足够的空间存放BOOT的程序与各种标志,并且设备上电后要先进入BOOT中进行"跳转到APP/更新APP"的判断,所以一般BOOT要在中断向量表默认的起始地址0x08000000,APP地址为0x08001000(假设BOOT代码大小为3K,留出1K大小的FLash空间存储各种标志)。
2.检测更新标志。在BOOT主循环中需要检测是否有更新APP标志SET_FLAG_DATA,如果检测到标志就更新APP;如果没有检测到更新APP标志SET_FLAG_DATA,则直接进行第6步跳转APP程序。
3.擦除Flash。擦除APP程序在Flash中存储的位置(注意:只有擦除后才能写入,所以一般是擦除APP存储的位置到Flash结束的位置),并且配置页擦除中Flash页的大小FLASH_PAGE_SIZE,不同型号的开发板每页的发小不一样,本文中所用开发板Flash页的大小为128字节。
4.写Flash。需要把APP的程序写入到Flash中(本文写在地址0x08010000—0x08020000之间)如何获取APP程序本文就不加以赘述,下面看代码。
5.如果Flash写入成功就擦除更新APP标志SET_FLAG_DATA,如果写入失败就从第2步开始在做一遍。下面是擦除更新标志的程序:
6.接下来就可以跳转APP程序了,具体程序如下:
7.这一步开始操作需要在APP程序的工程中进行,首先是设备自身的功能这里就直接跳过。在这里我们首先要设置接到上位机命令后在FLASH_UPDE_ADDR(更新标志所在地址)位置写入更新APP标志SET_FLAG_DATA,并重启设备或是跳转到BOOT所在地址:0x08000000。
注意:
APP的中断向量表要重映射到APP程序所在的起始地址,本文为0x08010000
。
8.最后分别把BOOT程序和APP程序分别烧录到设备的0x08000000与0x08010000地址就完成了。
注:
另外有的朋友用标准库实现IAP功能,如果开发板是Cortex M0内核的话可能会发现不能像Cortex-m3/m4内核的单片机那样通过设置SCB->VTOR 寄存器的值来实现中断向量表的重映射。
举报
更多回帖
rotate(-90deg);
回复
相关问答
嵌入式
单片机
IAP
怎样
去
实现
STM32
IAP
升级的设计
呢
2022-01-27
1178
如何在stm32上去
实现
IAP
功能
呢
2021-09-26
1063
怎样
去
修改STM32
IAP
升级的
程序
呢
2021-11-02
1109
IAP
功能
实现
过程中遇到的坑
2021-10-25
1109
怎样
通过
编写程序
去
实现
数字时钟显示
功能
呢
2022-03-01
1320
如何
去
实现
有线
IAP
用户
程序
升级
呢
2021-12-17
784
STM8
IAP
升级流程是
怎样
的?如何
去
实现
呢
2022-01-27
1047
如何
去
实现
IAP
编程
呢
2021-10-29
1100
如何通过USB升级代码
去
实现
程序
的下载更新
功能
呢
2021-11-12
1412
STM32是
怎样
通过CubeMX配置
去
进行
IAP
的
呢
2021-10-27
2095
发帖
登录/注册
20万+
工程师都在用,
免费
PCB检查工具
无需安装、支持浏览器和手机在线查看、实时共享
查看
点击登录
登录更多精彩功能!
英国威廉希尔公司网站
william hill官网 版块
小组
免费开发板试用
ebook
直播
搜索
登录
×
20
完善资料,
赚取积分