1.惨痛的教训
那是一个严寒的冬日,客户在现场使用我们公司新研发的设备,设备最初设计可以允许最多连接20个温湿度传感器,但是由于现场空间非常大,客户要求连接30个温湿度传感器。这个需求修改非常简单,只用修改程序中的一个宏定义就可以了。因为涉及到需要修改程序和更新程序固件,我们要求客户把设备寄回我们公司升级设备的固件,然后再把设备给客户寄到测试现场。但是客户因为项目进度计划紧迫,认为这种方案耽误的时间长,不同意这种处理方案!最终我们公司的研发和生产加班了6个小时,直到晚上12点才重新好一套设备,然后让业务人员连夜开车将新设备送给客户。因为一个小小的修改需求,浪费了大量的人力物力,真是沉重的教训!
有了这次沉重的教训,我毫不犹豫的给设备程序增加了IAP功能,自从设备有了IAP功能,我们可以根据需求随时更新现场设备的固件程序,从此以后就可以实现放飞自我了!
2.IAP是什么
IAP(In-Application Programming)指的是在应用编程,就是MCU程序固件在运行过程中可以获取新代码数据并对Flash部分区域进行烧写,用新固件程序覆盖旧程序固件,实现程序固件升级。IAP的目的是:通过预留的通信口对产品的程序固件进行更新升级。
为什么要使用IAP功能?
IAP功能会给我们带来哪些好处呢?
IAP可以为我们带来以下两个好处。
1、IAP可以实现免拆机壳升级产品程序固件。
通常情况下程序下载需要使用专用的下载口(如JTAG口),然而这个接口通常情况下不会预留在设备外部,如果需要更新设备的程序固件,就需要拆开设备外壳,使用下载器连接到设备下载口,下载程序到设备。
例如现场有100个设备,由于客户提出新的需求,需要给现场的设备升级程序固件。工程师来到现场,首先需要把100个设备的外壳打开,然后使用下载器连接到下载口升级程序固件,然后在将100个设备的外壳安装好。
拆卸和安装设备外壳是一个非常繁琐的过程,有时候甚至会由于意外操作损坏设备(如螺丝滑丝或电路板短路)!如果设备有IAP功能,我们可以使用设备预留的串口,USB口或者网口升级设备程序固件。不需要拆装设备外壳就可以实现程序固件更新,省时省力,也减小出问题的概率。
2、IAP可以通过网络实现对设备进行远程升级。
如果设备有3G/4G、WIFI、NB等网络功能,IAP可以利用这些网络功能实现远程设备升级。例如设备拥有IOT-NB功能,我们可以利用云端的服务器将数据通过NB网络下发给设备,实现设备的远程固件升级功能,无需外派工程师到现场,省时省力高效!
3.IAP工作原理
IAP的核心功能是:更新程序。那么IAP是如何实现更新程序功能,IAP的工作原理是什么呢?
我们先讲一个生活中的例子:金刚石刀头的制造过程。锯片的刀头处通常会焊接一个高强度,耐磨性好的金刚石刀头,这个刀头是金刚石粉末在热压机设备中经过高温高压制作而成。
热压机设备制造过程中的温度和压力的工艺决定决定金刚石性能品质,例如一个简单的工艺是:启动时温度和压力缓慢增加,一定时间后到达高温高压状态,随后保持高温高压一段时间,最后缓慢减小温度和压力,这个生产过程称为工艺曲线控制。
假设客户需要锯大理石的锯片,需要高强度的锯片,因此需要修改金刚石刀头的工艺曲线。首先生产主任拿来曲线工艺清单,操作工人接收曲线工艺清单,重新设置工艺曲线,然后重启设备,就这样完成了工艺曲线的更新。在整个工艺曲线更新的过程中有三个重要部分:
1、设备当前运行的工艺曲线参数。
2、生产主任提供的新工艺曲线参数。
3、操作工人。
工艺曲线更新的过程中有三个重要动作:
1、下发,生产主任将新工艺传递给操作工人。
2、更换,生产工人删除旧的工艺曲线,输入新的工艺曲线。
3、重启,完成新工艺参数输入后重新启动机器,运行新的工艺曲线。
回到正题,在实现IAP功能时通常需要在设计固件程序时编写两个项目代码:
1、第一个项目代码不执行用户功能操作(产品功能),而是通过USB、USART或者网口接收数据(APP代码就是数据),并对第二部分代码进行更新,我们把这部分代码称为bootloader。
2、第二个项目代码是真正的功能代码(实现产品功能),我们把这部分代码称为app(应用程序)。
bootloader和app这两个代码都同时烧录在Flash中(不同区域),当芯片上电后,bootloader代码首先开始运行,随后跳转并执行app代码,大致流程如下:
1、检查是否需要对app代码进行更新,如果有需要就执行app代码更新。
2、跳转到app代码。
3、运行app代码。
结合金刚石刀头这个实例,可以将IAP工作流程作如下对比:
1、bootloader相当于操作工。操作工可以接收新的工艺参数,更新工艺参数;bootloader可以接收新的程序固件,更新设备程序固件。
2、app就相当于设备中运行的工艺参数。
3、新的app就相当于新的工艺参数。
4、下发,对应外部设备将新app程序数据发送给bootloader。
5、更换,对应bootloader将接收到的appapp程序数据写入app程序对应的FLASH区域。
6、重启,对应bootloader完成app更新后,跳转并执行app代码。
根据IAP工作流程,可以将IAP功能分解成以下3部分功能:
1、数据交互,接收外部设备发送来的数据。
2、数据存储,将接收到的数据写入存储器。
3、程序跳转,跳转并执行APP。
IAP的以上3部分功能称为IAP三板斧,接下来我们看这三板斧具体完成哪些细节工作,以及我们如何实现这三板斧。
创作不易希望朋友们点赞,转发,评论,关注!
您的点赞,转发,评论,关注将是我持续更新的动力!
CSDN:https://blog.csdn.net/li_man_man_man
今日头条:https://www.toutiao.com/article/7149576260891443724