Android Update Engine 分析
文章平均质量分 97
深入代码分析 Android Update Engine 的各种操作和行为
洛奇看世界
中山大学毕业,某芯片公司高级技术支持工程师,十几年的行业资深老油条,2b 狗主人,一个喜欢运动的老爹,一只热爱生活的程序猿。
展开
-
Android Update Engine 分析(三二)Android 的槽位切换是如何实现的?
Android slot 槽位的切换是 Android OTA 一个比较基础的知识点,刚接触 Android OTA 的同学往往不清楚槽位 slot 到底是如何切换的,所以这也是 Android OTA 讨论群里问得比较多的问题我在[《Android A/B System OTA分析(三)主系统和bootloader的通信》](https://blog.csdn.net/guyongqiangx/article/details/72480154)有中,有做过相关内容的分析。但没有明确指出槽位是如何切换的。原创 2024-07-29 01:17:33 · 225 阅读 · 0 评论 -
Android Update Engine 分析(三一)Android 能在升级时新增分区吗?
经常在讨论群和答疑群看到有同学问能不能在升级时新增分区,以及如何新增分区的问题。这里打算分两篇来介绍:第一篇,介绍分区调整的基本原理。包括普通分区的增加,以及 super 设备上分区的增加;第二篇,新增分区实战。基于 Android 12(S) 代码,提供一个新增分区的实例。作为第一篇,本文从原理角度出发,详细分析分区更新的底层逻辑,让你对升级时能否增加、修改和删除分区,以及修改分区可能的风险有一个彻底的认识。原创 2024-07-17 23:32:26 · 183 阅读 · 0 评论 -
Android Update Engine 分析(三十)有了A/B系统,为什么还要 Recovery?
本文先单独分析 A/B 系统和 Recovery 系统各自的功能,然后对比功能差异来找到 A/B 系统并不能完全替代 Recovery 系统的原因。如果 Recovery 系统所有的功能 A/B 系统都能满足,那自然的结果就是有了 A/B 系统,就可以不需要 Recovery 系统了。如果 A/B 系统并不能实现所有的 Recovery 所具有的功能,那就无法完全替换。同时,也解释了 Recovery 系统存在的意义。原创 2024-07-11 10:55:08 · 231 阅读 · 0 评论 -
Android Update Engine 分析(二十九)如何进行连续多个版本的升级?
关于如何连续进行多个版本升级,这是一个很常见的需求,也是 OTA 讨论群里试不试就会讨论的一个话题。这个场景一般来自测试对多版本连续升级的检查需求:当前系统运行在 A 槽位(版本 v1),然后希望对 B 槽位进行连续多个版本的升级。以升级两个版本 v2, v3 为例,希望先将 B 槽位升级到版本 v2,然后保持系统运行在 A 槽位,继续将 B 槽位版本从 v2 升级到 v3。这个场景看起来很合理,但实际上没有必要。原创 2024-05-14 12:46:28 · 332 阅读 · 0 评论 -
Android Update Engine 分析(二十八)payload.bin 文件还能再压缩吗?
之前 Android OTA 交流群里有人问过,说他的升级包太大,有什么办法可以调整升级包的大小,其中一种尝试的方式就是进行压缩。碰巧前段时间群里又有人发起话题,想知道 payload.bin 是不是一个压缩文件,估计是他的 payload.bin 文件太大了,希望能够压缩一下。简单来说,payload.bin 并不是一个压缩文件,但里面的数据大部分已经充分压缩过了,所以整个文件也就没有多少可以再压缩的空间了。原创 2024-04-20 23:13:46 · 358 阅读 · 0 评论 -
Android Update Engine 分析(二十四)制作降级包时,到底发生了什么?
Android 中,跟降级相关的选项比较多,在 Android 13 的代码中就包含了以下这些选项:downgrade,override_timestamp,vabc_downgrade,spl_downgrade。后续会逐个场景展开分析,本篇主要分析使用 `–downgrade`制作降级包的场景。读完本文,你将得到以下问题的答案:升级或降级的本质是什么?我们制作降级包时到底发生了什么?使用降级包进行 OTA 更新时又发生了什么?原创 2023-10-22 17:54:23 · 1748 阅读 · 0 评论 -
Android Update Engine分析(一)Makefile
写完《Android AB System OTA分析》系列后打算一口气将Update Engine也写了的,但一直由于各种借口,最终没有完成。后来6月份的时候陆陆续续读了Update Engine部分代码,记了点笔记,本打算等彻底读完再分享的,但按照目前的进度不知道读完是哪一天,所以先将笔记贴在这里,如果我的这几篇笔记能对您阅读或理解Update Engine机制有一丝帮助,那花时间整理也是值得的...原创 2017-08-28 16:28:21 · 16465 阅读 · 4 评论 -
Android Update Engine分析(二)Protobuf和AIDL文件
Android Update Engine分析(二)Protobuf和AIDL文件 技术文章直入主题,展示结论,容易让人知其然,不知其所以然。 我个人更喜欢在文章中展示如何阅读代码,逐步分析解决问题的思路和过程。这样的思考比知道结论更重要,希望我的分析能让你有所收获。1. Update Engine中的特殊源文件在上一篇《Android Update Engine分析(...原创 2018-06-26 19:38:44 · 5706 阅读 · 1 评论 -
Android Update Engine分析(三)客户端进程
Android Update Engine分析(三)客户端update_engine_client 技术文章直入主题,展示结论,容易让人知其然,不知其所以然。 我个人更喜欢在文章中展示如何阅读代码,逐步分析解决问题的思路和过程。这样的思考比知道结论更重要,希望我的分析能让你有所收获。前面两篇分别分析了Makefile,Protobuf和AIDL相关文件,从本篇开始正式深入功能实...原创 2018-06-26 20:20:14 · 14139 阅读 · 4 评论 -
Android Update Engine分析(四)服务端进程
Android Update Engine分析(四)服务端进程前面三篇分别分析了Makefile,Protobuf和AIDL相关文件以及Update Engine的客户端进程update_engine_client,Android Update Engine分析(一)MakefileAndroid Update Engine分析(二)Protobuf和AIDL文件Android Up...原创 2018-08-27 17:22:19 · 7728 阅读 · 4 评论 -
Android Update Engine分析(五)服务端核心之Action机制
Android Update Engine分析(五)服务端核心之Action机制前面四篇分别分析了Makefile,Protobuf和AIDL相关文件, Update Engine的客户端进程update_engine_client以及Update Engine的服务端:Android Update Engine分析(一)MakefileAndroid Update Engine分析(...原创 2018-08-30 18:36:19 · 6288 阅读 · 0 评论 -
Android Update Engine分析(六)服务端核心之Action详解
Android Update Engine分析(六)服务端核心之Action详解本系列到现在为止的前五篇分别分析了Makefile,Protobuf和AIDL相关文件, Update Engine的客户端进程,Update Engine的服务端及Action机制:Android Update Engine分析(一)MakefileAndroid Update Engine分析(二)Pr...原创 2018-09-04 20:44:16 · 6198 阅读 · 2 评论 -
Android Update Engine分析(七) DownloadAction之FileWriter
Android Update Engine分析(七) DownloadAction之FileWriter本系列到现在为止的共有六篇,分别分析分析了Makefile,Update Engine的客户端、服务端及Action机制的细节:Android Update Engine分析(一)MakefileAndroid Update Engine分析(二)Protobuf和AIDL文件Andr......原创 2018-09-21 18:54:10 · 8387 阅读 · 6 评论 -
Android Update Engine分析(八)升级包制作脚本分析
Android Update Engine分析(八)升级包制作脚本分析本系列到现在为止共有七篇,分别如下:Android Update Engine分析(一)MakefileAndroid Update Engine分析(二)Protobuf和AIDL文件Android Update Engine分析(三)客户端进程Android Update Engine分析(四)服务端进程And...原创 2018-09-27 18:30:03 · 9720 阅读 · 1 评论 -
Android Update Engine分析(九) delta_generator 工具的 6 种操作
最初计划《Android Update Engine分析》系列的时候,大概有十二篇左右,后来分析 payload 数据生成时觉得要花很多时间去分析整理和消化,就放了一放,结果这一放,3 年就过去了,时间真是过得很快。中间不少朋友加我微信询问 delta 数据生成的问题,也只能不了了之。最近决定继续这一系列的写作。计划中的后续内容包括 payload 生成的所有细节,以及 update engine 从 Android N 开始的演化,动态逻辑分区等。原创 2022-01-06 19:48:14 · 3062 阅读 · 0 评论 -
Android Update Engine分析(十) 生成 payload 和 metadata 的哈希
本篇从代码上一步一步分析生成 payload 和 metadata 数据的哈希值的逻辑流程。如果只想看整个函数调用总结,请转到第 3 节,如果想在 linux 命令行通过手工计算来验证,请跳转到第 4 节。原创 2022-01-09 14:18:37 · 2709 阅读 · 0 评论 -
Android Update Engine分析(十一) 更新 payload 签名
上一篇《Android Update Engine 分析(十)生成 payload 和 metadata 的哈希》详细分析了 metadata 和 payload 的哈希时如何生成的,本篇继续分析脚本中是如何对这两个哈希进行签名,并将签名结果更新到 payload 文件中。原创 2022-01-20 11:10:04 · 4240 阅读 · 0 评论 -
Android Update Engine 分析(十二) 验证 payload 签名
上两篇详细分析了 metadata 和 payload 的哈希如何生成,如何签名,如何更新到 payload 文件中,本篇继续分析代码是如何验证 payload 签名的,包括代码中验证签名的流程和签名在命令行的手动验证。本篇主要内容有三点:1. 如何提供公钥和验证签名;2. 总结 payload 的处理流程;3. 手动在命令行提取 payload 的数据进行验证。原创 2022-01-22 10:53:56 · 2377 阅读 · 0 评论 -
Android Update Engine分析(十三) 提取 payload 的 property 数据
前面三篇分别分析了,如何生成 payload 的哈希,如何对 payload 的哈希签名,如何将 payload 的签名写回 payload 文件中。本篇分析如何提取 payload 文件的属性数据,包括 payload 的 "`FILE_SIZE`" 和 "`FILE_HASH`",以及 metadata 数据的 "`METADATA_SIZE`" 和 "`METADATA_HASH`"。原创 2022-01-23 00:01:37 · 4427 阅读 · 0 评论 -
Android Update Engine分析(十四) 生成 payload 数据
生成 payload 数据是 `delta_generator` 工具最主要的功能,当我准备重新更新这一些列文章时,一开始就想写这个的,不过因为太久没看,不记得 payload 细节了,更无从从细节上分析。所以就先写一些简单的操作,等熟悉了再开始写。经过前面篇的分析了解 payload 结构,现在是时候来解决这个问题了。原创 2022-01-30 15:27:27 · 3313 阅读 · 0 评论 -
Android Update Engine 分析(十五) FullUpdateGenerator 策略
生成 payload 时,会选择不同的策略去遍历每一个分区的每一个 block 生成相应的 Operation 数据:1. 差分升级的情况下,如果 version.minor = 1, 则使用 InplaceGenerator 策略2. 差分升级的情况下,其它情况使用 ABGenerator 策略3. 全量升级情况, 使用 FullUpdateGenerator 策略 本篇分析最简单的 FullUpdateGenerator 策略原创 2022-02-02 00:12:24 · 2661 阅读 · 0 评论 -
Android Update Engine 分析(十六) ABGenerator 策略
上一篇《Android Update Engine 分析(十五) FullUpdateGenerator 策略》详细分析了制作全量包使用的 FullUpdateGenerator 策略,本篇详细分析制作差分包使用的 ABGenerator 策略,虽然说叫详细分析,但因为涉及代码多,层次深,这里主要捡一些重要函数进行注释,其它略过。原创 2022-02-11 18:10:40 · 2309 阅读 · 0 评论 -
Android Update Engine 分析(十七)10 类 InstallOperation 数据的生成和应用
Update Engine 在升级时,最底层的操作就是一个个的 InstallOperation, 根据 InstallOperation 的 Type 和 data, 在源分区和目标分区执行相应的操作,最终在目标分区得到期望的数据。在本篇中,我们不用去管升级的各种流程, 各种签名,只关注 InstallOperation 的 10 种 Type 对应的数据时如何生成的,又是如何使用的。原创 2022-02-15 13:37:35 · 3131 阅读 · 0 评论 -
Android Update Engine 分析(十八)差分数据到底是如何更新的?
过去一直以来陆续有朋友问,差分数据到底是如何更新的?其实我一开始在这个问题上也犯了错误,没搞清楚整个分区更新流程。本文详细跟踪差分数据接收到以后,manifest 数据时如何被解析和使用,InstallOperation 数据又是如何被用于更新的。原创 2023-03-11 16:09:24 · 4246 阅读 · 0 评论 -
Android Update Engine 分析(十九)Extent 到底是个什么鬼?
说来惭愧,几年前,我把 Android 的 system/update_engine 目录下早期的代码翻了一遍,很多地方提到了并且使用了 extent 这个概念来处理数据,但我一直没有搞懂 extent 到底是个什么东西,只是知道一个 extent 由两个数据表示,一个表示起始位置,另一个表示长度。在制作升级包时,差分操作基于 extent 进行;在设备端升级时基于 extent 进行还原。仅致于此,并没有继续深究~最近才了解到 extent 是现在常见的文件系统组织方式,突然一惊,真是 out 了原创 2023-09-16 11:29:28 · 1736 阅读 · 1 评论 -
Android Update Engine 分析(二十)为什么差分包比全量包小,但升级时间却更长?
时不时有同学在 OTA 讨论群和 VIP 答疑群问升级速度的问题,其中一个典型的问题是:为什么差分包比全量包小,但升级时间却更长?与几百 M 甚至几个 G 的全量包相比,差分包相对较小,有时候甚至小到只有几个 M,这么小的差分包,意味携带的 payload 数据很少,写入很少的数据耗时应该很少才是。但为什么现实中差分升级时,差分包很小,但升级时间却比大很多的全量包升级更长。前段时间又有类似话题出现在 VIP 答疑群,几经讨论,这个问题算是彻底弄清楚了。本篇专门探讨这个问题为你揭晓答案。原创 2023-08-17 16:27:07 · 2396 阅读 · 0 评论 -
Android Update Engine 分析(二十一)Android A/B 更新过程
我的第一篇 A/B 系统分析文章《Android A/B System OTA分析(一)概览》从总体上介绍了什么是 A/B 系统,A/B 系统如何进行升级切换,应该是不少人 A/B 系统升级的入门读物。从那之后,我陆续写过几十篇 Android A/B 系统升级的文章(到现在也还有很多话题没有写),但每一篇都只分析了很小的一部分,要不就是分析功能代码,要不就是分析处理流程,要不就是演示工具使用。似乎从来没有一篇从总体角度上,全面又很详细介绍 Android A/B 系统升级。幸运的是,Android 官方对原创 2023-08-28 13:11:45 · 2345 阅读 · 0 评论 -
Android Update Engine 分析(二十二)OTA 降级限制之 timestamp
在我的 OTA 讨论群以及 VIP 答疑群里每隔一段时间就会有人问关于 OTA 降级,以及升级时检查 max_timestamp 失败的问题。我觉得有必要把这个问题总结一下。因此,本篇详细分析 OTA 升级时检查 max_timestamp 失败的原因,以及 max_timestamp 的整个处理流程。原创 2023-09-23 02:03:36 · 1925 阅读 · 0 评论 -
Android Update Engine 分析(二十三)如何在升级后清除用户数据?
在 OTA 讨论群呆久了,经常就能听到各种需求。最常见的一个就是升级后清除用户数据。对老同学们来说这个问题非常非常简单;但对不了解 OTA 的新同学来说,这可能有点无从下手。如何在升级后清除用户数据?一句话,在制作升级包时指定 “–wipe-user-data” 选项就可以了。今天单独写一篇关于升级后如何清除用户数据的话题,其实主要不是为了介绍怎么做,而是梳理一下清除用户数据的流程,包括从制作升级包开始,到最终用户数据被清除的这一整个过程。原创 2023-09-25 20:30:00 · 1916 阅读 · 0 评论 -
Android Update Engine 分析(二十五)升级状态 prefs 是如何保存的?
本系列到现在为止一共二十四篇,前面十七篇基本上就是阅读 update engine 的核心代码和函数,第十七篇以后开始按照话题进行分析。在前面十七篇中,把核心功能代码过了一遍,但仍然有不少功能代码还没分析过。例如,Update Engine 的升级状态数据时如何保存的?系统到底定义了哪些 prefs 数据?本文就管理 Update Engine 状态的 Prefs 类进行详细分析。原创 2023-09-30 01:43:15 · 1508 阅读 · 0 评论 -
Android Update Engine 分析(二十六)OTA 更新后不切换 Slot 会怎样?
上一篇《Android Update Engine分析(二十五)升级状态 prefs 是如何保存的?》 主要分析了 Update Engine 中 prefs 的实现,以及对所有使用 prefs 的统计。在最后打算以 kPrefsBootId 为例,提供一些研究 prefs 的方法。但随着学习的深入,发现 kPrefsBootId 的变化涉的内容很多。这个过程包括,系统升级,成功更新各分区镜像,接着写入 prefs 状态标记,设备重启,系统启动 Update Engine 服务进程,Update Engin原创 2023-10-08 22:59:44 · 1776 阅读 · 0 评论 -
Android Update Engine 分析(二十七)如何实现 OTA 更新但不切换 Slot?
上篇《Android Update Engine分析(二十六)OTA 更新后不切换 Slot 会怎样?》 分析了 OTA 更新但如果不进行切换,重启会失败的原因,以及我的一种解决思路。分享到 OTA 答疑群后,小伙伴子非鱼分享了他的理解,比我提到的方法更简单,立马打脸了(也不完全算是打脸,主要是现成的,更简单直接,在这里也特别对子非鱼的分享表示感谢)。哈哈,我欢迎这样打脸,大家多交流才有进步。简而言之,如果我们升级以后,又不希望切换 Slot,就可以借用 "SWITCH_SLOT_ON_REBOOT=0"原创 2023-10-15 23:43:05 · 1776 阅读 · 0 评论