AndroidFOTA升级流程
Android设备的系统升级有两种⽅式:(1)下载更新包到⼿机后,⼿动安装,即所谓“卡刷包”的形式更新;(2) 通过 Over-the-
air(OTA)的⽅式更新系统,简称为FOTA(Firmware Over The Air),FOTA升级有两种⽅式,⼀种是Full update,即将整个IMG置于升级包中,然后将升级包直接拷贝到系统;⼀种是Increamental update,即通过增量式的差分包,只是将系统更新的部分打包,然后以打补丁的形式应⽤到系统。
在介绍FOTA升级流程之前,先来看看Android系统的分区。⼀般,Android系统有如下⼏个分区(不同⼚商、设备可能有差异):
/boot: ⽤于系统启动的分区,主要包括Kernel和ramdisk。主要⽤于挂载system和其他分区,并加载system分区的代码。没有该分区,⼿机是⽆法正常启动的;
ramdisk.img is a small partition image that is mounted read-only by the kernel at boot time. It only contains /init and a few config files. It is used to start init which will mount the rest of the system images properly and run the init
procedure. A Ramdisk is a standard Linux feature.
/system:该分区包含了出了 kernel/ramdisk之外的系统应⽤程序和库⽂件;正常操作情况下,该分区是只读状态;
/recovery:⽤于系统升级打补丁,包含了⼀个完整的Linux操作系统和⼀个特殊的recovery包。FOTA升级时,下载完更新包后,进⼊recovery模式,recovery程序会读更新包,然后将各个patch应⽤到各个分区;
/misc:升级时,recovery⽤于存储相关信息的⼩分区
/data:主要包含了⽤户的数据,如联系⼈、短信、设置以及安装的应⽤。清除该分区等同于将⼿机重置,OTA不会影响该分区;
/cache:⽤于存放需要经常访问使⽤的数据和应⽤组件,访问该分区需要特殊的应⽤程序权限;OTA升级时下载的升级包就位于该分区;
FOTA升级流程
1. 设备定时检查FOTA服务器是否有更新;如有更新,服务其发送消息(包括更新包URL,以及关于该更新包的描述)通知设备
2. 更新程序下载升级包到 cache 或者 data 分区,并验证升级包的签名证书(证书位于/system/etc/security/otacerts.zip),验证通过后,
通知⽤户准备安装
3. 设备重启⾄ recovery模式,此时启动的是recovery分区的kernel/system
4. init进程通过脚本: service recovery /sbin/recovery 启动 recovery程序
5. 执⾏ /cache/recovery/command中的脚本命令,将其指向于升级包:
"/sbin/recovery""--update_package=/cache/fota/update.zip"
6. recovery⾸先校验升级包的签名是否与 /res/keys (ramdisk)中的公钥相匹配
7. recovery通过FOTA中的脚本解析更新包,然后将修改分别更新到对应的boot/system等分区;在系统分区包含的新⽂件包含了⽤于
更新recovery分区的内容
8. 系统正常重启:
1. 启动更新后的boot/system 分区
2. 启动时,系统检查当前recovery分区和需要更新的recovery分区(事先保存在/system分区),如果有差异,则更新recovery
分区
制作android软件流程9. 设备通知FOTA服务器升级完成
参考⽂献
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论