STM32+IAP方案 实现网络升级应用固件

关注了这个概念有些日子了,这段时间总算有机会实战==网络升级应用固件,这里记录下遇到的问题,及解决方案。
原理与网上流传的串口作为传输手段 一致;不同之处,无非我这里使用了网络设备传输。==(lwip)TFTP客户端的应用.
参考:
IAR环境下STM32+IAP方案的实现
STM32浅谈之IAP.pdf
基于IAP和Keil MDK的远程升级设计
keil MDK中如何生成*.bin格式的文件


概况:

  • 什么是IAP,为什么要IAP
  • 可实现的原理
  • 实现过程
  • 细节及实现
    以上基本都可以从【IAR环境下STM32+IAP方案的实现】中找到答案。这里只是贴图,醒目:
    IAP框架布局:
    这里写图片描述
    STM32F103ZET6的启动方式有三种:内置FLASH启动、内置SRAM启动、系统存储器ROM启动,通过BOOT0和BOOT1引脚的设置可以选择从哪中方式启动,这里选择内置的FLASH启动。其FLASH的地址为0x08000000—0x0807ffff,共512KB,这些都能从芯片数据手册中直接得到。而这里首要的一个问题是中断的问题。正常情况下发生中断的过程为:发生中断(中断请求),到中断向量表查找中断函数入口地址,跳转到中断函数,执行中断函数,中断返回。也就是说在STM32的内置的Flash中有一个中断向量表来存放各个中断服务函数的入口地址,内置Flash的分配情况大致如下图2-1。
    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述
    在内置的Flash里面添加一个BootLoader程序,BootLoader程序和user application各有一个中断向量表,假设BootLoader程序占用的空间为N+M字节,则程序的走向应该如图2-2所示(借用网友的原图并做改动,其中虚线部分为原图步骤④⑤的走向,本人改为指向灰色部分)。
    这里写图片描述
    上电初始程序依然从0x08000004处取出复位中断向量地址,执行复位中断函数后跳转到IAP的main(标号①所示),在IAP的main函数执行完成后强制跳转到0x08000004+N+M处(标号②所示),最后跳转到新的main函数中来(标号③所示),当发生中断请求后,程序跳转到新的中断向量表中取出新的中断函数入口地址,再跳转到新的中断服务函数中执行(标号④⑤所示),执行完中断函数后再返回到main函数中来(标号⑥所示)。
    对于步骤④⑤,网友认为是:“在main执行的过程中,如果CPU得到一个中断请求,PC指针仍强制跳转到地址0x08000004中断向量表处,而不是新的中断向量表,如图标号④所示,程序再根据我们设置的中断向量表偏移量,跳转到对应中断源新的中断服务程序中,如图标号⑤所示”。我对此的理解是:“当发生中断后,程序从0x08000004(旧)处的中断向量表中得到相应的中断服务函数入口地址,继而跳转到相应的中断服务程序”。但是旧的中断向量列表里边存放的是IAP程序中断函数的入口地址,它是如何得到user程序中断函数的入口地址呢?所以我觉得此种说法是错误的。“当发生中断时PC指针强制会跳转到0x08000004处”这种说法并没有错,只是忽略了后续的一些知识要点而导致这个说法出现矛盾。
    对于步骤④⑤我认为的是,在main函数的执行过程中,如果CPU得到一个中断请求,PC指针本来应该跳转到0x08000004处的中断向量表,由于我们设置了中断向量表偏移量为N+M,因此PC指针被强制跳转到0x08000004+N+M处的中断向量表中得到相应的中断函数地址(待求证),再跳转到相应新的中断服务函数,执行结束后返回到main函数中来。

IAP流程描述:

1、IAP的bootloader引导程序

IAP在应用中编程,可以拓展成远程网络更新应用固件。
片内的flash,至少划分成2个分区,对应至少两个完整的程序;
低地址分区端推荐放入IAP程序==bootloader引导程序(这里边的手段可以是串口、网络等不同的方式),高地址分区端推荐烧写app固件。
关键点提及:
IAP程序中,当满足跳转条件(被触发)时,执行跳转代码到app应用固件程序,跳转代码流程:
至少需要设定跳转目的地的app应用固件 栈顶指针,:

/* Initialize user application's Stack Pointer */
__set_MSP(*(__IO uint32_t*) USER_FLASH_FIRST_PAGE_ADDRESS);

其中,app应用固件的分区地址:

#define USER_FLASH_FIRST_PAGE_ADDRESS 0x08009000

2、app应用固件

需要两处的更改,不然错误未知
IROM设置如图:
这里写图片描述
中断向量表偏移:
这里写图片描述

NVIC_SetVectorTable(NVIC_VectTab_FLASH,VectorTable_Offset);

其中:

#define NVIC_VectTab_FLASH           ((uint32_t)0x08000000)
#define VectorTable_Offset  0x9000 

查错:

如果做了上边的工作,IAP依然无法顺利执行跳转至app应用程序,可以查看.map和.bin文件,确定是否如实的改变的中断向量表的偏移和栈顶指针,如图:
这里写图片描述
.bin文件:
这里写图片描述
可以看到,主栈顶MSP地址=0x2000C8C8、reset_handler地址=0x08009189
如此,才能生效,否则,可能原因:
修改后的向量表偏移,在之后的程序中,又再次被还原,通过如下的函数:

void NVIC_SetVectorTable(uint32_t NVIC_VectTab, uint32_t Offset);
void SystemInit (void);
SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET;

附:

1、如需要.hex文件转.bin,参见上边的文章
当然,就算使用.hex文件,同样可以升级,只是需要修改IAP中判定已经升级的文件是否有效,文件条件部分的代码,

if(((*(__IO uint32_t*)USER_FLASH_FIRST_PAGE_ADDRESS) & 0x2FFE0000 ) == 0x20000000)

2、地址偏移后的app应用程序,是否能够独立的运行?
不能,理由:
这里写图片描述
可知,开机上电并不能够找到我们指定的偏移后的向量表。

  • 21
    点赞
  • 156
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: STM32 W5500 IAP是指使用STM32微控制器和W5500以太网控制器进行在线固件升级IAP)。 在线固件升级是一种通过网络远程升级设备固件的方式,相比传统的局限于物理访问的固件升级方式更加灵活和方便。STM32微控制器作为设备的主控制器,可以通过W5500以太网控制器实现网络的通信。 W5500是一款基于硬件TCP/IP协议栈的以太网控制器,具有高性能和低功耗的特点。它支持10/100M以太网速率,可以实现与外部网络的快速连接。通过W5500与网络连接,我们可以利用其强大的网络通信能力实现远程的固件升级。 在STM32 W5500 IAP中,我们可以使用W5500与网络进行通信,接收远程服务器发送的固件更新包。同时,STM32微控制器可以通过串口等方式与W5500进行通信,从而实现接收并存储固件更新包,完成设备的固件升级。 通过STM32 W5500 IAP,我们可以实现设备的远程固件升级,避免了传统方式中需要物理连接设备才能进行升级的限制。这种方式不仅提高了固件升级的灵活性和便利性,同时也节省了维护和升级的成本。 ### 回答2: STM32是意法半导体公司推出的一系列32位单片机系列,而W5500是一款由韩国WIZnet公司推出的高性能以太网控制器。而IAP是指在单片机中的应用程序内部进行固件升级的技术,即在不需改变硬件的情况下更新固件。 在使用STM32和W5500进行IAP过程中,可以通过以下步骤完成固件升级: 1. 准备升级文件:首先应准备好新的固件文件,这些文件通常是.bin或.hex格式的,在更新之前应进行合适的版本控制。 2. 初始化W5500:在正式进行固件升级之前,需要对W5500进行初始化配置,包括设置IP地址、端口号等参数,确保网络连接的正常运行。 3. 设置引导模式:在单片机的引导模式中,可以通过特定的引脚或者配置寄存器的方式告知单片机以IAP方式启动。 4. 连接服务器:使用W5500建立与服务器的TCP/IP连接,在升级过程中通过网络传输固件文件。 5. 接收固件:单片机在连接到服务器后,通过W5500接收服务器发送的固件文件,确保稳定的网络连接以及适当的接收缓冲区的设置。 6. 写入固件:在接收到固件文件之后,单片机将固件数据写入到内部的闪存中,逐步替换旧的固件。 7. 完成升级固件写入完毕后,重新启动单片机,以新的固件程序运行。 总之,STM32和W5500可以结合使用进行IAP,通过网络传输固件文件,并在单片机内部进行固件升级。这种方法可以实现在不改变硬件的情况下,对设备的功能进行更新和改进。 ### 回答3: STM32 W5500 IAP是指使用STM32微控制器和W5500以太网模块进行固件升级的功能。 STM32是意法半导体公司开发的一系列32位ARM Cortex-M微控制器,具有强大的性能和丰富的外设资源,常用于嵌入式系统开发。 W5500是WIZnet公司开发的一款高度集成的以太网控制器,支持TCP/IP协议栈,能够通过以太网连接到局域网或互联网。 IAP(In-Application Programming)是一种在应用程序中进行固件升级的技术。通过IAP,用户可以在系统运行时通过网络或其他方式下载新的固件,并将其写入到MCU的内部闪存中。 在STM32 W5500 IAP中,W5500可以提供网络连接能力,使得MCU可以通过以太网接口连接到服务器或其他设备,通过网络下载新固件。而STM32则负责控制IAP过程,包括下载固件、解析数据、写入闪存等操作。 使用STM32 W5500 IAP能够实现系统在线升级的功能,无需连接到开发环境即可完成固件更新。这对于远程设备或无法直接访问的设备非常有用。同时,固件升级可以修复bug、添加新功能,提升系统稳定性和扩展性。 总而言之,STM32 W5500 IAP通过结合STM32微控制器和W5500以太网模块,实现在运行时通过网络进行固件升级的功能。这样的解决方案具有灵活性和便捷性,可以为嵌入式系统提供更好的升级方式。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值