OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5055|回复: 12

关于IAP的一点疑问,双区原理,希望大家来探讨一下

[复制链接]

19

主题

58

帖子

0

精华

初级会员

Rank: 2

积分
65
金钱
65
注册时间
2015-8-23
在线时间
20 小时
发表于 2016-9-19 11:41:27 | 显示全部楼层 |阅读模式
100金钱
首先先看下这个模型,见下图,我把整个stm32单片机的flash分成了3份。第一个,是放bootloader。接下来的flash分成了两个部分。第二个部分用来存储bootloader里所接受到的bin数据。把数据写入这个区域。然后在Flash1上运行。我的疑问是flash1上运行的话,是不是要把flash2上的数据拷到flash1上才能运行啊?还是说根本不需要。我对这个原理上表示怀疑。

模型

模型

最佳答案

查看完整内容[请看2#楼]

真正做产品必须IAP FLASH1 FLASH2,:FLASH1可以存储你刚出厂的程序,如果没有固件更新就一直运行这个片区的程序。FLASH2可以存储你升级过来的程序,然后程序可以选择在这个片区运行,也可以把FLASH2复制到FLASH1,还是运行FLASH1,当然最好还是保持FLASH1不动,这样一旦设备刷机成砖头,还可以接个按键啥的运行会出厂程序。。我是这么做的;当然,思路是思路,做是另外一回事,,固件更新程序必须做CRC校验,甚至GUID判断,及错误重 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

21

主题

387

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1043
金钱
1043
注册时间
2016-9-8
在线时间
213 小时
发表于 2016-9-19 11:41:28 | 显示全部楼层
本帖最后由 密耳 于 2016-9-19 17:09 编辑

真正做产品必须IAP FLASH1 FLASH2,:FLASH1可以存储你刚出厂的程序,如果没有固件更新就一直运行这个片区的程序。FLASH2可以存储你升级过来的程序,然后程序可以选择在这个片区运行,也可以把FLASH2复制到FLASH1,还是运行FLASH1,当然最好还是保持FLASH1不动,这样一旦设备刷机成砖头,还可以接个按键啥的运行会出厂程序。。我是这么做的;当然,思路是思路,做是另外一回事,,固件更新程序必须做CRC校验,甚至GUID判断,及错误重发机制。发送端的数据必须做分割处理。一个固件包(我们目前的固件bin是30多K,level o3)多包次发送(加上头尾CRC GUID等),接收端STM32再把数据还原,写FLASH.
shop60994719.taobao.com
回复

使用道具 举报

9

主题

108

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1136
金钱
1136
注册时间
2013-7-16
在线时间
80 小时
发表于 2016-9-19 11:49:48 | 显示全部楼层
只需分两个区就可以了,一个Bootloader 区和 一个应用程序区,Bootloader 负责接收上位机传送的bin文件并写入到应用程序区, 写完后跳转到应用程序区执行应用程序。
回复

使用道具 举报

19

主题

58

帖子

0

精华

初级会员

Rank: 2

积分
65
金钱
65
注册时间
2015-8-23
在线时间
20 小时
 楼主| 发表于 2016-9-19 12:04:30 | 显示全部楼层
cookles 发表于 2016-9-19 11:49
只需分两个区就可以了,一个Bootloader 区和 一个应用程序区,Bootloader 负责接收上位机传送的bin文件并写 ...

现在是要分2个区,我们主管让这么做的,但是有点怀疑其原理。
回复

使用道具 举报

355

主题

1476

帖子

12

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
8105
金钱
8105
注册时间
2015-10-15
在线时间
2922 小时
发表于 2016-9-19 12:24:33 | 显示全部楼层
你本身就只有一个应用,
你写入flash2,就可以直接在flash2执行了。。。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

11

主题

1044

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3722
金钱
3722
注册时间
2011-5-23
在线时间
2013 小时
发表于 2016-9-19 12:32:12 | 显示全部楼层
拷贝比较简单,不拷贝的话,两边地址不一样,需要编译成地址无关的代码,麻烦事多多。

分3个区是最合理的。
另外,如果有需要,还建议在前面留几个小块的扇区保存参数用。
如果内部FLASH不够用,SWAP区可以使用外部的SPI FLASH。内部的毕竟太小太贵。

固件制作可以参考一下这个: 请问一下 固件升级中的校验问题 http://www.openedv.com/thread-84143-1-1.html

RT-Thread RTOS 音频,WIFI,蓝牙
回复

使用道具 举报

19

主题

58

帖子

0

精华

初级会员

Rank: 2

积分
65
金钱
65
注册时间
2015-8-23
在线时间
20 小时
 楼主| 发表于 2016-9-19 13:17:34 | 显示全部楼层
aozima 发表于 2016-9-19 12:32
拷贝比较简单,不拷贝的话,两边地址不一样,需要编译成地址无关的代码,麻烦事多多。

分3个区是最合理 ...

你好,你的意思是,把FLASH2里的数据拷贝到FLASH1里去运行啊。但是这样的好处活着意义是什么呢?
回复

使用道具 举报

72

主题

2711

帖子

2

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
3505
金钱
3505
注册时间
2014-8-4
在线时间
696 小时
发表于 2016-9-19 13:22:41 | 显示全部楼层
flash1和flash2彼此独立,可以根据boot选择运行
回复

使用道具 举报

70

主题

6763

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
13138
金钱
13138
注册时间
2012-11-26
在线时间
3814 小时
发表于 2016-9-19 13:35:10 | 显示全部楼层
你FLASH2存储的是什么?
回复

使用道具 举报

19

主题

430

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1341
金钱
1341
注册时间
2016-4-22
在线时间
187 小时
发表于 2016-9-19 13:42:11 | 显示全部楼层
只有一个应用写入没问题直接跑就行了。不用分2个flash区。如果担心升级出错,应该备份原来的数据,而不是写入到flash2,然后又copy到flash1
伤情最是晚凉天,憔悴斯人不堪怜。
邀酒摧肠三杯醉,寻香惊梦五更寒。
钗头凤斜卿有泪,荼蘼花了我无缘。
小楼寂寞新雨月,也难如钩也难圆。
回复

使用道具 举报

30

主题

1170

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
金钱
1993
注册时间
2016-2-16
在线时间
527 小时
发表于 2016-9-19 14:48:50 | 显示全部楼层
我现在项目就是这样弄的,flash1和flash2彼此独立,boot根据某个掉电可保持的数据决定运行那一段的程序。flash1里面根据通讯协议可写flash2位置的数据,flash2反之。
回复

使用道具 举报

3

主题

2178

帖子

2

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
3323
金钱
3323
注册时间
2013-7-19
在线时间
195 小时
发表于 2016-9-19 17:22:05 | 显示全部楼层
通俗来说双区其中一个区是备份,一旦1区更新失败,机子不会趴窝,可以从2区启动并恢复1区。跟电脑的双BIOS保险类似
回复

使用道具 举报

355

主题

1476

帖子

12

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
8105
金钱
8105
注册时间
2015-10-15
在线时间
2922 小时
发表于 2016-9-19 18:27:36 | 显示全部楼层
一个区域用来备份老程序,一个区域用来执行新程序。。。
升级过程怕有异常,还可以重新切换加载老程序。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-29 03:06

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表