# update_updater_0711 **Repository Path**: rayllll/update_updater_0711 ## Basic Information - **Project Name**: update_updater_0711 - **Description**: Updater module | 升级安装组件 - **Primary Language**: Unknown - **License**: Apache-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 447 - **Created**: 2025-07-11 - **Last Updated**: 2025-07-11 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 升级包安装组件 - [简介](#section184mcpsimp) - [目录](#section198mcpsimp) - [说明](#section218mcpsimp) - [使用说明](#section220mcpsimp) - [相关仓](#section247mcpsimp) ## 简介 升级包安装组件运行在updater分区,其功能主要包括读取misc分区信息获取升级包状态,对升级包进行校验,确保升级包合法有效;然后从升级包中解析出升级的可执行程序,创建子进程并启动升级程序。具体升级的动作由升级脚本控制。 更多升级子系统相关概念,请参考:[升级子系统](https://gitee.com/openharmony/docs/blob/master/zh-cn/readme/%E5%8D%87%E7%BA%A7%E5%AD%90%E7%B3%BB%E7%BB%9F.md) **图 1** 升级子系统架构图 ![](figures/Openharmony-updater-升级子系统架构图.png) ## 目录 ``` base/update/updater/ ├── resources # 升级子系统用户界面图片资源目录 ├── services # 组件服务层代码目录 │ ├── applypatch # 升级包数据更新代码目录 │ ├── diffpatch # 差分还原代码目录 │ ├── etc # 启动相关配置文件目录 │ ├── flashd # flashd模式镜像写入和升级功代码目录 │ ├── fs_manager # 文件系统和分区管理代码目录 │ ├── hdi # 硬件相关接口定义 │ ├── include # 升级子系统头文件目录 │ ├── log # 升级子系统日志模块目录 │ ├── package # 升级包管理模块目录 │ ├── ptable_parse # 分区表解析代码目录 │ ├── script # 升级脚本管理目录 │ ├── ui # 升级ui界面代码目录 │ └── updater_binary # 升级可执行程序目录 ├── interfaces │ └── kits # 对外模块接口定义 └── utils # 升级子系统通用代码目录 └── include # 升级子系统通用函数头文件目录 ``` ## 说明 ### 使用说明 升级包安装组件运行在updater分区里,需要如下的操作 1、创建updater分区 updater是一个独立的分区,分区大小建议不小于20MB。updater分区镜像是ext4 格式文件系统。确保系统内核ext4 文件系统的config 是打开状态。 2、创建misc分区 misc 分区中存储了升级子系统在升级过程中需要的元数据\(metadata\),如升级命令,掉电续传记录等。 misc 分区的大小约1MB,是一个裸分区,无需制作文件系统, 升级子系统直接访问。 3、分区配置表 升级包安装组件在运行过程中,需要通过分区配置表操作分区。默认的分区配置表文件名是fstab.updater,在编译的时候,打包到升级包安装组件中。 4、升级包安装组件启动 updater分区的init 进程有单独的配置文件 init.cfg,升级包安装进程启动配置在该文件中。 5、升级包安装组件编译 a、在build/subsystem\_config.json文件添加配置。 如下: ``` "updater": { "project": "hmf/updater", "path": "base/update/updater", "name": "updater", "dir": "base/update" }, ``` b、 产品中添加需要编译的组件 以Hi3516DV300为例,在productdefine/common/products/Hi3516DV300.json 中添加updater: ``` "updater:updater":{}, ``` 6、updater分区镜像编译 编译配置在build仓下,build\_updater\_image.sh 脚本中,该脚本由OHOS 编译系统调用。 ## AB流式升级 用户设备并非在data分区上总是有足够的空间用于下载OTA升级包,同时用户有时候不需要进入小系统升级来影响设备体验。为了解决这些问题,OpenHarmony中添加了对AB流式升级的更新,可以在下载数据块Chunk写入备用B分区,而无需将数据块或者升级包存储到data分区;同时不需要进入updater小系统进行升级,用户设备操作在活跃A分区,更新在备用B分区。 ### 关键技术 1、 支持AB分区独立升级,实现无缝更新。 2、 支持流式升级断点续传,在网络断开连接、用户操作暂停等操作后,重新点击下载并更新可以实现继续更新。 3、 支持多种安全校验,每个数据块Chunk会带有哈希校验,更新完后会对每个镜像进行完整性校验。 4、 支持异常回滚机制,确保升级失败时自动恢复到稳定分区,确保用户体验。 5、 支持流式传输数据块自定义,可以根据设备data分区大小自调整。 ### 做包流程 在AB流式升级当中,修改的重点是在原AB差分或者全量升级包的基础上,对大于本文档数据大小要求的new和diff操作要进行更小的切片,并按照TLV格式把差分依赖文件都封装到update.bin文件中 1、 切割内容大于45KB的diff/new 输入参数:pkgdiff、new命令 输出结果:对于pkgdiff命令尝试生成diff文件,如果diff文件大于45KB,就把pkgdiff命令分成多个pkgdiff,直到每个pkgdiff命令的diff文件大小都小于45KB。new命令直接判断block的内容大小,不满足大小的,就分割成多个new命令 2、计算img总块除去action列表中操作的块 输入参数:action列表中所有操作过的块,img总块 输出参数:两者补集,即将需要copy的块进行升序排序,连续的组成集合,按照原有new的格式进行组合成copy命令 3、根据TLV格式封装action及diff等内容到update.bin 输入参数:transfer.list、new.dat、patch.dat 输出结果:将transfer.list每一行封装成一个chunk,依赖的内容在new.dat和patch.dat中查找,并按TLV格式生成update.bin ## 相关仓 [升级子系统](https://gitee.com/openharmony/docs/blob/master/zh-cn/readme/%E5%8D%87%E7%BA%A7%E5%AD%90%E7%B3%BB%E7%BB%9F.md) [**update\_updater**](https://gitee.com/openharmony/update_updater) [build](https://gitee.com/openharmony/build) [productdefine\_common](https://gitee.com/openharmony/productdefine_common)