埃斯提爱慕
发布时间:2024-7-21 10:48
|
跌跌撞撞,历经一个星期,终于实现了功能。 双BANK的好处是,不再像以前一样,需要一个bootloader程序来负责跳转,程序始终运行在0x08000000起始的位置。在用户程序中,只管接收新固件,并存放在另一个BANK中,也就是0x08040000起始的区域,接收完成后,切换SWAP_BANK,重新,即可。 https://shequ.stmicroelectronics.cn/thread-643647-1-1.html 还是在这个工程基础上修改。 首先找用户手册里相关的说明。
看了这些后,就认为只要按步骤,改变SWAP_BANK位就可以了。在STM32CubeProgrammer
勾选SWAP_BANK选项后,再读Flash。
通过这个验证,我再次觉得使用很简单,因为程序都是从0x08000000处复位运行。也就是当SWAP_BANK未勾选时,应用程序中,将新固件接收,并写到0x08040000开的的程序空间(BANK2区域),然后通过勾选SWAP_BANK,新程序就变到了0x08000000的位置,下次复位运行就是新程序了。这样就省掉了原来bootloader。 移植一个Ymodem,用于下载新的固件。(这个就不多细说了,官方例程里有)
同样,也读出来确认一下,两个区域都有程序
勾选SWAP_BANK,复位程序
试到这里,功能是实现了,但我们实际应用中可不能用下载软件来切换。还得在程序里实现切换SWAP_BANK。 修改程序 需要注意的是,擦除需要根据SWAP_BANK的状态来决定擦除BANK1还是BANK2。而写flash的地址,不需要管SWAP_BANK的状态,都是从0x08040000到0x0807ffff。
|
【LSM6DSV320X评测】MEMS上位机体验 以及MLS数据预采集
STM32H503多轴运动控制卡
经验分享 | STM32H563 SPI DMA应用演示
实战经验 | 读取STM32H5 Data Flash触发NMI的问题解析
实战经验 | STM32H5的PB14引脚被意外拉低的问题解析
《STM32系列产品选型手册》全面更新
【NUCLEO-WBA65RI评测】Android端蓝牙OTA升级
【NUCLEO-WBA65RI评测】USB HID设备测试
经验分享 | 读取 STM32H5 Data Flash 触发 NMI 的问题解析
【NUCLEO-WBA65RI评测】功耗测试
微信公众号
手机版
感谢