可在线OTA升级的嵌入式系统设计方案

2019-07-12 20:34发布

什么是在线OTA升级

-         OTA是Over-the-Air的简写,空中下载技术的意思。 -         OTA在线升级在日常消费电子产品中很常见,比如手机,机顶盒等,通过网络,下载升级数据包,更新操作系统等底层固件进行系统更新升级。 -         在线升级系统对于批量化消费电子产品来说是相当重要的。因为销售给客户的电子产品,其中的软件系统可能有潜在的bug或者功能为实现不齐全,需要在售后进一步完善更新系统。一般都是通过网络远程给用户进行系统更新。

可在线OTA升级的嵌入式系统Flash存储区规划

-         要设计带有OTA在线升级功能的嵌入式系统,首先需要对系统的flash存储区进行分区规划。 -         一般带有OTA系统的分区规划如图1所示。 -         本系统的分区不包括升级失败的备份还原分区,本文只考虑升级成功的情况,升级失败还原只需再增加冗余分区与启动方案即可。
Figure 1带有OTA升级功能的嵌入式系统Flash存储器分区规划 -         在图1的flash分区规划中,uboot根据boot flag param分区里的数据,选择正常的应用系统Normal APP System启动还是从升级系统 Update System 启动。 -         Uboot可以用其它类型的boot代替,常规应用系统和升级系统的 OS kernel可以是Linux Kernel ,也可以是普通的 RTOS Kernel,实际设计的时候,要根据Flash存储空间的大小进行调整与优化,选择合适的OS Kernel 和 uboot进行系统的规划。 -         另外,OTA升级时,从网络上下载的一般是压缩的升级数据包(数据包包含OS Kernel 与 Rootfs),需要单独一个分区用于存放压缩的升级数据包。 -         用户数据单独设置一个分区存放,以保证OTA升级更新之后,用户数据不会丢失。

嵌入式系统在线升级流程

1). Normal  APP系统与 Update 系统的启动选择 - 带有OTA升级的嵌入式系统,一般都有两个系统,一般是通过启动Update 系统,在运行Update系统的应用,擦出Normal  APP系统中的程序数据,再将OTA下载的新系统数据解压,重新写入Normal APP 系统所在的分区。 -  双系统的启动选择方式如图2所示。 - Uboot 通过读取 BootFlag Param 分区中的参数来选择一个系统启动。
Figure 2 uboot 通过判断boot flag param 分区中的参数选择启动一个系统 2). OTA在线升级的全过程 - 系统OTA在线升级的整个流程如图3所示。 - 整个OTA在线升级并不神秘,但是步骤还是多而繁琐,通过画出流程,我们才知道每一步到底做了什么。
Figure 3 系统OTA在线升级的整个流程