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: [ |
| 76 | "liblibfdt", |
| 77 | "liblog_rust", |
| 78 | "libpvmfw_fdt_template", |
| 79 | ], |
| 80 | data: [ |
| 81 | ":test_pvmfw_devices_vm_dtbo", |
| 82 | ":test_pvmfw_devices_vm_dtbo_without_symbols", |
| 83 | ":test_pvmfw_devices_with_rng", |
| 84 | ":test_pvmfw_devices_with_rng_iommu", |
| 85 | ":test_pvmfw_devices_with_multiple_devices_iommus", |
| 86 | ":test_pvmfw_devices_with_iommu_sharing", |
| 87 | ":test_pvmfw_devices_with_iommu_id_conflict", |
| 88 | ], |
| 89 | // To use libpvmfw_fdt_template for testing |
| 90 | enabled: false, |
| 91 | target: { |
| 92 | android_arm64: { |
| 93 | enabled: true, |
| 94 | }, |
| 95 | }, |
| 96 | } |
| 97 | |
| 98 | rust_test { |
| 99 | name: "libpvmfw.dice.test", |
| 100 | srcs: ["src/dice.rs"], |
| 101 | defaults: ["libpvmfw.test.defaults"], |
| 102 | rustlibs: [ |
| 103 | "libcbor_util", |
| 104 | "libciborium", |
| 105 | "libdiced_open_dice_nostd", |
| 106 | "libpvmfw_avb_nostd", |
| 107 | ], |
| 108 | } |
| 109 | |
Jaewan Kim | c6e023b | 2023-10-12 15:11:05 +0900 | [diff] [blame] | 110 | genrule { |
| 111 | name: "test_pvmfw_devices_vm_dtbo", |
| 112 | defaults: ["dts_to_dtb"], |
| 113 | srcs: ["testdata/test_pvmfw_devices_vm_dtbo.dts"], |
| 114 | out: ["test_pvmfw_devices_vm_dtbo.dtbo"], |
| 115 | } |
| 116 | |
| 117 | genrule { |
| 118 | name: "test_pvmfw_devices_vm_dtbo_without_symbols", |
| 119 | defaults: ["dts_to_dtb"], |
| 120 | srcs: ["testdata/test_pvmfw_devices_vm_dtbo_without_symbols.dts"], |
| 121 | out: ["test_pvmfw_devices_vm_dtbo_without_symbols.dtbo"], |
| 122 | } |
| 123 | |
| 124 | genrule { |
| 125 | name: "test_pvmfw_devices_with_rng", |
| 126 | defaults: ["dts_to_dtb"], |
| 127 | srcs: ["testdata/test_pvmfw_devices_with_rng.dts"], |
| 128 | out: ["test_pvmfw_devices_with_rng.dtb"], |
| 129 | } |
| 130 | |
Jaewan Kim | 51ccfed | 2023-11-08 13:51:58 +0900 | [diff] [blame] | 131 | genrule { |
| 132 | name: "test_pvmfw_devices_with_rng_iommu", |
| 133 | defaults: ["dts_to_dtb"], |
| 134 | srcs: ["testdata/test_pvmfw_devices_with_rng_iommu.dts"], |
| 135 | out: ["test_pvmfw_devices_with_rng_iommu.dtb"], |
| 136 | } |
| 137 | |
| 138 | genrule { |
| 139 | name: "test_pvmfw_devices_with_multiple_devices_iommus", |
| 140 | defaults: ["dts_to_dtb"], |
| 141 | srcs: ["testdata/test_pvmfw_devices_with_multiple_devices_iommus.dts"], |
| 142 | out: ["test_pvmfw_devices_with_multiple_devices_iommus.dtb"], |
| 143 | } |
| 144 | |
| 145 | genrule { |
| 146 | name: "test_pvmfw_devices_with_iommu_sharing", |
| 147 | defaults: ["dts_to_dtb"], |
| 148 | srcs: ["testdata/test_pvmfw_devices_with_iommu_sharing.dts"], |
| 149 | out: ["test_pvmfw_devices_with_iommu_sharing.dtb"], |
| 150 | } |
| 151 | |
| 152 | genrule { |
| 153 | name: "test_pvmfw_devices_with_iommu_id_conflict", |
| 154 | defaults: ["dts_to_dtb"], |
| 155 | srcs: ["testdata/test_pvmfw_devices_with_iommu_id_conflict.dts"], |
| 156 | out: ["test_pvmfw_devices_with_iommu_id_conflict.dtb"], |
| 157 | } |
| 158 | |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 159 | cc_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 160 | name: "pvmfw", |
David Brazdil | 30a7f08 | 2022-07-07 15:30:14 +0100 | [diff] [blame] | 161 | defaults: ["vmbase_elf_defaults"], |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 162 | srcs: [ |
Andrew Walbran | 267f6c1 | 2022-03-24 11:26:36 +0000 | [diff] [blame] | 163 | "idmap.S", |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 164 | ], |
| 165 | static_libs: [ |
| 166 | "libpvmfw", |
| 167 | ], |
Andrew Walbran | a5b7af5 | 2022-07-06 15:06:20 +0000 | [diff] [blame] | 168 | linker_scripts: [ |
| 169 | "image.ld", |
| 170 | ":vmbase_sections", |
| 171 | ], |
Jiyong Park | 17b8d75 | 2022-12-16 14:36:24 +0900 | [diff] [blame] | 172 | // `installable: false` is inherited from vmbase_elf_defaults, and that |
| 173 | // hides this module from Make, which makes it impossible for the Make world |
| 174 | // to place the unstripped binary to the symbols directory. Marking back as |
| 175 | // installable exposes this module to the Make world again. Note that this |
| 176 | // module (pvmfw) still is NOT installed to any of the filesystem images. It |
| 177 | // is fed into pvmfw_bin and then into pvmfw_img to become a standalone |
| 178 | // partition image. This is just to package the unstripped file into the |
| 179 | // symbols zip file for debugging purpose. |
| 180 | installable: true, |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 181 | } |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 182 | |
| 183 | raw_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 184 | name: "pvmfw_bin", |
| 185 | stem: "pvmfw.bin", |
| 186 | src: ":pvmfw", |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 187 | enabled: false, |
| 188 | target: { |
| 189 | android_arm64: { |
| 190 | enabled: true, |
| 191 | }, |
| 192 | }, |
| 193 | } |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 194 | |
Jaewan Kim | 2cf6f39 | 2023-02-10 01:35:47 +0900 | [diff] [blame] | 195 | // Provide pvmfw.bin binary regardless of the architecture for building test. |
| 196 | // Note that skipping tests on unsupported device is easy |
| 197 | // while configuring server configuration to make such tests to run on working |
| 198 | // devices. |
| 199 | prebuilt_etc { |
| 200 | name: "pvmfw_test", |
| 201 | filename: "pvmfw_test.bin", |
| 202 | target: { |
| 203 | android_arm64: { |
| 204 | src: ":pvmfw_bin", |
| 205 | }, |
| 206 | }, |
Alice Wang | 1c7e0eb | 2023-04-11 17:03:42 +0000 | [diff] [blame] | 207 | src: ":empty_file", |
Jaewan Kim | 2cf6f39 | 2023-02-10 01:35:47 +0900 | [diff] [blame] | 208 | installable: false, |
| 209 | } |
| 210 | |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 211 | prebuilt_etc { |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 212 | name: "pvmfw_embedded_key", |
| 213 | src: ":avb_testkey_rsa4096_pub_bin", |
| 214 | installable: false, |
| 215 | } |
| 216 | |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 217 | genrule { |
| 218 | name: "pvmfw_embedded_key_rs", |
| 219 | srcs: [":pvmfw_embedded_key"], |
| 220 | out: ["lib.rs"], |
| 221 | cmd: "(" + |
| 222 | " echo '#![no_std]';" + |
| 223 | " echo '#![allow(missing_docs)]';" + |
| 224 | " echo 'pub const PUBLIC_KEY: &[u8] = &[';" + |
| 225 | " xxd -i < $(in);" + |
| 226 | " echo '];';" + |
| 227 | ") > $(out)", |
| 228 | } |
| 229 | |
| 230 | rust_library_rlib { |
| 231 | name: "libpvmfw_embedded_key", |
Pierre-Clément Tosi | 4894b43 | 2023-06-27 14:02:26 +0000 | [diff] [blame] | 232 | defaults: ["vmbase_rlib_defaults"], |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 233 | srcs: [":pvmfw_embedded_key_rs"], |
| 234 | crate_name: "pvmfw_embedded_key", |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 235 | } |
| 236 | |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 237 | prebuilt_etc { |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 238 | name: "pvmfw_sign_key", |
| 239 | src: ":avb_testkey_rsa4096", |
| 240 | installable: false, |
| 241 | } |
| 242 | |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 243 | // We need to rename *.dts into *.cpp as cc_object doesn't accept *.dts as an |
| 244 | // input |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 245 | genrule { |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 246 | name: "pvmfw_platform.dts.renamed", |
| 247 | srcs: ["platform.dts"], |
| 248 | out: ["out.cpp"], |
| 249 | cmd: "cp $(in) $(out)", |
| 250 | visibility: ["//visibility:private"], |
| 251 | } |
| 252 | |
| 253 | // Then run the macro processor to replace symbols like GIC_SPI into actual |
| 254 | // numbers defined in the ARM DT binding headers |
| 255 | cc_object { |
| 256 | name: "pvmfw_platform.dts.preprocessed", |
| 257 | header_libs: ["arm_dt_bindings_headers"], |
| 258 | host_supported: true, |
| 259 | srcs: [":pvmfw_platform.dts.renamed"], |
| 260 | cflags: [ |
| 261 | "-E", |
| 262 | "-P", |
| 263 | "-xassembler-with-cpp", // allow C preprocessor directives |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 264 | ], |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 265 | visibility: ["//visibility:private"], |
| 266 | } |
| 267 | |
| 268 | // Compile the preprocessed dts into binary and create a rust library source |
| 269 | // having the binary. |
| 270 | cc_genrule { |
| 271 | name: "pvmfw_fdt_template_rs", |
| 272 | srcs: [":pvmfw_platform.dts.preprocessed"], |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 273 | out: ["lib.rs"], |
| 274 | tools: ["dtc"], |
Jaewan Kim | 96411e9 | 2023-11-13 15:54:02 +0900 | [diff] [blame] | 275 | cmd: "$(location dtc) -@ -I dts -O dtb -o $(genDir)/compiled.dtbo $(in) && " + |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 276 | "(" + |
| 277 | " echo '#![no_std]';" + |
| 278 | " echo '#![allow(missing_docs)]';" + |
| 279 | " echo 'pub const RAW: &[u8] = &[';" + |
| 280 | " xxd -i < $(genDir)/compiled.dtbo;" + |
| 281 | " echo '];';" + |
| 282 | ") > $(out)", |
Jiyong Park | 9c1c818 | 2023-05-25 15:40:11 +0900 | [diff] [blame] | 283 | visibility: ["//visibility:private"], |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 284 | } |
| 285 | |
| 286 | rust_library_rlib { |
| 287 | name: "libpvmfw_fdt_template", |
Pierre-Clément Tosi | 4894b43 | 2023-06-27 14:02:26 +0000 | [diff] [blame] | 288 | defaults: ["vmbase_rlib_defaults"], |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 289 | srcs: [":pvmfw_fdt_template_rs"], |
| 290 | crate_name: "pvmfw_fdt_template", |
| 291 | } |
| 292 | |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 293 | bootimg { |
| 294 | name: "pvmfw_img", |
| 295 | stem: "pvmfw.img", |
| 296 | kernel_prebuilt: ":pvmfw_bin", |
| 297 | header_version: "3", |
| 298 | partition_name: "pvmfw", |
| 299 | enabled: false, |
| 300 | target: { |
| 301 | android_arm64: { |
| 302 | enabled: true, |
| 303 | }, |
| 304 | }, |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 305 | use_avb: true, |
| 306 | avb_private_key: ":pvmfw_sign_key", |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 307 | } |