STM32 IAP应用开发——通过内置DFU实现USB升级(方式2)



By
jonson
12 4 月 24
0
comment

什么是IAP?

IAP(In-Application Programming) 指MCU可以在系统中获取新代码并对自己重新编程,即可用程序来改变程序。在应用编程(IAP)是用户的应用代码对片内Flash存储器进行擦除/编程的方法。这种方式的典型应用就是用一小段代码来实现程序的下载,实际上单片机的ISP功能就是通过IAP技术来实现的,即片子在出厂前就已经有一段小的boot程序在里面,片子上电后,开始运行这段程序,当检测到上位机有下载要求时,便和上位机通信,然后下载数据到数据存储区,从而实现固件升级。

什么是BootLoader?

百度百科:在嵌入式操作系统中,BootLoader是在操作系统内核运行之前运行。可以初始化硬件设备、建立内存空间映射图,从而将系统的软硬件环境带到一个合适状态,以便为最终调用操作系统内核准备好正确的环境。在嵌入式系统中,通常并没有像BIOS那样的固件程序(注,有的嵌入式CPU也会内嵌一段短小的启动程序),因此整个系统的加载启动任务就完全由BootLoader来完成。

实际上,BootLoader不仅仅在操作系统上使用,在一些内存小,功能应用较为简单的单片机设备上面也可以通过BootLoader来完成固件升级。

什么是DFU?

DFU全称为Download Firmware Update,是ST官方推出的一个通过USB接口进行IAP升级的方案,同串口ISP一样,他们都集成在了芯片内部的Bootloader区段,可以通过配置boot引脚来启动。

不过STM32内置DFU的型号都比较新,像STM32F4系列是有的,但是像F0和F1系列则没有,不过没有关系,如果你用的型号没有内置DFU程序,也可以通过CubeMX来快速生成和移植一个DFU功能程序到你的Flash中来使用。

使用DFU的优缺点?

使用DFU的好处是不用自己制作Bootloader,因为这部分代码在STM32出厂之前就已经做好并且烧录进去了,而且不占用用户代码的Flash,另外,在PC端我们也不需要专门定制一个上位机,因为官方就有专门的升级Tool以及USB驱动。

缺点是要改变boot引脚的电平,才能启动Bootloader,这样的话在应用场景上就有比较大的限制了。

所以,要根据项目的实际需求去选择合适的方案。

我之前也有发过一些关于STM32远程升级的文章,实现的方式有很多种,感兴趣的同学可以去看一下。

STM32 IAP应用开发——通过内置DFU实现USB升级(方式1)

固件升级系列合集:https://blog.csdn.net/ShenZhen_zixian/article/details/129074047

1 硬件介绍

我这里测试用的是STM32F407。

用到的硬件接口如下:

接口 引脚 作用
USB PA11 PA12 (必要)通过USB连接PC端,用来传输固件以实现升级
BOOT BOOT0 BOOT1 (必要)通过改变boot电平来切换运行模式
串口 PA9 (非必要)通过CH340连接到PC端,打印固件版本号,方便查看升级是否成功
LED PF9 (非必要)方便查看代码是否跑起来了

BOOT引脚配置对应如下图:

请添加图片描述

1)主Flash

主Flash起始地址为0x08000000,它指的是STM32内置Flash,通常我们烧录的代码就是存放在这个位置。

2)系统存储器

系统存储器起始地址为0x1FFF0000,这种模式启动的程序功能是由芯片厂家设置的,STM32在出厂时会这个区域内置一段BootLoader, 也就是我们常说的ISP程序, 这是一块ROM,出厂后无法修改。我们要使用的DFU就是放在这里。

3)嵌入式SRAM

嵌入式SRAM起始地址为0x20000000,既然是SRAM,自然也就没有程序存储的能力了,这个模式一般用于程序调试。假如我只修改了代码中一个小小的 地方,然后就需要重新擦除整个Flash,比较的费时,可以考虑从这个模式启动代码(也就是STM32的内存中),用于快速的程序调试,等程序调试完成后,在将程序下载到SRAM中。

2 环境搭建

2.1 Keil uVsion

关于STM32以及Keil的环境这里就不具体介绍了,网上教程也很多,不懂的同学自行查阅资料。

环境搭建好之后需要准备一个能够正常运行的代码,用来测试我们后面的固件升级。

2.2 DfuSeDemo

1、下载DfuSeDemo

DfuSeDemo是用来升级固件的,可以在ST的官网下载。

下载地址:https://www.st.com/en/development-tools/stsw-stm32080.html

注:本文测试的时候,用的是v3.0.6版本。

请添加图片描述

2、安装DfuSeDemo

下载完成后直接安装即可。

提示:记住安装的路径,后面要用。

默认安装路径:C:Program Files (x86)STMicroelectronicsSoftwareDfuSe v3.0.6Bin

安装好之后打开安装路径的文件夹,会看到以下几个文件。

请添加图片描述

3、安装驱动

根据自己的操作系统选择对应的驱动。(Win11的自行查阅资料安装)

请添加图片描述

64系统安装dpinst_amd64.exe,32位系统安装dpinst_x86.exe

请添加图片描述

2.3 检查USB驱动

1、让STM32进入系统存储器启动模式

也就是配置BOOT0引脚拉高,BOOT1引脚拉低。

提示:BOOT引脚的状态要在MCU启动之前配置好才能进入对应的模式,可以先配置BOOT引脚再上电,也可以在配置好BOOT引脚之后复位MCU。

请添加图片描述

2、把STM32的USB连接到PC端

如果前面的驱动安装没有问题,连接上电脑之后可以在设备管理器看到一个STM Device in DFU Mode设备。

请添加图片描述

3、打开DfuSeDemo

如果驱动和接线都没问题,那么在DfuSeDemo可以看到已连接的STM32设备以及DFU的一些信息(VID、PID以及软件版本)。

提示:如果没有找到设备,请检查前面的步骤。

请添加图片描述

至此,环境就搭建完成了。

3 固件升级

3.1 打包新版本固件

因为DfuSeDemo只能下载dfu文件,所以在进行在线升级之前我们要先将编译好的hex文件或者bin文件转换成dfu文件。用的工具是DfuFileMgr.exe,前面其实也有提到,在DfuSeDemo的安装目录里面就有,不需要再额外安装了。

hex跟bin最终的效果基本是一样的,根据自己的需求选其中一种方式即可。

1、打包hex文件

步骤如下:

1)输入设备信息

提示:设备信息在DfuSeDemo中可以看到。

请添加图片描述

2)打开hex文件

请添加图片描述

3)生成dfu文件

请添加图片描述

4)保存dfu文件

请添加图片描述

5)成功生成dfu文件

请添加图片描述

2、打包bin文件

步骤如下:

1)输入设备信息

提示:设备信息在DfuSeDemo中可以看到。

请添加图片描述

2)选择bin文件并输入Flash起始地址

请添加图片描述

请添加图片描述

3)生成dfu文件

请添加图片描述

4)保存dfu文件

请添加图片描述

5)成功生成dfu文件

请添加图片描述

3.2 升级固件

1、打开DfuSeDemo

请添加图片描述

2、导入打包好的dfu文件

请添加图片描述

请添加图片描述

3、升级固件

请添加图片描述

4、重启设备

升级完成后可以在DfuSeDemo上面点击Leave DFU mode退出DFU模式。

也可以配置好新的BOOT模式之后重启或重新上电。

提示:BOOT模式要改成主Flash模式(BOOT0引脚拉低)才能正常运行新版本的代码。

请添加图片描述

至此,整个升级流程就走完了。

结束语

好了,关于如何通过STM32内置DFU实现USB升级就讲到这里,这种方式虽然限制较多,但在某些应用场景是很方便的,比如SB键盘,不需要自己编写Bootloader和上位机就可以实现升级,而且官方的升级渠道还稳定。其他应用场景就再另说,合适的才是最好的。

如果你有什么问题或者有更好的方法,欢迎在评论区留言。

发表回复