高通OTA升级非常规分区方法

高通OTA升级非常规分区方法

  • 1. 高通LE OTA背景
  • 2. 高通LE OTA升级方案
    • 2.1 SDX12 OTA方案
    • 2.2 OTA升级TZ/RPM/Aboot

OTA是一个通用述语,常见的解释为over the air。通过这一解释,OTA最开始的概念,是空中升级。后来,又衍生出了FOTA,FOAT的概念。

FOTA可以理解为Firmware Over The Air,即在线升级,是指通过模块的数据通道完成升级包的下载和安装。此外,FOAT,是模块项目实践运用中,发展出来的另一种升级方式,可描述为通过本地升级工具对模块进行软件更新的过程。FOAT与FOTA的不同是,升级包的导入方式上的不同。FOAT是通过串口传输导入,没有无线部分的介入。所以两者只是升级包导入的方式上的不同。在升级包导入到设备后,升级包的安装更新,都归为模块自身的基本升级功能,由Recovery系统来完成。

综上,在模块项目中OTA调试,可分为三大块,即:
在这里插入图片描述

1. 高通LE OTA背景

高通MDM、MSM平台提供了基本的升级功能,大概都以开源的Android升级设计实现作为基础,对其代码进行移植,适配到自身平台上。从差分包制作工具,升级过程,都有一套完整的方案,并且所涉及到的工具和代码均完全开放,因此该方案的可塑性也更大。其中包括统一的用于安装升级包的Recovery系统,编译OTA底包专属框架,和处理底包制作升级包的脚本和工具等。

由于该方案中各个文件的PATCH 基于文件系统而来,因此很难在bootloader 阶段实现(无法挂载文件系统),所以在分区设计上,除了预留存放差分包,备份文件的空间外,还需要添加专门的分区(kernel, bootloader,filesystem)以供FOTA 使用,而该分区必须独立于正常运行时的分区。这也就导致了该方案在硬件(FLASH,DDR)要求比较高。

在LE 的FOTA 方案中,升级程序作为一个应用程序运行,升级包则是一个标准的zip 文件(命名为ota 文件),升级过程则是解析升级包中指定的脚本文件,并根据解析到的内容引用对应的功能模块,从而完成整个升级过程。

2. 高通LE OTA升级方案

下面主要介绍基于高通LE OTA方案,SDX12做的一些改进,以及如何在SDX12上完成 tz、rpm、appsboot等非常规镜像或分区的OTA升级。

2.1 SDX12 OTA方案

X12 OTA升级使用的是高通平台通用的FOTA方案,基本可以总结以下几个步骤:

  1. 本地制作差分包,并上传到远端OTA服务器
  2. x12启动OTA client线程去在固定间隔时间访问OTA服务器
  3. 当OTA服务器上有可用OTA 包,则校验包是否完整、版本号是否符合预期
  4. 若(3)中校验OK,则下载OTA包到本地
  5. 下载完成后重启进入recovery模式
  6. recovery模式启动后会先检测是否存在OTA包,存在则解压包并使用包中的工具打patch
  7. 升级完成后设置成功标记并重启进入boot模式
  8. 升级完成

流程图如下:
在这里插入图片描述

高通LE平台是多个子系统构成,其中boot、system这两个子系统属于HLOS镜像,其他如tz、rpm、appsboot、modem等均为non-HLOS镜像。

虽然NAND设备 (例如SDX12) 支持non-hlos镜像的OTA升级,但电源中断安全升级机制仅适用于system、boot和modem镜像。启动关键映像 (如tz、rpm、appsboot等) 可以升级,但如果在升级的很短时间内发生电源中断 (通常为毫秒),设备将处于砖砌状态。

因此默认OTA方案通常仅建议升级boot、system和modem镜像,其中boot镜像是以全包的方式、system镜像以文件patch方式、modem以压缩拆分后的patch方式:
在这里插入图片描述
但由于boot镜像占用较大的空间,对于硬件(FLASH,DDR)要求比较高。很多时候无法满足,因此我们在高通LE OTA升级方案上做出如下优化:将boot镜像也以patch的方式进行升级,这样就可以减少对于硬件(FLASH,DDR)要求,满足低存储空间的场景。
在这里插入图片描述

2.2 OTA升级TZ/RPM/Aboot

但是还存在客户想OTA升级启动关键映像 (如tz、rpm、appsboot等),如客户有屏幕的场景,想更新开机动画,而开机动画在sbl阶段就已经开始,因此就需要去升级appsboot镜像。虽然启动关键映像 (如tz、rpm、appsboot等) 可以升级,但如果在升级的很短时间内发生电源中断 (通常为毫秒),设备将处于砖砌状态。但高通针对这种情况,也是提供了对应的升级方案,但不建议使用,下面我们将简单介绍如何去OTA升级这些非常规的分区。

根据高通文档80-16206-49 AA,我们可以看到如我们想升级non-hlos镜像,只需将这些镜像打包在OTA目标版本底包的RADIO目录下即可。

在这里插入图片描述
按照上述方法,我们手动将appsboot镜像打包到RADIO目录下:

在这里插入图片描述
然后使用OTA差分制作工具制作差分包,就可以在OTA差分包firmware目录下看到appsboot镜像,当升级时就会按照patch脚本去打patch升级appsboot镜像:

在这里插入图片描述
在差分包的patch脚本META-INF\com\google\android\updater-script中也确实可以看到appsboot镜像将以raw镜像的方式升级:

在这里插入图片描述

但上面这种方式需要手动打包tz、rpm、appsboot等镜像到OTA目标版本底包中,这样是非常不便利的,因此修改ota底包制作流程,将tz、rpm、appsboot等镜像按需打包进OTA底包中:

在这里插入图片描述

但如果我们在目标和当前版本OTA底包中都放上tz、rpm、appsboot等镜像,又会导致他们会以patch的方式升级,而tz、rpm、appsboot等镜像本身就只有不到1M的空间,因此完全无需patch方式,因此修改差分包制作工具,判断当文件为tz、rpm、appsboot等镜像时,无需制作patch,直接拷贝目标镜像即可。

在这里插入图片描述
通过上述这些修改,就可以完成OTA升级tz、rpm、appsboot等非常规分区。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/210081.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jupyter notebook 不知道密码,怎么登录解决办法

jupyter notebook 不知道密码,怎么登录解决办法 1、 windows下,打开命令行,输入jupyter notebook list : C:\Users\tom>jupyter notebook list Currently running servers: http://localhost:8888/?tokenee8bb2c28a89c8a24d…

企业软件定制开发的优势|app小程序网站搭建

企业软件定制开发的优势|app小程序网站搭建 企业软件定制开发是一种根据企业特定需求开发定制化软件的服务。相比于购买现成的软件产品,企业软件定制开发具有许多优势。 1.企业软件定制开发可以满足企业独特需求。每个企业都有自己独特的业务流程和需求,…

使用docker命令_进入容器_登录mysql服务_并执行sql语句---Docker工作笔记005

今天就用到了,不得不说用docker用到的还是少,记录一下,常用的也就这些吧. 首先执行: docker ps [root@localhost dataease-1.18.9]# docker ps CONTAINER ID IMAGE COMMAND CREATED …

代码随想录算法训练营Day 59 || 503.下一个更大元素II、42. 接雨水

503.下一个更大元素II 力扣题目链接(opens new window) 给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素),输出每个元素的下一个更大元素。数字 x 的下一个更大的元素是按数组遍历顺序,这个数字之后的第一个比它更…

华清远见嵌入式学习——网络编程——作业4

作业要求&#xff1a;①使用IO多路复用中的select函数实现TCP并发服务器客户端 ②使用IO多路复用中的poll函数实现TCP并发服务器的服务器端 一、 代码 #include <myhead.h>#define SERPORT 8888 //服务器端口号 #define SERIP "192.168.114.113"…

曲率半径的推导

参考文章 参考文章

ABB机 器 人 操 作 培 训

目 录 1 培训手册介绍 ---------------------------------------------2 2 系统安全与环境保护 ---------------------------------------------3 3 机器人综述 ---------------------------------------------5 4 机器人示教 --------------------------------------------12…

强化学习------贝尔曼方程

目录 前言基础知识马尔可夫决策过程 (Markov decision process, MDP)回报(Return)折扣回报(Discounted Return) State Value&#xff08;状态价值函数&#xff09;贝尔曼方程的推导贝尔曼方程的矩阵形式Action Value&#xff08;动作价值函数&#xff09;贝尔曼最优公式 前言 …

pip安装python包到指定python版本下

python -m pip install 包名1.命令行进入到指定python安装目录。比如我电脑上有python3.8也有python3.9。准备给python3.9安装指定的包

gitee推荐-PHP面试准备的资料

该内容为giee项目。PHP-Interview: 这个项目是自己准备PHP面试整理的资料。包括PHP、MySQL、Linux、计算机网络等资料。方便自己以后查阅&#xff0c;会不定期更新&#xff0c;欢迎提交pr&#xff0c;如果错误&#xff0c;请指出&#xff0c;谢谢 在线预览地址&#xff1a;Intr…

Android7.1 高通平台 修改系统默认语言

客户需求&#xff1a;修改系统默认语言为英文&#xff08;美国&#xff09; 源码位置&#xff1a;/build/tools/buildinfo.sh 只需修改 ro.product.locale的值即可&#xff0c;如下图&#xff1a;

【大数据】Docker部署HMS(Hive Metastore Service)并使用Trino访问Minio

本文参考链接置顶&#xff1a; Presto使用Docker独立运行Hive Standalone Metastore管理MinIO&#xff08;S3&#xff09;_hive minio_BigDataToAI的博客-CSDN博客 一. 背景 团队要升级大数据架构&#xff0c;需要摒弃hadoop&#xff0c;底层使用Minio做存储&#xff0c;应用…