当前位置:首页 > 公众号精选 > strongerHuang
[导读]关注、 星标公众号,不错过精彩内容 转自公号:最后一个bug 二次整理:strongerHuang 做软件开发的人,都知道程序升级。升级的方式有很多,今天就来讲讲升级的软件的设计思路。 一、ISP/ICP/IAP名称解释 在我们学习MCU的过程中经常看到IAP、ISP、JTAG等等一些

关注、 星标公众,不错过精彩内容

转自公号:最后一个bug

二次整理:strongerHuang


做软件开发的人,都知道程序升级。升级的方式有很多,今天就来讲讲升级的软件的设计思路。


一、ISP/ICP/IAP名称解释

在我们学习MCU的过程中经常看到IAP、ISP、JTAG等等一些与在线编程相关的专业名词,可能很多小伙伴到现在都迷迷糊糊的,这里简单为大家介绍一下:


1)ICP -(In-circuit programmer)  

ICP表示在电路编程,MCU内部不需要有程序,直接上电就能够进行对程序存储区域进行编程的方式,我们平时使用JTAG或者SWD等等就属于这种方式。


2)ISP - (In-system programer) 

ISP表示在系统编程,通过MCU专用的串行编程接口进行编程,那也就是说MCU需要具有运行的外部条件,比如需要有晶振等等。比如说平时使用的stm32通过设置boot引脚设置对应启动模式,然后通过串口等对内部Flash进行升级,可以说这种方式就是厂家在芯片内部固化了一个BootLoader程序。


3)IAP - (In-application programer) 

IAP表示在应用编程,这种名词应该是大家在平时学习过程中见得比较多的,相当于自己定制一个BootLoader程序,自己通过编程设计可以实现各种升级的方式比如串口、CAN、以太网等等,非常的灵活。其实这个BootLoader程序也是我们自己设计的程序,你也可以认为是一个App程序,相当于通过对App划分职责对自己进行更新和升级。这种方式也就是我们今天话题的主角。


二、MCU软件升级设计思路

对于我们的MCU现在大部分的都是使用Flash来存储程序,同时程序内部也会有读写Flash的接口函数,中断也可以方便的重定位,这样就非常适合IAP程序的开发。


1)IAP升级V1.0

升级软件设计图:

我们把MCU的Flash分区分为如上图所示的三个部分,Bootloader就是我们所要编写的启动程序,App程序为项目的实际应用程序,Param区域是用于存储相应的版本App的版本信息以及完整性校验标志序列等传递数据区域。

工作方式1:当MCU启动以后运行Bootloader程序,检测到Param参数区域是否存在App记录,如果存在App直接运行App程序即可,如果不存在,则向PC机请求App文件。


工作方式2:当MCU运行App过程中,接收到PC机的升级请求,更新Param参数区域,并跳转到BootLoader进行App程序的接受和升级,升级完成以后处理Param参数区域并运行对应的新App程序。


V1.0算是比较常规的应用案例,我们都知道对MCU内部Flash进行编程一般会有解锁、擦除、写入和验证几个阶段,当我们擦除原来MCU存储的App程序以后如果手头上没有相关的固件,基本上就不能恢复了,这样如果我们想退回到之前的版本不可能了!于是升级方案还需要在改善一下。


2)IAP升级V2.0 

为了解决V1.0提出的问题我们App分成了两部分如下图所示:

解析一下:上面两张图的原理是一样的,都是把接收到的新App保存起来(如果你用于备份老的App也是可以的),图1是通过把MCU内部Flash进行划分,一部分用于存储新App,另外一部分是原来运行的App区域,这样的话,当我们通过bootloader接收完完整的新App进行校验、解密处理以后便可以写入到平时运行的App区域,从而防止了V1.0在升级过程中掉电、通信异常导致擦除了App的问题。


同时,我们也可以把上一版本App备份到我们预留的内部Flash或者外部存储设备中,如果想还原系统即可直接通过PC发送相应命令进行恢复即可。


好了,又有小伙伴提出问题,大家都知道我们自己编写的BootLoader是非常灵活的,可以支持多种通信协议的升级模式,不过在前期我们可能没有考虑完善,后续想进一步完善相应功能就需要我们对Bootloader进行升级,那么我们可以通过App对Bootloader进行升级操作,一般这种方式就可以满足需求,不过如果在升级BootLoader过程中发生故障,那Bootloader全部被擦除导致整个MCU变成了个砖头。好吧,是时候上V3.0版本的IAP程序了。


3)IAP升级V3.0 

为了解决V2.0问题,作者设计了第三种升级方式:

解析一下:在V2.0的基础上我们增加了Bootloader2,对于Bootloader1相当于固化在MCU中自定义的一种升级方式,而Bootloader2是可以根据我们启动升级需求进行升级的区域,这样即使在升级过程中擦除,我们也可以通过BootLoader1或者App2来进行恢复Bootloader2。


不过具体的实现过程会设计到较多的逻辑处理,大家在实现该方案的同时需要前期进行软件上的设计和梳理。


免责声明: 本文转自最后一个bug,版权归原作者所有。如涉及作品版权问题,请与我联系删除。

推荐阅读:
几种常见的校验算法
为什么IoT设备的操作系统选用RTOS
分享一篇专治MCU各种 HardFault 的库

关注 微信公众号『strongerHuang』,后台回复“1024”查看更多内容,回复“加群”按规则加入技术交流群。


长按前往图中包含的公众号关注

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭