Alice Wang | f3d96b1 | 2022-12-15 13:10:47 +0000 | [diff] [blame] | 1 | package { |
| 2 | default_applicable_licenses: ["Android-Apache-2.0"], |
| 3 | } |
| 4 | |
Pierre-Clément Tosi | 44e9f94 | 2023-06-27 14:33:56 +0000 | [diff] [blame] | 5 | rust_library_rlib { |
| 6 | name: "libpvmfw_avb_nostd", |
Alice Wang | f3d96b1 | 2022-12-15 13:10:47 +0000 | [diff] [blame] | 7 | crate_name: "pvmfw_avb", |
Nikita Ioffe | da1b273 | 2023-09-04 13:46:56 +0100 | [diff] [blame] | 8 | defaults: ["avf_build_flags_rust"], |
Alice Wang | f3d96b1 | 2022-12-15 13:10:47 +0000 | [diff] [blame] | 9 | srcs: ["src/lib.rs"], |
| 10 | prefer_rlib: true, |
| 11 | rustlibs: [ |
David Pursell | a7c727b | 2023-08-14 16:24:40 -0700 | [diff] [blame] | 12 | "libavb_rs_nostd", |
Alice Wang | f275286 | 2023-01-18 11:51:25 +0000 | [diff] [blame] | 13 | "libtinyvec_nostd", |
Alice Wang | f3d96b1 | 2022-12-15 13:10:47 +0000 | [diff] [blame] | 14 | ], |
Alice Wang | a78279c | 2022-12-16 12:41:19 +0000 | [diff] [blame] | 15 | whole_static_libs: [ |
Pierre-Clément Tosi | 69467e0 | 2023-02-01 13:35:15 +0000 | [diff] [blame] | 16 | "libavb_baremetal", |
Alice Wang | a78279c | 2022-12-16 12:41:19 +0000 | [diff] [blame] | 17 | ], |
Alice Wang | f3d96b1 | 2022-12-15 13:10:47 +0000 | [diff] [blame] | 18 | no_stdlibs: true, |
| 19 | stdlibs: [ |
| 20 | "libcore.rust_sysroot", |
| 21 | ], |
| 22 | } |
| 23 | |
| 24 | rust_test { |
Alice Wang | bf7fadd | 2023-01-13 12:18:24 +0000 | [diff] [blame] | 25 | name: "libpvmfw_avb.integration_test", |
| 26 | crate_name: "pvmfw_avb_test", |
Nikita Ioffe | da1b273 | 2023-09-04 13:46:56 +0100 | [diff] [blame] | 27 | defaults: ["avf_build_flags_rust"], |
Alan Stokes | d7aea45 | 2024-03-14 14:20:04 +0000 | [diff] [blame] | 28 | srcs: ["tests/api_test.rs"], |
Alice Wang | f3d96b1 | 2022-12-15 13:10:47 +0000 | [diff] [blame] | 29 | test_suites: ["general-tests"], |
Alice Wang | a78279c | 2022-12-16 12:41:19 +0000 | [diff] [blame] | 30 | data: [ |
| 31 | ":avb_testkey_rsa2048_pub_bin", |
| 32 | ":avb_testkey_rsa4096_pub_bin", |
| 33 | ":microdroid_kernel_signed", |
Alice Wang | 6b486f1 | 2023-01-06 13:12:16 +0000 | [diff] [blame] | 34 | ":microdroid_initrd_normal", |
Alice Wang | 4e55dd9 | 2023-01-11 10:17:01 +0000 | [diff] [blame] | 35 | ":microdroid_initrd_debuggable", |
Alice Wang | 6b486f1 | 2023-01-06 13:12:16 +0000 | [diff] [blame] | 36 | ":test_image_with_one_hashdesc", |
Alice Wang | 86383df | 2023-01-11 10:03:56 +0000 | [diff] [blame] | 37 | ":test_image_with_non_initrd_hashdesc", |
Alice Wang | f275286 | 2023-01-18 11:51:25 +0000 | [diff] [blame] | 38 | ":test_image_with_initrd_and_non_initrd_desc", |
Alice Wang | 86383df | 2023-01-11 10:03:56 +0000 | [diff] [blame] | 39 | ":test_image_with_prop_desc", |
Alice Wang | ab0d020 | 2023-05-17 08:07:41 +0000 | [diff] [blame] | 40 | ":test_image_with_service_vm_prop", |
| 41 | ":test_image_with_unknown_vm_type_prop", |
| 42 | ":test_image_with_multiple_props", |
| 43 | ":test_image_with_duplicated_capability", |
Shikha Panwar | a26f16a | 2023-09-27 09:39:00 +0000 | [diff] [blame] | 44 | ":test_image_with_rollback_index_5", |
Shikha Panwar | 4a0651d | 2023-09-28 13:06:13 +0000 | [diff] [blame] | 45 | ":test_image_with_multiple_capabilities", |
Nikolina Ilic | 57ba9c4 | 2024-10-01 09:50:48 +0000 | [diff] [blame^] | 46 | ":test_image_with_all_capabilities", |
Alice Wang | a78279c | 2022-12-16 12:41:19 +0000 | [diff] [blame] | 47 | ":unsigned_test_image", |
| 48 | ], |
Alice Wang | bf7fadd | 2023-01-13 12:18:24 +0000 | [diff] [blame] | 49 | prefer_rlib: true, |
Alice Wang | a78279c | 2022-12-16 12:41:19 +0000 | [diff] [blame] | 50 | rustlibs: [ |
| 51 | "libanyhow", |
Alice Wang | bf7fadd | 2023-01-13 12:18:24 +0000 | [diff] [blame] | 52 | "libavb_bindgen", |
David Pursell | a7c727b | 2023-08-14 16:24:40 -0700 | [diff] [blame] | 53 | "libavb_rs_nostd", |
Alice Wang | 1f0add0 | 2023-01-23 16:22:53 +0000 | [diff] [blame] | 54 | "libhex", |
Alice Wang | bf7fadd | 2023-01-13 12:18:24 +0000 | [diff] [blame] | 55 | "libpvmfw_avb_nostd", |
Alice Wang | 1f0add0 | 2023-01-23 16:22:53 +0000 | [diff] [blame] | 56 | "libopenssl", |
Alice Wang | a78279c | 2022-12-16 12:41:19 +0000 | [diff] [blame] | 57 | ], |
| 58 | enabled: false, |
| 59 | arch: { |
| 60 | // Microdroid kernel is only available in these architectures. |
| 61 | arm64: { |
| 62 | enabled: true, |
| 63 | }, |
| 64 | x86_64: { |
| 65 | enabled: true, |
| 66 | }, |
| 67 | }, |
| 68 | } |
| 69 | |
| 70 | // Generates a 16KB unsigned image for testing. |
| 71 | genrule { |
| 72 | name: "unsigned_test_image", |
| 73 | tools: ["avbtool"], |
| 74 | out: ["unsigned_test.img"], |
| 75 | cmd: "$(location avbtool) generate_test_image --image_size 16384 --output $(out)", |
Alice Wang | f3d96b1 | 2022-12-15 13:10:47 +0000 | [diff] [blame] | 76 | } |
Alice Wang | 6b486f1 | 2023-01-06 13:12:16 +0000 | [diff] [blame] | 77 | |
Alice Wang | 86383df | 2023-01-11 10:03:56 +0000 | [diff] [blame] | 78 | avb_gen_vbmeta_image { |
| 79 | name: "test_non_initrd_hashdesc", |
| 80 | src: ":unsigned_test_image", |
| 81 | partition_name: "non_initrd11", |
| 82 | salt: "2222", |
| 83 | } |
| 84 | |
| 85 | avb_add_hash_footer { |
| 86 | name: "test_image_with_non_initrd_hashdesc", |
| 87 | src: ":unsigned_test_image", |
| 88 | partition_name: "boot", |
| 89 | private_key: ":pvmfw_sign_key", |
Alice Wang | f275286 | 2023-01-18 11:51:25 +0000 | [diff] [blame] | 90 | salt: "3322", |
Alice Wang | 86383df | 2023-01-11 10:03:56 +0000 | [diff] [blame] | 91 | include_descriptors_from_images: [ |
| 92 | ":test_non_initrd_hashdesc", |
| 93 | ], |
| 94 | } |
| 95 | |
| 96 | avb_add_hash_footer { |
Alice Wang | f275286 | 2023-01-18 11:51:25 +0000 | [diff] [blame] | 97 | name: "test_image_with_initrd_and_non_initrd_desc", |
| 98 | src: ":unsigned_test_image", |
| 99 | partition_name: "boot", |
| 100 | private_key: ":pvmfw_sign_key", |
| 101 | salt: "3241", |
| 102 | include_descriptors_from_images: [ |
| 103 | ":microdroid_initrd_normal_hashdesc", |
| 104 | ":test_non_initrd_hashdesc", |
| 105 | ], |
| 106 | enabled: false, |
| 107 | arch: { |
| 108 | // microdroid_initrd_normal_hashdesc is only available in these architectures. |
| 109 | arm64: { |
| 110 | enabled: true, |
| 111 | }, |
| 112 | x86_64: { |
| 113 | enabled: true, |
| 114 | }, |
| 115 | }, |
| 116 | } |
| 117 | |
| 118 | avb_add_hash_footer { |
Alice Wang | 86383df | 2023-01-11 10:03:56 +0000 | [diff] [blame] | 119 | name: "test_image_with_prop_desc", |
| 120 | src: ":unsigned_test_image", |
| 121 | partition_name: "boot", |
| 122 | private_key: ":pvmfw_sign_key", |
Alice Wang | f275286 | 2023-01-18 11:51:25 +0000 | [diff] [blame] | 123 | salt: "2134", |
Alice Wang | 86383df | 2023-01-11 10:03:56 +0000 | [diff] [blame] | 124 | props: [ |
| 125 | { |
| 126 | name: "mock_prop", |
| 127 | value: "3333", |
| 128 | }, |
| 129 | ], |
| 130 | } |
| 131 | |
Alice Wang | 6b486f1 | 2023-01-06 13:12:16 +0000 | [diff] [blame] | 132 | avb_add_hash_footer { |
Alice Wang | ab0d020 | 2023-05-17 08:07:41 +0000 | [diff] [blame] | 133 | name: "test_image_with_service_vm_prop", |
| 134 | src: ":unsigned_test_image", |
| 135 | partition_name: "boot", |
| 136 | private_key: ":pvmfw_sign_key", |
| 137 | salt: "2131", |
| 138 | props: [ |
| 139 | { |
| 140 | name: "com.android.virt.cap", |
| 141 | value: "remote_attest", |
| 142 | }, |
| 143 | ], |
| 144 | } |
| 145 | |
| 146 | avb_add_hash_footer { |
| 147 | name: "test_image_with_unknown_vm_type_prop", |
| 148 | src: ":unsigned_test_image", |
| 149 | partition_name: "boot", |
| 150 | private_key: ":pvmfw_sign_key", |
| 151 | salt: "2132", |
| 152 | props: [ |
| 153 | { |
| 154 | name: "com.android.virt.cap", |
| 155 | value: "foo", |
| 156 | }, |
| 157 | ], |
| 158 | } |
| 159 | |
| 160 | avb_add_hash_footer { |
| 161 | name: "test_image_with_multiple_props", |
| 162 | src: ":unsigned_test_image", |
| 163 | partition_name: "boot", |
| 164 | private_key: ":pvmfw_sign_key", |
| 165 | salt: "2133", |
| 166 | props: [ |
| 167 | { |
| 168 | name: "com.android.virt.cap", |
| 169 | value: "remote_attest", |
| 170 | }, |
| 171 | { |
| 172 | name: "another_vm_type", |
| 173 | value: "foo_vm", |
| 174 | }, |
| 175 | ], |
| 176 | } |
| 177 | |
| 178 | avb_add_hash_footer { |
| 179 | name: "test_image_with_duplicated_capability", |
| 180 | src: ":unsigned_test_image", |
| 181 | partition_name: "boot", |
| 182 | private_key: ":pvmfw_sign_key", |
| 183 | salt: "2134", |
| 184 | props: [ |
| 185 | { |
| 186 | name: "com.android.virt.cap", |
| 187 | value: "remote_attest|remote_attest|remote_attest", |
| 188 | }, |
| 189 | ], |
| 190 | } |
| 191 | |
| 192 | avb_add_hash_footer { |
Alice Wang | 6b486f1 | 2023-01-06 13:12:16 +0000 | [diff] [blame] | 193 | name: "test_image_with_one_hashdesc", |
| 194 | src: ":unsigned_test_image", |
Alice Wang | 8aa3cb1 | 2023-01-11 09:04:04 +0000 | [diff] [blame] | 195 | partition_name: "boot", |
Alice Wang | 6b486f1 | 2023-01-06 13:12:16 +0000 | [diff] [blame] | 196 | private_key: ":pvmfw_sign_key", |
| 197 | salt: "1111", |
| 198 | } |
Shikha Panwar | a26f16a | 2023-09-27 09:39:00 +0000 | [diff] [blame] | 199 | |
| 200 | avb_add_hash_footer { |
| 201 | name: "test_image_with_rollback_index_5", |
| 202 | src: ":unsigned_test_image", |
| 203 | partition_name: "boot", |
| 204 | private_key: ":pvmfw_sign_key", |
| 205 | salt: "1211", |
| 206 | rollback_index: 5, |
| 207 | } |
Shikha Panwar | 4a0651d | 2023-09-28 13:06:13 +0000 | [diff] [blame] | 208 | |
| 209 | avb_add_hash_footer { |
| 210 | name: "test_image_with_multiple_capabilities", |
| 211 | src: ":unsigned_test_image", |
| 212 | partition_name: "boot", |
| 213 | private_key: ":pvmfw_sign_key", |
| 214 | salt: "2134", |
| 215 | props: [ |
| 216 | { |
| 217 | name: "com.android.virt.cap", |
| 218 | value: "remote_attest|secretkeeper_protection", |
| 219 | }, |
| 220 | ], |
| 221 | } |
Nikolina Ilic | 57ba9c4 | 2024-10-01 09:50:48 +0000 | [diff] [blame^] | 222 | |
| 223 | avb_add_hash_footer { |
| 224 | name: "test_image_with_all_capabilities", |
| 225 | src: ":unsigned_test_image", |
| 226 | partition_name: "boot", |
| 227 | private_key: ":pvmfw_sign_key", |
| 228 | salt: "4231", |
| 229 | props: [ |
| 230 | { |
| 231 | name: "com.android.virt.cap", |
| 232 | value: "remote_attest|secretkeeper_protection|supports_uefi_boot", |
| 233 | }, |
| 234 | ], |
| 235 | } |