Android 分区升级学习总结

Android13已经要求强制开启AB分区升级,不再使用之前的recovery模式升级

主要的回调函数区别:

回调函数 核心关注 触发阶段 典型用途
onUpdaterStateChange 更新器状态流转 状态切换时 控制 UI 流程(如页面跳转)
onEngineStatusUpdate 引擎内部状态 引擎状态变化时 判断当前处于下载/校验/写入等阶段
onEnginePayloadApplicationComplete 写入结果 写入完成后 判断成功/失败,决定是否重启
onProgressUpdate 进度数值 持续更新中 刷新进度条

onUpdaterStateChange

对应如下几种状态:

java 复制代码
UpdaterState.java
   public static final int IDLE = 0;
    public static final int ERROR = 1;
    public static final int RUNNING = 2;
    public static final int PAUSED = 3;
    public static final int SLOT_SWITCH_REQUIRED = 4;
    public static final int REBOOT_REQUIRED = 5;

有些场景会出现看不到IDLE,RUNNING 回调。

onEngineStatusUpdate

对应引擎内部状态

java 复制代码
UpdateEngineStatuses.java

 public static final int STATUS_UPDATED_NEED_REBOOT = 6;

    static {
        STATUS_MAP.put(0, "IDLE");
        STATUS_MAP.put(1, "CHECKING_FOR_UPDATE");
        STATUS_MAP.put(2, "UPDATE_AVAILABLE");
        STATUS_MAP.put(3, "DOWNLOADING");
        STATUS_MAP.put(4, "VERIFYING");
        STATUS_MAP.put(5, "FINALIZING");
        STATUS_MAP.put(6, "UPDATED_NEED_REBOOT");
        STATUS_MAP.put(7, "REPORTING_ERROR_EVENT");
        STATUS_MAP.put(8, "ATTEMPTING_ROLLBACK");
        STATUS_MAP.put(9, "DISABLED");
    }

上图,状态11可忽略。

完整的状态参考:

java 复制代码
system/update_engine/client_library/include/update_engine/update_status.h

enum class UpdateStatus {
  IDLE = 0,
  CHECKING_FOR_UPDATE = 1,
  UPDATE_AVAILABLE = 2,
  DOWNLOADING = 3,
  VERIFYING = 4,
  FINALIZING = 5,
  UPDATED_NEED_REBOOT = 6,
  REPORTING_ERROR_EVENT = 7,
  ATTEMPTING_ROLLBACK = 8,
  DISABLED = 9,
  // Broadcast this state when an update aborts because user preferences do not
  // allow updates, e.g. over cellular network.
  NEED_PERMISSION_TO_UPDATE = 10,
  CLEANUP_PREVIOUS_UPDATE = 11,

  // This value is exclusively used in Chrome. DO NOT define nor use it.
  // TODO(crbug.com/977320): Remove this value from chrome by refactoring the
  // Chrome code and evantually from here. This is not really an operation or
  // state that the update_engine stays on. This is the result of an internal
  // failure and should be reflected differently.
  // ERROR = -1,
};

onEnginePayloadApplicationComplete

对应引擎内部的执行结果。

java 复制代码
UpdateEngineErrorCodes.java

    static {
        CODE_TO_NAME_MAP.put(0, "SUCCESS");
        CODE_TO_NAME_MAP.put(1, "ERROR");
        CODE_TO_NAME_MAP.put(4, "FILESYSTEM_COPIER_ERROR");
        CODE_TO_NAME_MAP.put(5, "POST_INSTALL_RUNNER_ERROR");
        CODE_TO_NAME_MAP.put(6, "PAYLOAD_MISMATCHED_TYPE_ERROR");
        CODE_TO_NAME_MAP.put(7, "INSTALL_DEVICE_OPEN_ERROR");
        CODE_TO_NAME_MAP.put(8, "KERNEL_DEVICE_OPEN_ERROR");
        CODE_TO_NAME_MAP.put(9, "DOWNLOAD_TRANSFER_ERROR");
        CODE_TO_NAME_MAP.put(10, "PAYLOAD_HASH_MISMATCH_ERROR");
        CODE_TO_NAME_MAP.put(11, "PAYLOAD_SIZE_MISMATCH_ERROR");
        CODE_TO_NAME_MAP.put(12, "DOWNLOAD_PAYLOAD_VERIFICATION_ERROR");
        CODE_TO_NAME_MAP.put(15, "NEW_ROOTFS_VERIFICATION_ERROR");
        CODE_TO_NAME_MAP.put(20, "DOWNLOAD_STATE_INITIALIZATION_ERROR");
        CODE_TO_NAME_MAP.put(26, "DOWNLOAD_METADATA_SIGNATURE_MISMATCH");
        CODE_TO_NAME_MAP.put(29, "DOWNLOAD_METADATA_HASH_MISMATCH");
        CODE_TO_NAME_MAP.put(48, "USER_CANCELLED");
        CODE_TO_NAME_MAP.put(52, "UPDATED_BUT_NOT_ACTIVE");
    }

onProgressUpdate

对应每一步的状态和进度。

典型调用顺序

onUpdaterStateChange(CHECKING)

→ onEngineStatusUpdate(CHECKING_FOR_UPDATE)

→ onUpdaterStateChange(DOWNLOADING)

→ onEngineStatusUpdate(DOWNLOADING)

→ onProgressUpdate(10%) ... onProgressUpdate(100%)

→ onEngineStatusUpdate(VERIFYING)

→ onEngineStatusUpdate(FINALIZING)

→ onEnginePayloadApplicationComplete(SUCCESS)

→ onUpdaterStateChange(COMPLETE)

log 分析

1 升级成功log

05-08 10:51:47.214 19141 19165 com.example.android.systemupdatersample D UpdateManager onStatusUpdate invoked, status=3, progress=0.67

这只是表示在status=3 (下载状态)的0.67进度

2. 升级包不匹配

相关推荐
龙仔7251 小时前
【麒麟V10系统 SSH自动防暴力破解(失败3次封IP)完整配置笔记】
笔记·tcp/ip·ssh·防攻击
情绪总是阴雨天~1 小时前
Flask Web 开发入门笔记
笔记·flask
今儿敲了吗1 小时前
数据库(四)——关系数据库SQL语言
数据库·笔记·sql
问心无愧05131 小时前
ctf show web入门31
前端·笔记
远离UE41 小时前
Forward+ & Deferred+学习笔记
笔记·数码相机·学习
Hua-Jay1 小时前
OpenCV联合C++/Qt 学习笔记(十六)----图像细化、轮廓检测、轮廓信息统计及轮廓外接多边形
c++·笔记·qt·opencv·学习·计算机视觉
谙弆悕博士1 小时前
Fortran学习笔记
经验分享·笔记·学习·职场和发展·跳槽·学习方法·fortran
50万马克的面包2 小时前
C语言:三大基础排序算法模板 冒泡 / 选择 / 插入)
c语言·笔记·算法·排序算法
西梅汁2 小时前
C++ 桥接模式(结构型)
笔记