IAP设计能不能做两个APP,相互之间切换升级

2019-07-14 15:15发布

按照传统IAP的设计方法,一个boot,一个APP,在升级的时候如果断电了整个产品的程序部分就挂了,在内部flash足够的情况下,我能不能做两个APP,相互之间切换升级。比喻说,这次运行APP1,升级就是写APP2,升级完运行APP2,再升级就是写APP1,升级完运行APP1。这样掉电了原来的程序还在,当然防掉电的方法好像还可以先存EEPROM,但是我说的这种方法可不可靠呢?
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
9条回答
hy381
1楼-- · 2019-07-15 01:02
 精彩回答 2  元偷偷看……
60user179
2楼-- · 2019-07-15 06:46
hy381 发表于 2018-12-13 15:35
1.在升級時,boot不會掛掉,可重新再升級APP
2.flash足夠,且可重映多個中斷向量下,理論上,可做到boot+APP1+APP2,由boot決定要進入APP1或APP2,由boot決定要升級哪個

这里的boot能不能不要,就是app里面包含了boot部分,app里面既有主程序,又有升级跳转程序(在特定情况下执行,如串口收到特殊帧)。两个app都是这样,相互升级,相互跳转
ji5687
3楼-- · 2019-07-15 09:17
60user179 发表于 2018-12-13 15:52
这里的boot能不能不要,就是app里面包含了boot部分,app里面既有主程序,又有升级跳转程序(在特定情况下执行,如串口收到特殊帧)。两个app都是这样,相互升级,相互跳转

如果没有 boot,上电后,MCU一般从 0 地址开始取指运行。
怎么来确保处于低段地址的那个 APP 不会出错呢?
必须保证有一段代码是安全的、可运行的,不会在升级的过程中被破坏的。
那这段代码,不就是 boot 了吗?
60user179
4楼-- · 2019-07-15 10:21
hy381 发表于 2018-12-13 15:22
試想,開机要如何選擇APP1或APP2,沒有確定不被破壞的區,那程式就有机會跑飛掉
若一定要在APP1和APP2更新,也可,但還是要有開机區,確定跑到好的APP區
即START+APP1+APP2,但APP還要多更新的程式,只會加大程式的flash

本帖最后由 NapoleonWang 于 2017-11-16 16:17 编辑

大概理解,现在另外一个问题,如果两个app,我要keil生成bin文件的时候,要怎么设置rom的起始地址呢?毕竟对用户来说不知道现在是要升级app1还是app2@atm8686@chuan199
hy381
5楼-- · 2019-07-15 13:26
小弟我沒用過二個APP
我的認知,用戶更新的軟件就要給他選擇更新哪個區域
rom的起始位置,就看你要分配多大給他,較要注意的應該是中斷向量的設定
不知什麼情況要用到兩個APP,正常情況是一個boot+一個APP,因為boot一定會是活著的,也不需要再更新boot區
cmstock
6楼-- · 2019-07-15 17:30
 精彩回答 2  元偷偷看……

一周热门 更多>