/winapp-dfuse

stm32的USB-DFU上位机工具源码(MFC),基于ST官方DfuSe-v3.0.4 ,实现了hex转dfu,解决官方代码的一些bug

Primary LanguageC

DfuSe-v3.0.5说明文档

为什么做这个?

上段时间做了个STM32串口IAP的开源项目,在实际项目中如果采用uart或者485等进行数据通信那么采用串口IAP进行固件升级将会是个很好的选择,但是有的时候我们的产品或者项目不是用的串口而是用的USB和上位机进行通信,那么这时候就没必要用USB转串口工具进行协议转换了,这样不仅存在风险而且增加成本。所以很多时候会采用USB的HID、CDC等子类进行数据通信,在这种情况下进行固件升级就会优选DFU方式了。什么是dfu? 准确的说它也是IAP的子集,只不过我们常认为的IAP是通过串口,而dfu是通过USB而已。

通过dfu进行升级需要使用.dfu文件,ST官方提供了将.hex文件或者.bin文件转成.dfu文件的工具,最新的版本是DfuSe—v3.0.4(可以从官方下载),我下载安装之后发现并不能将.hex转.dfu 总是提示我文件错误。还有一个问题就是.bin生成.dfu之后保存的位置总是不对。这真的不能忍呀,于是就直接看官方的MFC源码开始跳进了解BUG的坑。。。

我做了些什么?

基于ST官方所提供的DfuSe_v3.0.4版本。

特色:

  • 1.解决ST官方版本无法将.hex格式文件直接转换成.dfu格式文件的痛点。

  • 2.解决ST官方版本保存生成的目标文件之后文件找不到的BUG。

官方v3.0.4使用的是低版本vs,我这里使用的vs2017最新版,如果你要对源码进行修改请安装相关环境。

目录结构

  • "Bin": 这里是生成好的最终可以直接使用的目标文件,如果你对源码不感兴趣可以丢弃源码只使用这里的可执行文件就够了。包括:

    • "DfuFileMgr.exe": 对,这个就是能把hex文件直接转换成dfu的神器了。

    • "DfuSeDemo.exe": 这个可执行文件就是对下位机进行固件升级的上位机工具了。

    • "DfuSeCommand.exe": 这个是脚本啦,就是给你提供命令行的方式去dfu升级固件,其实在真正的项目中不会使用DfuSeDemo.exe工具进行固件升级的,你想呀,你要是把DfuSeDemo.exe丢给客户,哪个客户能忍受得了?都是直接把这个脚本嵌入到你的客户端应用中去神不知鬼不觉的升级。

    • "STDFUTester.exe": 这个跟你没有半毛钱的关系,不要去操心。

    • ".dll": 这个就是上面4个exe文件运行所需要的动态链接库,不能少了。

    • "Doc": 这是ST官方提供的说明文档,反正我是懒得看,也看不懂。

    • "Driver": 这个东西很重要,有的电脑自带DFU驱动,但有很多就不行,所有这里提供了DFU的驱动。根据的你电脑选择对应的驱动安装就好了。如果你是win10,并且没有自带驱动,那么你就试试win8的驱动吧。

    • "version.txt": 你懂得

  • "Sources": 看名字就知道这是源码了。可以提前告诉你这是基于C++的MFC程序,如果你没玩过MFC那就尽量远离吧,避免溅你一身血。。。

  • "keilkill.bat": 这是dos的脚本程序,因为编译代码后会生成很多链接库或者中间文件之类的东西,很占用存储空间。所以就写了个脚本,当你编译完成之后退出vs然后双击执行这个脚本就会把那些垃圾清除了。

  • ".dfu和.hex": 没啥用,就是给你做测试用的。

代码工程打开的正确方式

用VS打开Sources文件夹下的DfuSe.sln,这个就不用我教你了吧。 (前4个要按照顺序)

  1. 重新生成STTubeDevice30
  2. 重新生成STDFU
  3. 重新生成STDFUFiles
  4. 重新生成STFUPRT
  5. 之后就可以将DfuFileMgr、DfuSeDemo、DfuSeCommand中的任意一个设置为启动项进行启动了。
  6. 根据你的期望去实现你的小目标吧。

接下来有什么打算

  1. 将DfuFileMgr.exe做成脚本的形式,这样当Keil编译完成生成hex文件之后自动的去调用脚本生成dfu文件。就不用再用鼠标在那点呀点呀的了。

  2. 这一项还没想到。。。。。。。

初次提交 2017/06/17

更新日期 2017/06/20

首次在DfuSeCommand中实现hex转dfu,不过还存在bug,有时候会转换失败。

更新日期 2017/06/23

解决将hex文件转换成dfu文件时有时候失败的bug,完成-t命令进行文件转换。

更新日期 2017/06/24

完善命令行,使-t(hex转dfu命令)命令与原有命令兼容。

实现使用一条命令>

	.\DfuSeCommand.exe -t test.hex test.dfu -c --de 0 -d --fn test.dfu 即可实现转换与下载。

上述命令可简写为>

	.\DfuSeCommand.exe -t test.hex -c --de 0 -d --fn test.dfu 

上述命令可分写为>

	.\DfuSeCommand.exe -t test.hex demo.dfu    将test.hex转成demo.dfu文件
	.\DfuSeCommand.exe -c --de 0               连接dfu设备
	.\DfuSeCommand.exe -d --fn demo.dfu        下载之前生成的demo.dfu文件

更新日期 2017/07/06

我把.hex文件转.dfu文件的可执行程序及命令行工具放在了另一个仓储,名字"hex2dfu"这样就方便用户直接下载使用了。 hex2dfu工具

更新日期 2017/07/10

增加了DfuSeCommand.exe脚本中的*选择器的功能,用户可以用命令:

.\DfuSeCommand.exe -t *.hex demo.dfu 进行格式转换,或者用下面简写方式
.\DfuSeCommand.exe -t *.hex  

更新日期 2017/07/17

解决因引入*选择器而导致的文件路径bug。