Android Safety 系列专题【篇二:AVB签名】

Android AVB(Android Verified Boot ,安卓验证启动)是 Google 为 Android 系统设计的一套安全机制,用于确保设备在启动过程中加载的系统软件(如 bootloader、内核、system 分区等)是经过授权且未被篡改的。其核心目标是 防止恶意软件在启动阶段植入系统 ,并支持 防回滚(anti-rollback) 保护。其核心功能主要如下两个:

  • 验证启动:从只读固件开始,在加载和执行代码前进行密码学验证,确保代码是真实的且没有已知安全漏洞。
  • 完整性保护:通过密码学签名和哈希验证,确保系统分区(如 boot.img、system.img、vendor.img 等)未被篡改。

1、AVB校验机制

AVB的几个重要主要组件如下:

  • VBMeta 结构:核心数据结构,包含哈希描述符(Hash Descriptors),用于验证整个分区;哈希树描述符(Hashtree Descriptors),用于验证文件系统分区;链式分区描述符(Chained Partition Descriptors),用于授权委托。
  • avbtool:用于创建和操作验证启动镜像的工具,主要生成 vbmeta.img。
  • libavb:设备端验证库,在引导加载程序和 Android 系统中执行验证。

1)AVB工作流程

AVB的工作流程主要如下:

  • Boot ROM 验证 Primary Bootloader(PBL)(通常由芯片厂商实现)。
  • Bootloader(如 ABL / U-Boot) 启动后:
  • 读取 vbmeta 分区(或从其他分区提取 VBMeta 数据)
  • 使用内置公钥验证 VBMeta 签名。
  • 检查各分区(boot, system, vendor 等)的哈希值是否匹配。
  • 检查 rollback index 是否 ≥ 设备当前记录的值。
  • 若全部验证通过:
    • 加载 boot 分区(含 kernel + ramdisk)。
    • 启动 Android 系统。
  • 若验证失败:
    • Locked 状态:设备拒绝启动(可能进入 recovery 或死循环)。
    • Unlocked 状态:显示警告,但仍允许启动(用于开发者调试)。

2)AVB与Secure Boot的区别?

从使用目的来看AVB和Secure boot,都是为了防止镜像被篡改,那么他们到底有什么区别呢?

  • 针对AP侧镜像的安全校验和镜像签名,就是所谓的google avb机制。因为AP侧镜像基本上都是由Google AOSP设计,因此需要使用Google的AVB(Android Verified Boot)特性来保证镜像的完整性和真实性。

  • 针对BP侧镜像的安全校验和镜像签名,就是所谓的Secure Boot机制。因为这些都是厂商自己设计,通常的做法是这些厂商在自己的芯片内部是有一个硬件单元的,只能一次烧录,是不可逆的,烧录的东西和root key密切相关,efuse被熔断了,那么root key就不能改变,同时这块芯片只能运行和root key相关的key签名的镜像。

相关推荐
黄林晴20 小时前
用了这么久 Koin Scope,原来一直都用错了?
android·kotlin
爱勇宝1 天前
我做了一个只用来搜歌词的小 App
android·前端·后端
众少成多积小致巨2 天前
JNI (Java Native Interface) 技术手册中文参考指南
android·java·c++
Coffeeee2 天前
如何使用Glide和Coil加载WebP动图
android·kotlin·glide
Kapaseker2 天前
5 分钟搞懂 Kotlin DSL
android·kotlin
恋猫de小郭2 天前
AI Agent 开发究竟是啥?如何用 AI 开发 Agent ?深入浅出给你一套概念
android·前端·ai编程
黄林晴2 天前
Android 17 正式发布!target 37 一大批旧代码直接不能用了
android
Carson带你学Android2 天前
Android 17 正式发布:AI 终于成了系统能力
android·前端·ai编程
三少爷的鞋2 天前
当 UseCase 开始长期监听,它可能已经不是 UseCase 了
android
恋猫de小郭2 天前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter