blob: 238b48c90fa9cbb78d9bc7f25249f7f0ecca50f9 [file] [log] [blame]
Igor Opaniuka2846322018-06-03 21:56:42 +03001# Copyright (c) 2018, Linaro Limited
2#
3# SPDX-License-Identifier: GPL-2.0+
4#
5# Android Verified Boot 2.0 Test
6
7"""
Michal Simek50fa1182023-05-17 09:17:16 +02008This tests Android Verified Boot 2.0 support in U-Boot:
Igor Opaniuka2846322018-06-03 21:56:42 +03009
10For additional details about how to build proper vbmeta partition
Sam Protsenkocd43fa12020-01-24 17:53:44 +020011check doc/android/avb2.rst
Igor Opaniuka2846322018-06-03 21:56:42 +030012
13For configuration verification:
14- Corrupt boot partition and check for failure
15- Corrupt vbmeta partition and check for failure
16"""
17
18import pytest
19import u_boot_utils as util
20
21# defauld mmc id
22mmc_dev = 1
23temp_addr = 0x90000000
24temp_addr2 = 0x90002000
25
Tom Rini1ba07812019-10-24 11:59:18 -040026@pytest.mark.buildconfigspec('cmd_avb')
27@pytest.mark.buildconfigspec('cmd_mmc')
Igor Opaniuka2846322018-06-03 21:56:42 +030028def test_avb_verify(u_boot_console):
29 """Run AVB 2.0 boot verification chain with avb subset of commands
30 """
31
32 success_str = "Verification passed successfully"
33
34 response = u_boot_console.run_command('avb init %s' %str(mmc_dev))
35 assert response == ''
36 response = u_boot_console.run_command('avb verify')
37 assert response.find(success_str)
38
39
Tom Rini1ba07812019-10-24 11:59:18 -040040@pytest.mark.buildconfigspec('cmd_avb')
41@pytest.mark.buildconfigspec('cmd_mmc')
Simon Glass461b7912023-01-06 08:52:19 -060042@pytest.mark.notbuildconfigspec('sandbox')
Igor Opaniuka2846322018-06-03 21:56:42 +030043def test_avb_mmc_uuid(u_boot_console):
44 """Check if 'avb get_uuid' works, compare results with
45 'part list mmc 1' output
46 """
47
48 response = u_boot_console.run_command('avb init %s' % str(mmc_dev))
49 assert response == ''
50
51 response = u_boot_console.run_command('mmc rescan; mmc dev %s' %
52 str(mmc_dev))
53 assert response.find('is current device')
54
55 part_lines = u_boot_console.run_command('mmc part').splitlines()
56 part_list = {}
Simon Glasse9f4d872018-12-27 08:11:13 -070057 cur_partname = ''
Igor Opaniuka2846322018-06-03 21:56:42 +030058
59 for line in part_lines:
Simon Glasse9f4d872018-12-27 08:11:13 -070060 if '"' in line:
61 start_pt = line.find('"')
62 end_pt = line.find('"', start_pt + 1)
Igor Opaniuka2846322018-06-03 21:56:42 +030063 cur_partname = line[start_pt + 1: end_pt]
64
Simon Glasse9f4d872018-12-27 08:11:13 -070065 if 'guid:' in line:
66 guid_to_check = line.split('guid:\t')
Igor Opaniuka2846322018-06-03 21:56:42 +030067 part_list[cur_partname] = guid_to_check[1]
68
69 # lets check all guids with avb get_guid
Simon Glassf7990762022-02-11 13:23:23 -070070 for part, guid in part_list.items():
Igor Opaniuka2846322018-06-03 21:56:42 +030071 avb_guid_resp = u_boot_console.run_command('avb get_uuid %s' % part)
Simon Glasse9f4d872018-12-27 08:11:13 -070072 assert guid == avb_guid_resp.split('UUID: ')[1]
Igor Opaniuka2846322018-06-03 21:56:42 +030073
74
Tom Rini6c03ea12018-06-18 19:04:25 -040075@pytest.mark.buildconfigspec('cmd_avb')
Igor Opaniuka2846322018-06-03 21:56:42 +030076def test_avb_read_rb(u_boot_console):
77 """Test reading rollback indexes
78 """
79
80 response = u_boot_console.run_command('avb init %s' % str(mmc_dev))
81 assert response == ''
82
83 response = u_boot_console.run_command('avb read_rb 1')
Jens Wiklander404dee12018-09-25 16:40:21 +020084 assert response == 'Rollback index: 0'
Igor Opaniuka2846322018-06-03 21:56:42 +030085
86
Tom Rini6c03ea12018-06-18 19:04:25 -040087@pytest.mark.buildconfigspec('cmd_avb')
Igor Opaniuka2846322018-06-03 21:56:42 +030088def test_avb_is_unlocked(u_boot_console):
89 """Test if device is in the unlocked state
90 """
91
92 response = u_boot_console.run_command('avb init %s' % str(mmc_dev))
93 assert response == ''
94
95 response = u_boot_console.run_command('avb is_unlocked')
Jens Wiklander404dee12018-09-25 16:40:21 +020096 assert response == 'Unlocked = 1'
Igor Opaniuka2846322018-06-03 21:56:42 +030097
98
Tom Rini1ba07812019-10-24 11:59:18 -040099@pytest.mark.buildconfigspec('cmd_avb')
100@pytest.mark.buildconfigspec('cmd_mmc')
Simon Glass461b7912023-01-06 08:52:19 -0600101@pytest.mark.notbuildconfigspec('sandbox')
Igor Opaniuka2846322018-06-03 21:56:42 +0300102def test_avb_mmc_read(u_boot_console):
103 """Test mmc read operation
104 """
105
106 response = u_boot_console.run_command('mmc rescan; mmc dev %s 0' %
107 str(mmc_dev))
108 assert response.find('is current device')
109
110 response = u_boot_console.run_command('mmc read 0x%x 0x100 0x1' % temp_addr)
111 assert response.find('read: OK')
112
113 response = u_boot_console.run_command('avb init %s' % str(mmc_dev))
114 assert response == ''
115
116 response = u_boot_console.run_command('avb read_part xloader 0 100 0x%x' %
117 temp_addr2)
118 assert response.find('Read 512 bytes')
119
120 # Now lets compare two buffers
121 response = u_boot_console.run_command('cmp 0x%x 0x%x 40' %
122 (temp_addr, temp_addr2))
123 assert response.find('64 word')
Igor Opaniuk78b0b9d2019-04-09 15:38:14 +0200124
125
126@pytest.mark.buildconfigspec('cmd_avb')
127@pytest.mark.buildconfigspec('optee_ta_avb')
128def test_avb_persistent_values(u_boot_console):
129 """Test reading/writing persistent storage to avb
130 """
131
132 response = u_boot_console.run_command('avb init %s' % str(mmc_dev))
133 assert response == ''
134
135 response = u_boot_console.run_command('avb write_pvalue test value_value')
136 assert response == 'Wrote 12 bytes'
137
138 response = u_boot_console.run_command('avb read_pvalue test 12')
139 assert response == 'Read 12 bytes, value = value_value'