OpenEdv-开源电子网

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

STM32F4 IAP升级方案探讨

[复制链接]

39

主题

131

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1439
金钱
1439
注册时间
2015-12-26
在线时间
208 小时
发表于 2017-9-5 16:18:06 | 显示全部楼层 |阅读模式
2金钱
最近打算做IAP升级,用的STM32F4,遇到一个问题,就是IAP升级时是一边收数据一边写flash好还是等bin文件都收完了一次写flash好。因为有时APP程序会大于SRAM的大小,这样就不能一次收完bin文件再写了。但是一边收一边写flash(假如收2k的数据后就写flash),如果中间通信故障,那么升级失败,连原来的APP程序也运行不了了。

有什么好的办法可以避免这种问题。(也想过先把原来的APP备份在某个扇区,如果中间升级失败在回退,但是不知道这样会不会很耗时间)

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

430

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1461
金钱
1461
注册时间
2011-12-1
在线时间
110 小时
发表于 2017-9-5 16:53:37 | 显示全部楼层
像你说的这种情况就只能用一边收一边写flash的方式了,不要担心中途升级失败的问题,一般你程序比较稳定的话,这种失败的几率几乎没有的,所以也不必想的那么复杂。至于你的BIN文件下发通讯这个必须要保证好,否则不管你是全部下发还是一边发一边写都得不到保证的。而且一边发一边写还有个好处是你发2K之后就验证下是否写正确,而全部下发的话出错就只能重新来,更耗时。
专业从事软硬件设计,毕业设计,C51/AVR/MSP430/STM32等单片机软硬件制作与定制。有需求的可以联系我。QQ:3436737049淘宝店铺:龙隽电子科技
回复

使用道具 举报

39

主题

131

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1439
金钱
1439
注册时间
2015-12-26
在线时间
208 小时
 楼主| 发表于 2017-9-5 17:02:27 | 显示全部楼层
xlong_06 发表于 2017-9-5 16:53
像你说的这种情况就只能用一边收一边写flash的方式了,不要担心中途升级失败的问题,一般你程序比较稳定的 ...

嗯,我是分包发的,通讯协议是自定的,帧头加每个小包的数据,用的求和校验。
回复

使用道具 举报

16

主题

216

帖子

1

精华

高级会员

Rank: 4

积分
970
金钱
970
注册时间
2016-11-24
在线时间
156 小时
发表于 2017-9-5 17:02:43 | 显示全部楼层
我目前是用外部SRAM来接收需要升级的bin,接收完毕校验通过之后,再从外部SRAM那里把数据写入FLASH,目前这个方法用在SD卡升级和网络升级中都是稳定运行,突然断电也不会出问题,整个升级过程要十来秒钟
回复

使用道具 举报

1

主题

430

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1461
金钱
1461
注册时间
2011-12-1
在线时间
110 小时
发表于 2017-9-5 17:04:31 | 显示全部楼层
ZhuMX 发表于 2017-9-5 17:02
嗯,我是分包发的,通讯协议是自定的,帧头加每个小包的数据,用的求和校验。

用的串口通讯吗,保证好通讯的话,一般不会出现失败的问题的,毕竟这写flash还是很稳定的,就想你烧程序,一般都会烧录成功的!
专业从事软硬件设计,毕业设计,C51/AVR/MSP430/STM32等单片机软硬件制作与定制。有需求的可以联系我。QQ:3436737049淘宝店铺:龙隽电子科技
回复

使用道具 举报

39

主题

131

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1439
金钱
1439
注册时间
2015-12-26
在线时间
208 小时
 楼主| 发表于 2017-9-5 17:06:37 | 显示全部楼层
lzq12 发表于 2017-9-5 17:02
我目前是用外部SRAM来接收需要升级的bin,接收完毕校验通过之后,再从外部SRAM那里把数据写入FLASH,目前这 ...

请问你是分包接收还是一次性接收的bin文件?用的哪种校验方式?想参考下,谢谢
回复

使用道具 举报

16

主题

216

帖子

1

精华

高级会员

Rank: 4

积分
970
金钱
970
注册时间
2016-11-24
在线时间
156 小时
发表于 2017-9-5 17:13:03 | 显示全部楼层
ZhuMX 发表于 2017-9-5 17:06
请问你是分包接收还是一次性接收的bin文件?用的哪种校验方式?想参考下,谢谢

严格来说我基本都算不上校验,就是检测一下接收到的数据的一些标志。网络升级的校验完全就是靠协议,完全不担心数据丢失。这个是SD卡升级的:http://www.openedv.com/forum.php ... id=90835&extra=,这个是网络升级的:http://www.openedv.com/forum.php ... d=104667&extra=
回复

使用道具 举报

39

主题

131

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1439
金钱
1439
注册时间
2015-12-26
在线时间
208 小时
 楼主| 发表于 2017-9-5 17:18:12 | 显示全部楼层
lzq12 发表于 2017-9-5 17:13
严格来说我基本都算不上校验,就是检测一下接收到的数据的一些标志。网络升级的校验完全就是靠协议,完全 ...

好的,感谢感谢
回复

使用道具 举报

8

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
167
金钱
167
注册时间
2017-8-23
在线时间
16 小时
发表于 2017-9-5 17:29:04 | 显示全部楼层
可以用外部spi flash,先将待烧录的程序通过BootLoader写入外部FLASH中,写完之后,再将数据从SPI flash读取并写入内部flash中。
因为专注,所以专业!
回复

使用道具 举报

39

主题

131

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1439
金钱
1439
注册时间
2015-12-26
在线时间
208 小时
 楼主| 发表于 2017-9-5 18:02:26 | 显示全部楼层
Mrzeng 发表于 2017-9-5 17:29
可以用外部spi flash,先将待烧录的程序通过BootLoader写入外部FLASH中,写完之后,再将数据从SPI flash读取 ...

嗯,但是这样会不会很耗时间?我Bin文件大约135K,以后可能还会变大
回复

使用道具 举报

12

主题

228

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1730
金钱
1730
注册时间
2016-3-8
在线时间
678 小时
发表于 2017-9-5 18:19:00 | 显示全部楼层
ZhuMX 发表于 2017-9-5 18:02
嗯,但是这样会不会很耗时间?我Bin文件大约135K,以后可能还会变大

如果设备上有SD卡,就用SD卡方式升级会简单点。
回复

使用道具 举报

8

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
167
金钱
167
注册时间
2017-8-23
在线时间
16 小时
发表于 2017-9-5 22:19:16 | 显示全部楼层
ZhuMX 发表于 2017-9-5 18:02
嗯,但是这样会不会很耗时间?我Bin文件大约135K,以后可能还会变大

看你采用的是什么通信方式来升级,usb的话也可以很快,主要看你的硬件上有什么资源,F4是自带USB OTG驱动的.
因为专注,所以专业!
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-18 08:03

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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