我用的是Nor Flash,用RT自己写了一个程序做Bootloader,下载到FLASH的0x00000位置。
应用程序下载到FLASH的0x10000位置。应用程序用了RT的OTA软件包,获取到升级程序包存放到Fal的download分区。
上电的时候bootloader从download取出升级包,刷入到FLASH的0x10000位置,然后再从FLASH的0x10000位置读程序文件到内存,关中断,再把读取到内存中的APP复制到内从0x000位置,然后跳转到
go_app = (iapfun)*(__IO uint32_t *)(0+32);这个位置
go_app();执行应用程序。
其中需要注意的是从FLASH的0x10000位置读程序文件到内存,这个内存需要避开从0x000位置到给应用程序留出的空间;再把读取到内存中的APP复制到内从0x000位置,实现这个功能的代码也需要避开从0x000位置到给应用程序留出的空间;升级包需要自己封装一下,我是做了加密、压缩、添加了个文件头用于指出升级包版保证只更新一次。
可能方法比较笨,但是可以用。
我用的是Nor Flash,用RT自己写了一个程序做Bootloader,下载到FLASH的0x00000位置。
应用程序下载到FLASH的0x10000位置。应用程序用了RT的OTA软件包,获取到升级程序包存放到Fal的download分区。
上电的时候bootloader从download取出升级包,刷入到FLASH的0x10000位置,然后再从FLASH的0x10000位置读程序文件到内存,关中断,再把读取到内存中的APP复制到内从0x000位置,然后跳转到
go_app = (iapfun)*(__IO uint32_t *)(0+32);这个位置
go_app();执行应用程序。
其中需要注意的是从FLASH的0x10000位置读程序文件到内存,这个内存需要避开从0x000位置到给应用程序留出的空间;再把读取到内存中的APP复制到内从0x000位置,实现这个功能的代码也需要避开从0x000位置到给应用程序留出的空间;升级包需要自己封装一下,我是做了加密、压缩、添加了个文件头用于指出升级包版保证只更新一次。
可能方法比较笨,但是可以用。
1
举报