开发背景


最近开发的一款产品上位机与下位机之间使用LAN通讯(下位机STM32通过SPI控制网络模块W5500联网)因此固件升级也考虑通过LAN通讯的方式传输文件。本文重点阐述文件传输方案,固件升级过程一笔带过。


一、文件传输方案选择



1、HTTP协议

1、上位机作为客户端使用浏览器,下位机作为服务器。采用这种方式,在下位机httpserver功能完善的情况下在浏览器上可以查看配置信息,如版本号,网络参数。但是下位机httpserver开发复杂,暂用较大FLAH存储空间。
2、上位机充当服务器,下位机作为客户端模拟浏览器。采用这种方式,下位机只能请求固定名字的升级文件,而且上位机无法查看配置下位机参数。

2、TFTP协议

下位机固件一般小于1M,因此无需使用复杂庞大的FTP协议。同样也有两种细分方案可供选择。
1、上位机作为客户端,下位机作为服务器。客户端输入TFTP服务器地址、端口号及升级文件后,上传给下位机使用。这种方式服务器地址必须固定,升级文件名没有限制。
2、上位机作为服务器,下位机作为客户端。下位机指定服务器地址、端口号及升级文件名后请求下载,下载完成后使用。这种方式服务器地址及升级文件名必须固定。

3、HTTP协议与TFTP协议配合使用

下位机作为HTTP服务器,上位机可以查看配置参数,同时下位机也作为TFTP客户端,可以请求下载升级文件。这样可以通过http指定升级文件名。这种方式下位机开发难度最大,放弃这种方案。
综合分析后,决定采用TFTP协议,上位机作为客户端,下位机作为服务器。

二、步骤

1.新建STM32工程,调试好SPI及IO口输出

比较简单,不再讲解。

2.开发W5500的TFTP功能

1、github上下载W5500官方驱动库,地址:(https://github.com/Wiznet/ioLibrary_Driver)

stm32 cubemx配置FATFS挂载多个磁盘_tftp

2、由于TFTP传输层使用的是UDP,先调试好UDP收发功能。

3、开发调试TFTP功能。官方库只支持TFTP客户端,需要自己学习TFTP协议,再添加服务器代码。

stm32 cubemx配置FATFS挂载多个磁盘_服务器_02

4、上位机TFTP工具选择tftpd32,请自行百度下载。

stm32 cubemx配置FATFS挂载多个磁盘_下位机_03

5、TFTP文件传输开发调试,使用wireshark查看分析网络包。

stm32 cubemx配置FATFS挂载多个磁盘_下位机_04

3.下位机使用接收到的文件进行升级。