blob: 48e9297c75bfb78460753fc07c9cee59ee2b73a5 [file] [log] [blame]
Igor Opaniuk6d0043a2018-06-03 21:56:43 +03001Android Verified Boot 2.0
2
3This file contains information about the current support of Android Verified
4Boot 2.0 in U-boot
5
61. OVERVIEW
7---------------------------------
8Verified Boot establishes a chain of trust from the bootloader to system images
9* Provides integrity checking for:
10 - Android Boot image: Linux kernel + ramdisk. RAW hashing of the whole
11 partition is done and the hash is compared with the one stored in
12 the VBMeta image
13 - system/vendor partitions: verifying root hash of dm-verity hashtrees.
14* Provides capabilities for rollback protection.
15
16Integrity of the bootloader (U-boot BLOB and environment) is out of scope.
17
18For additional details check:
19https://android.googlesource.com/platform/external/avb/+/master/README.md
20
Jens Wiklander6663e072018-09-25 16:40:20 +0200211.1. AVB using OP-TEE (optional)
22---------------------------------
23If AVB is configured to use OP-TEE (see 4. below) rollback indexes and
24device lock state are stored in RPMB. The RPMB partition is managed by
25OP-TEE (https://www.op-tee.org/) which is a secure OS leveraging ARM
26TrustZone.
27
Igor Opaniuk6d0043a2018-06-03 21:56:43 +030028
292. AVB 2.0 U-BOOT SHELL COMMANDS
30-----------------------------------
31Provides CLI interface to invoke AVB 2.0 verification + misc. commands for
32different testing purposes:
33
34avb init <dev> - initialize avb 2.0 for <dev>
35avb verify - run verification process using hash data from vbmeta structure
36avb read_rb <num> - read rollback index at location <num>
37avb write_rb <num> <rb> - write rollback index <rb> to <num>
38avb is_unlocked - returns unlock status of the device
39avb get_uuid <partname> - read and print uuid of partition <partname>
40avb read_part <partname> <offset> <num> <addr> - read <num> bytes from
41partition <partname> to buffer <addr>
42avb write_part <partname> <offset> <num> <addr> - write <num> bytes to
43<partname> by <offset> using data from <addr>
44
45
463. PARTITIONS TAMPERING (EXAMPLE)
47-----------------------------------
48Boot or system/vendor (dm-verity metadata section) is tampered:
49=> avb init 1
50=> avb verify
51avb_slot_verify.c:175: ERROR: boot: Hash of data does not match digest in
52descriptor.
53Slot verification result: ERROR_IO
54
55Vbmeta partition is tampered:
56=> avb init 1
57=> avb verify
58avb_vbmeta_image.c:206: ERROR: Hash does not match!
59avb_slot_verify.c:388: ERROR: vbmeta: Error verifying vbmeta image:
60HASH_MISMATCH
61Slot verification result: ERROR_IO
62
63
644. ENABLE ON YOUR BOARD
65-----------------------------------
66The following options must be enabled:
67CONFIG_LIBAVB=y
Igor Opaniukb0aa74a2018-07-17 14:33:25 +030068CONFIG_AVB_VERIFY=y
Igor Opaniuk6d0043a2018-06-03 21:56:43 +030069CONFIG_CMD_AVB=y
70
Jens Wiklander6663e072018-09-25 16:40:20 +020071In addtion optionally if storing rollback indexes in RPMB with help of
72OP-TEE:
73CONFIG_TEE=y
74CONFIG_OPTEE=y
75CONFIG_OPTEE_TA_AVB=y
76CONFIG_SUPPORT_EMMC_RPMB=y
Igor Opaniuk6d0043a2018-06-03 21:56:43 +030077
78Then add `avb verify` invocation to your android boot sequence of commands,
79e.g.:
80
81=> avb_verify=avb init $mmcdev; avb verify;
82=> if run avb_verify; then \
83 echo AVB verification OK. Continue boot; \
84 set bootargs $bootargs $avb_bootargs; \
85 else \
86 echo AVB verification failed; \
87 exit; \
88 fi; \
89
90=> emmc_android_boot= \
91 echo Trying to boot Android from eMMC ...; \
92 ... \
93 run avb_verify; \
94 mmc read ${fdtaddr} ${fdt_start} ${fdt_size}; \
95 mmc read ${loadaddr} ${boot_start} ${boot_size}; \
96 bootm $loadaddr $loadaddr $fdtaddr; \
97
Sam Protsenko965ec3c2019-10-21 13:55:16 +030098If partitions you want to verify are slotted (have A/B suffixes), then current
99slot suffix should be passed to 'avb verify' sub-command, e.g.:
100
101=> avb verify _a
Igor Opaniuk6d0043a2018-06-03 21:56:43 +0300102
103To switch on automatic generation of vbmeta partition in AOSP build, add these
104lines to device configuration mk file:
105
106BOARD_AVB_ENABLE := true
107BOARD_AVB_ALGORITHM := SHA512_RSA4096
108BOARD_BOOTIMAGE_PARTITION_SIZE := <boot partition size>
109
110After flashing U-boot don't forget to update environment and write new
111partition table:
112=> env default -f -a
113=> setenv partitions $partitions_android
114=> env save
115=> gpt write mmc 1 $partitions_android