Bob Badour | e8af284 | 2022-04-07 10:44:22 -0700 | [diff] [blame] | 1 | package { |
| 2 | default_applicable_licenses: ["Android-Apache-2.0"], |
| 3 | } |
| 4 | |
Andrew Walbran | 68a8c16 | 2022-03-07 15:38:42 +0000 | [diff] [blame] | 5 | rust_ffi_static { |
| 6 | name: "libpvmfw", |
| 7 | crate_name: "pvmfw", |
David Brazdil | 30a7f08 | 2022-07-07 15:30:14 +0100 | [diff] [blame] | 8 | defaults: ["vmbase_ffi_defaults"], |
Andrew Walbran | 68a8c16 | 2022-03-07 15:38:42 +0000 | [diff] [blame] | 9 | srcs: ["src/main.rs"], |
Pierre-Clément Tosi | e8726e4 | 2022-10-17 13:35:27 +0100 | [diff] [blame] | 10 | features: [ |
| 11 | "legacy", |
| 12 | ], |
Andrew Walbran | f259488 | 2022-03-15 17:32:53 +0000 | [diff] [blame] | 13 | rustlibs: [ |
Pierre-Clément Tosi | a8a4a20 | 2022-11-03 14:16:46 +0000 | [diff] [blame] | 14 | "libaarch64_paging", |
Alice Wang | 947f3f7 | 2023-09-29 09:04:07 +0000 | [diff] [blame] | 15 | "libbssl_avf_nostd", |
Pierre-Clément Tosi | 90cd4f1 | 2023-02-17 11:19:56 +0000 | [diff] [blame] | 16 | "libbssl_ffi_nostd", |
Alan Stokes | d1ee63e | 2023-04-24 16:17:39 +0100 | [diff] [blame] | 17 | "libciborium_nostd", |
| 18 | "libciborium_io_nostd", |
Pierre-Clément Tosi | 1bf532b | 2023-11-13 11:06:20 +0000 | [diff] [blame] | 19 | "libcstr", |
Alice Wang | cb9d2f9 | 2023-02-06 10:29:00 +0000 | [diff] [blame] | 20 | "libdiced_open_dice_nostd", |
Andrew Walbran | 730375d | 2022-12-21 14:04:34 +0000 | [diff] [blame] | 21 | "libfdtpci", |
Alice Wang | 0bdc3f6 | 2023-03-15 10:46:12 +0000 | [diff] [blame] | 22 | "libhyp", |
Pierre-Clément Tosi | a0934c1 | 2022-11-25 20:54:11 +0000 | [diff] [blame] | 23 | "liblibfdt", |
Pierre-Clément Tosi | 37105a6 | 2022-10-18 12:21:48 +0100 | [diff] [blame] | 24 | "liblog_rust_nostd", |
Andrew Walbran | b398fc8 | 2023-01-24 14:45:46 +0000 | [diff] [blame] | 25 | "libonce_cell_nostd", |
Pierre-Clément Tosi | 2d65298 | 2023-01-09 19:30:17 +0000 | [diff] [blame] | 26 | "libpvmfw_avb_nostd", |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 27 | "libpvmfw_embedded_key", |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 28 | "libpvmfw_fdt_template", |
Andrew Walbran | f44f160 | 2023-05-30 14:59:19 +0000 | [diff] [blame] | 29 | "libsmccc", |
Pierre-Clément Tosi | 1cc5eb7 | 2023-02-02 11:09:18 +0000 | [diff] [blame] | 30 | "libstatic_assertions", |
Pierre-Clément Tosi | 328dfb6 | 2022-11-25 18:20:42 +0000 | [diff] [blame] | 31 | "libtinyvec_nostd", |
Pierre-Clément Tosi | 1cc5eb7 | 2023-02-02 11:09:18 +0000 | [diff] [blame] | 32 | "libuuid_nostd", |
Andrew Walbran | d1d0318 | 2022-12-09 18:20:01 +0000 | [diff] [blame] | 33 | "libvirtio_drivers", |
Andrew Walbran | dd74b90 | 2022-04-14 16:12:50 +0000 | [diff] [blame] | 34 | "libvmbase", |
Alan Stokes | a0e4296 | 2023-04-14 17:59:50 +0100 | [diff] [blame] | 35 | "libzerocopy_nostd", |
Pierre-Clément Tosi | 8383c54 | 2022-11-01 14:07:29 +0000 | [diff] [blame] | 36 | "libzeroize_nostd", |
Andrew Walbran | f259488 | 2022-03-15 17:32:53 +0000 | [diff] [blame] | 37 | ], |
Andrew Walbran | 68a8c16 | 2022-03-07 15:38:42 +0000 | [diff] [blame] | 38 | } |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 39 | |
Alice Wang | 1c7e0eb | 2023-04-11 17:03:42 +0000 | [diff] [blame] | 40 | // Generates an empty file. |
| 41 | genrule { |
| 42 | name: "empty_file", |
| 43 | out: ["empty_file"], |
| 44 | cmd: "touch $(out)", |
| 45 | } |
| 46 | |
Alan Stokes | ddb988c | 2023-11-27 11:13:06 +0000 | [diff] [blame] | 47 | rust_defaults { |
| 48 | name: "libpvmfw.test.defaults", |
Nikita Ioffe | da1b273 | 2023-09-04 13:46:56 +0100 | [diff] [blame] | 49 | defaults: ["avf_build_flags_rust"], |
Jiyong Park | c5d2ef2 | 2023-04-11 01:23:46 +0900 | [diff] [blame] | 50 | test_suites: ["general-tests"], |
| 51 | test_options: { |
| 52 | unit_test: true, |
| 53 | }, |
Alan Stokes | ddb988c | 2023-11-27 11:13:06 +0000 | [diff] [blame] | 54 | prefer_rlib: true, |
Jiyong Park | c5d2ef2 | 2023-04-11 01:23:46 +0900 | [diff] [blame] | 55 | rustlibs: [ |
Pierre-Clément Tosi | 1bf532b | 2023-11-13 11:06:20 +0000 | [diff] [blame] | 56 | "libcstr", |
Alan Stokes | ddb988c | 2023-11-27 11:13:06 +0000 | [diff] [blame] | 57 | ], |
| 58 | } |
| 59 | |
| 60 | rust_test { |
| 61 | name: "libpvmfw.bootargs.test", |
| 62 | host_supported: true, |
| 63 | // For now, only bootargs.rs is written to be conditionally compiled with std. |
| 64 | srcs: ["src/bootargs.rs"], |
| 65 | defaults: ["libpvmfw.test.defaults"], |
| 66 | rustlibs: [ |
Jiyong Park | c5d2ef2 | 2023-04-11 01:23:46 +0900 | [diff] [blame] | 67 | "libzeroize", |
| 68 | ], |
| 69 | } |
| 70 | |
Alan Stokes | ddb988c | 2023-11-27 11:13:06 +0000 | [diff] [blame] | 71 | rust_test { |
| 72 | name: "libpvmfw.device_assignment.test", |
| 73 | srcs: ["src/device_assignment.rs"], |
| 74 | defaults: ["libpvmfw.test.defaults"], |
| 75 | rustlibs: [ |
Jaewan Kim | 52477ae | 2023-11-21 21:20:52 +0900 | [diff] [blame^] | 76 | "libhyp", |
Alan Stokes | ddb988c | 2023-11-27 11:13:06 +0000 | [diff] [blame] | 77 | "liblibfdt", |
| 78 | "liblog_rust", |
| 79 | "libpvmfw_fdt_template", |
| 80 | ], |
| 81 | data: [ |
| 82 | ":test_pvmfw_devices_vm_dtbo", |
| 83 | ":test_pvmfw_devices_vm_dtbo_without_symbols", |
| 84 | ":test_pvmfw_devices_with_rng", |
Alan Stokes | ddb988c | 2023-11-27 11:13:06 +0000 | [diff] [blame] | 85 | ":test_pvmfw_devices_with_multiple_devices_iommus", |
| 86 | ":test_pvmfw_devices_with_iommu_sharing", |
| 87 | ":test_pvmfw_devices_with_iommu_id_conflict", |
Jaewan Kim | 52477ae | 2023-11-21 21:20:52 +0900 | [diff] [blame^] | 88 | ":test_pvmfw_devices_without_device", |
Jaewan Kim | a67e36a | 2023-11-29 16:50:23 +0900 | [diff] [blame] | 89 | ":test_pvmfw_devices_without_iommus", |
Alan Stokes | ddb988c | 2023-11-27 11:13:06 +0000 | [diff] [blame] | 90 | ], |
| 91 | // To use libpvmfw_fdt_template for testing |
| 92 | enabled: false, |
| 93 | target: { |
| 94 | android_arm64: { |
| 95 | enabled: true, |
| 96 | }, |
| 97 | }, |
| 98 | } |
| 99 | |
| 100 | rust_test { |
| 101 | name: "libpvmfw.dice.test", |
| 102 | srcs: ["src/dice.rs"], |
| 103 | defaults: ["libpvmfw.test.defaults"], |
| 104 | rustlibs: [ |
| 105 | "libcbor_util", |
| 106 | "libciborium", |
| 107 | "libdiced_open_dice_nostd", |
| 108 | "libpvmfw_avb_nostd", |
| 109 | ], |
| 110 | } |
| 111 | |
Jaewan Kim | c6e023b | 2023-10-12 15:11:05 +0900 | [diff] [blame] | 112 | genrule { |
| 113 | name: "test_pvmfw_devices_vm_dtbo", |
| 114 | defaults: ["dts_to_dtb"], |
| 115 | srcs: ["testdata/test_pvmfw_devices_vm_dtbo.dts"], |
| 116 | out: ["test_pvmfw_devices_vm_dtbo.dtbo"], |
| 117 | } |
| 118 | |
| 119 | genrule { |
| 120 | name: "test_pvmfw_devices_vm_dtbo_without_symbols", |
| 121 | defaults: ["dts_to_dtb"], |
| 122 | srcs: ["testdata/test_pvmfw_devices_vm_dtbo_without_symbols.dts"], |
| 123 | out: ["test_pvmfw_devices_vm_dtbo_without_symbols.dtbo"], |
| 124 | } |
| 125 | |
Jaewan Kim | cb0d45d | 2023-11-30 15:40:12 +0900 | [diff] [blame] | 126 | genrule_defaults { |
| 127 | name: "test_device_assignment_dts_to_dtb", |
| 128 | defaults: ["dts_to_dtb"], |
| 129 | srcs: ["testdata/test_crosvm_dt_base.dtsi"], |
| 130 | } |
| 131 | |
Jaewan Kim | c6e023b | 2023-10-12 15:11:05 +0900 | [diff] [blame] | 132 | genrule { |
| 133 | name: "test_pvmfw_devices_with_rng", |
Jaewan Kim | cb0d45d | 2023-11-30 15:40:12 +0900 | [diff] [blame] | 134 | defaults: ["test_device_assignment_dts_to_dtb"], |
Jaewan Kim | c6e023b | 2023-10-12 15:11:05 +0900 | [diff] [blame] | 135 | srcs: ["testdata/test_pvmfw_devices_with_rng.dts"], |
| 136 | out: ["test_pvmfw_devices_with_rng.dtb"], |
| 137 | } |
| 138 | |
Jaewan Kim | 51ccfed | 2023-11-08 13:51:58 +0900 | [diff] [blame] | 139 | genrule { |
Jaewan Kim | a67e36a | 2023-11-29 16:50:23 +0900 | [diff] [blame] | 140 | name: "test_pvmfw_devices_without_iommus", |
Jaewan Kim | cb0d45d | 2023-11-30 15:40:12 +0900 | [diff] [blame] | 141 | defaults: ["test_device_assignment_dts_to_dtb"], |
Jaewan Kim | a67e36a | 2023-11-29 16:50:23 +0900 | [diff] [blame] | 142 | srcs: ["testdata/test_pvmfw_devices_without_iommus.dts"], |
| 143 | out: ["test_pvmfw_devices_without_iommus.dtb"], |
Jaewan Kim | 51ccfed | 2023-11-08 13:51:58 +0900 | [diff] [blame] | 144 | } |
| 145 | |
| 146 | genrule { |
Jaewan Kim | 52477ae | 2023-11-21 21:20:52 +0900 | [diff] [blame^] | 147 | name: "test_pvmfw_devices_without_device", |
| 148 | defaults: ["test_device_assignment_dts_to_dtb"], |
| 149 | srcs: ["testdata/test_pvmfw_devices_without_device.dts"], |
| 150 | out: ["test_pvmfw_devices_without_device.dtb"], |
| 151 | } |
| 152 | |
| 153 | genrule { |
Jaewan Kim | 51ccfed | 2023-11-08 13:51:58 +0900 | [diff] [blame] | 154 | name: "test_pvmfw_devices_with_multiple_devices_iommus", |
Jaewan Kim | cb0d45d | 2023-11-30 15:40:12 +0900 | [diff] [blame] | 155 | defaults: ["test_device_assignment_dts_to_dtb"], |
Jaewan Kim | 51ccfed | 2023-11-08 13:51:58 +0900 | [diff] [blame] | 156 | srcs: ["testdata/test_pvmfw_devices_with_multiple_devices_iommus.dts"], |
| 157 | out: ["test_pvmfw_devices_with_multiple_devices_iommus.dtb"], |
| 158 | } |
| 159 | |
| 160 | genrule { |
| 161 | name: "test_pvmfw_devices_with_iommu_sharing", |
Jaewan Kim | cb0d45d | 2023-11-30 15:40:12 +0900 | [diff] [blame] | 162 | defaults: ["test_device_assignment_dts_to_dtb"], |
Jaewan Kim | 51ccfed | 2023-11-08 13:51:58 +0900 | [diff] [blame] | 163 | srcs: ["testdata/test_pvmfw_devices_with_iommu_sharing.dts"], |
| 164 | out: ["test_pvmfw_devices_with_iommu_sharing.dtb"], |
| 165 | } |
| 166 | |
| 167 | genrule { |
| 168 | name: "test_pvmfw_devices_with_iommu_id_conflict", |
Jaewan Kim | cb0d45d | 2023-11-30 15:40:12 +0900 | [diff] [blame] | 169 | defaults: ["test_device_assignment_dts_to_dtb"], |
Jaewan Kim | 51ccfed | 2023-11-08 13:51:58 +0900 | [diff] [blame] | 170 | srcs: ["testdata/test_pvmfw_devices_with_iommu_id_conflict.dts"], |
| 171 | out: ["test_pvmfw_devices_with_iommu_id_conflict.dtb"], |
| 172 | } |
| 173 | |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 174 | cc_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 175 | name: "pvmfw", |
David Brazdil | 30a7f08 | 2022-07-07 15:30:14 +0100 | [diff] [blame] | 176 | defaults: ["vmbase_elf_defaults"], |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 177 | srcs: [ |
Andrew Walbran | 267f6c1 | 2022-03-24 11:26:36 +0000 | [diff] [blame] | 178 | "idmap.S", |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 179 | ], |
| 180 | static_libs: [ |
| 181 | "libpvmfw", |
| 182 | ], |
Andrew Walbran | a5b7af5 | 2022-07-06 15:06:20 +0000 | [diff] [blame] | 183 | linker_scripts: [ |
| 184 | "image.ld", |
| 185 | ":vmbase_sections", |
| 186 | ], |
Jiyong Park | 17b8d75 | 2022-12-16 14:36:24 +0900 | [diff] [blame] | 187 | // `installable: false` is inherited from vmbase_elf_defaults, and that |
| 188 | // hides this module from Make, which makes it impossible for the Make world |
| 189 | // to place the unstripped binary to the symbols directory. Marking back as |
| 190 | // installable exposes this module to the Make world again. Note that this |
| 191 | // module (pvmfw) still is NOT installed to any of the filesystem images. It |
| 192 | // is fed into pvmfw_bin and then into pvmfw_img to become a standalone |
| 193 | // partition image. This is just to package the unstripped file into the |
| 194 | // symbols zip file for debugging purpose. |
| 195 | installable: true, |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 196 | } |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 197 | |
| 198 | raw_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 199 | name: "pvmfw_bin", |
| 200 | stem: "pvmfw.bin", |
| 201 | src: ":pvmfw", |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 202 | enabled: false, |
| 203 | target: { |
| 204 | android_arm64: { |
| 205 | enabled: true, |
| 206 | }, |
| 207 | }, |
| 208 | } |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 209 | |
Jaewan Kim | 2cf6f39 | 2023-02-10 01:35:47 +0900 | [diff] [blame] | 210 | // Provide pvmfw.bin binary regardless of the architecture for building test. |
| 211 | // Note that skipping tests on unsupported device is easy |
| 212 | // while configuring server configuration to make such tests to run on working |
| 213 | // devices. |
| 214 | prebuilt_etc { |
| 215 | name: "pvmfw_test", |
| 216 | filename: "pvmfw_test.bin", |
| 217 | target: { |
| 218 | android_arm64: { |
| 219 | src: ":pvmfw_bin", |
| 220 | }, |
| 221 | }, |
Alice Wang | 1c7e0eb | 2023-04-11 17:03:42 +0000 | [diff] [blame] | 222 | src: ":empty_file", |
Jaewan Kim | 2cf6f39 | 2023-02-10 01:35:47 +0900 | [diff] [blame] | 223 | installable: false, |
| 224 | } |
| 225 | |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 226 | prebuilt_etc { |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 227 | name: "pvmfw_embedded_key", |
| 228 | src: ":avb_testkey_rsa4096_pub_bin", |
| 229 | installable: false, |
| 230 | } |
| 231 | |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 232 | genrule { |
| 233 | name: "pvmfw_embedded_key_rs", |
| 234 | srcs: [":pvmfw_embedded_key"], |
| 235 | out: ["lib.rs"], |
| 236 | cmd: "(" + |
| 237 | " echo '#![no_std]';" + |
| 238 | " echo '#![allow(missing_docs)]';" + |
| 239 | " echo 'pub const PUBLIC_KEY: &[u8] = &[';" + |
| 240 | " xxd -i < $(in);" + |
| 241 | " echo '];';" + |
| 242 | ") > $(out)", |
| 243 | } |
| 244 | |
| 245 | rust_library_rlib { |
| 246 | name: "libpvmfw_embedded_key", |
Pierre-Clément Tosi | 4894b43 | 2023-06-27 14:02:26 +0000 | [diff] [blame] | 247 | defaults: ["vmbase_rlib_defaults"], |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 248 | srcs: [":pvmfw_embedded_key_rs"], |
| 249 | crate_name: "pvmfw_embedded_key", |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 250 | } |
| 251 | |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 252 | prebuilt_etc { |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 253 | name: "pvmfw_sign_key", |
| 254 | src: ":avb_testkey_rsa4096", |
| 255 | installable: false, |
| 256 | } |
| 257 | |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 258 | // We need to rename *.dts into *.cpp as cc_object doesn't accept *.dts as an |
| 259 | // input |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 260 | genrule { |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 261 | name: "pvmfw_platform.dts.renamed", |
| 262 | srcs: ["platform.dts"], |
| 263 | out: ["out.cpp"], |
| 264 | cmd: "cp $(in) $(out)", |
| 265 | visibility: ["//visibility:private"], |
| 266 | } |
| 267 | |
| 268 | // Then run the macro processor to replace symbols like GIC_SPI into actual |
| 269 | // numbers defined in the ARM DT binding headers |
| 270 | cc_object { |
| 271 | name: "pvmfw_platform.dts.preprocessed", |
| 272 | header_libs: ["arm_dt_bindings_headers"], |
| 273 | host_supported: true, |
| 274 | srcs: [":pvmfw_platform.dts.renamed"], |
| 275 | cflags: [ |
| 276 | "-E", |
| 277 | "-P", |
| 278 | "-xassembler-with-cpp", // allow C preprocessor directives |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 279 | ], |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 280 | visibility: ["//visibility:private"], |
| 281 | } |
| 282 | |
| 283 | // Compile the preprocessed dts into binary and create a rust library source |
| 284 | // having the binary. |
| 285 | cc_genrule { |
| 286 | name: "pvmfw_fdt_template_rs", |
| 287 | srcs: [":pvmfw_platform.dts.preprocessed"], |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 288 | out: ["lib.rs"], |
| 289 | tools: ["dtc"], |
Jaewan Kim | 96411e9 | 2023-11-13 15:54:02 +0900 | [diff] [blame] | 290 | cmd: "$(location dtc) -@ -I dts -O dtb -o $(genDir)/compiled.dtbo $(in) && " + |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 291 | "(" + |
| 292 | " echo '#![no_std]';" + |
| 293 | " echo '#![allow(missing_docs)]';" + |
| 294 | " echo 'pub const RAW: &[u8] = &[';" + |
| 295 | " xxd -i < $(genDir)/compiled.dtbo;" + |
| 296 | " echo '];';" + |
| 297 | ") > $(out)", |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 298 | visibility: ["//visibility:private"], |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 299 | } |
| 300 | |
| 301 | rust_library_rlib { |
| 302 | name: "libpvmfw_fdt_template", |
Pierre-Clément Tosi | 4894b43 | 2023-06-27 14:02:26 +0000 | [diff] [blame] | 303 | defaults: ["vmbase_rlib_defaults"], |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 304 | srcs: [":pvmfw_fdt_template_rs"], |
| 305 | crate_name: "pvmfw_fdt_template", |
| 306 | } |
| 307 | |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 308 | bootimg { |
| 309 | name: "pvmfw_img", |
| 310 | stem: "pvmfw.img", |
| 311 | kernel_prebuilt: ":pvmfw_bin", |
| 312 | header_version: "3", |
| 313 | partition_name: "pvmfw", |
| 314 | enabled: false, |
| 315 | target: { |
| 316 | android_arm64: { |
| 317 | enabled: true, |
| 318 | }, |
| 319 | }, |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 320 | use_avb: true, |
| 321 | avb_private_key: ":pvmfw_sign_key", |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 322 | } |