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"], |
| 10 | edition: "2021", |
Alan Stokes | a0e4296 | 2023-04-14 17:59:50 +0100 | [diff] [blame] | 11 | // Require unsafe blocks for inside unsafe functions. |
| 12 | flags: ["-Dunsafe_op_in_unsafe_fn"], |
Pierre-Clément Tosi | e8726e4 | 2022-10-17 13:35:27 +0100 | [diff] [blame] | 13 | features: [ |
| 14 | "legacy", |
Jakob Vukalovic | 4c1edbe | 2023-04-17 19:10:57 +0100 | [diff] [blame] | 15 | "cpu_feat_hafdbs", |
Pierre-Clément Tosi | e8726e4 | 2022-10-17 13:35:27 +0100 | [diff] [blame] | 16 | ], |
Andrew Walbran | f259488 | 2022-03-15 17:32:53 +0000 | [diff] [blame] | 17 | rustlibs: [ |
Pierre-Clément Tosi | a8a4a20 | 2022-11-03 14:16:46 +0000 | [diff] [blame] | 18 | "libaarch64_paging", |
Pierre-Clément Tosi | 90cd4f1 | 2023-02-17 11:19:56 +0000 | [diff] [blame] | 19 | "libbssl_ffi_nostd", |
Pierre-Clément Tosi | fc53115 | 2022-10-20 12:22:23 +0100 | [diff] [blame] | 20 | "libbuddy_system_allocator", |
Alan Stokes | d1ee63e | 2023-04-24 16:17:39 +0100 | [diff] [blame] | 21 | "libciborium_nostd", |
| 22 | "libciborium_io_nostd", |
Alice Wang | cb9d2f9 | 2023-02-06 10:29:00 +0000 | [diff] [blame] | 23 | "libdiced_open_dice_nostd", |
Andrew Walbran | 730375d | 2022-12-21 14:04:34 +0000 | [diff] [blame] | 24 | "libfdtpci", |
Alice Wang | 0bdc3f6 | 2023-03-15 10:46:12 +0000 | [diff] [blame] | 25 | "libhyp", |
Pierre-Clément Tosi | a0934c1 | 2022-11-25 20:54:11 +0000 | [diff] [blame] | 26 | "liblibfdt", |
Pierre-Clément Tosi | 37105a6 | 2022-10-18 12:21:48 +0100 | [diff] [blame] | 27 | "liblog_rust_nostd", |
Andrew Walbran | b398fc8 | 2023-01-24 14:45:46 +0000 | [diff] [blame] | 28 | "libonce_cell_nostd", |
Andrew Walbran | 9afab67 | 2023-04-17 14:26:23 +0000 | [diff] [blame] | 29 | "libpsci", |
Pierre-Clément Tosi | 2d65298 | 2023-01-09 19:30:17 +0000 | [diff] [blame] | 30 | "libpvmfw_avb_nostd", |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 31 | "libpvmfw_embedded_key", |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 32 | "libpvmfw_fdt_template", |
Pierre-Clément Tosi | 1cc5eb7 | 2023-02-02 11:09:18 +0000 | [diff] [blame] | 33 | "libstatic_assertions", |
Pierre-Clément Tosi | 328dfb6 | 2022-11-25 18:20:42 +0000 | [diff] [blame] | 34 | "libtinyvec_nostd", |
Pierre-Clément Tosi | 1cc5eb7 | 2023-02-02 11:09:18 +0000 | [diff] [blame] | 35 | "libuuid_nostd", |
Andrew Walbran | d1d0318 | 2022-12-09 18:20:01 +0000 | [diff] [blame] | 36 | "libvirtio_drivers", |
Andrew Walbran | dd74b90 | 2022-04-14 16:12:50 +0000 | [diff] [blame] | 37 | "libvmbase", |
Alan Stokes | a0e4296 | 2023-04-14 17:59:50 +0100 | [diff] [blame] | 38 | "libzerocopy_nostd", |
Pierre-Clément Tosi | 8383c54 | 2022-11-01 14:07:29 +0000 | [diff] [blame] | 39 | "libzeroize_nostd", |
Jakob Vukalovic | 85a00d7 | 2023-04-20 09:51:10 +0100 | [diff] [blame] | 40 | "libspin_nostd", |
Andrew Walbran | f259488 | 2022-03-15 17:32:53 +0000 | [diff] [blame] | 41 | ], |
Andrew Walbran | 68a8c16 | 2022-03-07 15:38:42 +0000 | [diff] [blame] | 42 | } |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 43 | |
Alice Wang | 1c7e0eb | 2023-04-11 17:03:42 +0000 | [diff] [blame] | 44 | // Generates an empty file. |
| 45 | genrule { |
| 46 | name: "empty_file", |
| 47 | out: ["empty_file"], |
| 48 | cmd: "touch $(out)", |
| 49 | } |
| 50 | |
Jiyong Park | c5d2ef2 | 2023-04-11 01:23:46 +0900 | [diff] [blame] | 51 | rust_test { |
| 52 | name: "libpvmfw.bootargs.test", |
| 53 | host_supported: true, |
| 54 | // For now, only bootargs.rs is written to be conditionally compiled with std. |
| 55 | srcs: ["src/bootargs.rs"], |
| 56 | test_suites: ["general-tests"], |
| 57 | test_options: { |
| 58 | unit_test: true, |
| 59 | }, |
| 60 | rustlibs: [ |
| 61 | "libzeroize", |
| 62 | ], |
| 63 | } |
| 64 | |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 65 | cc_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 66 | name: "pvmfw", |
David Brazdil | 30a7f08 | 2022-07-07 15:30:14 +0100 | [diff] [blame] | 67 | defaults: ["vmbase_elf_defaults"], |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 68 | srcs: [ |
Andrew Walbran | 267f6c1 | 2022-03-24 11:26:36 +0000 | [diff] [blame] | 69 | "idmap.S", |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 70 | ], |
| 71 | static_libs: [ |
| 72 | "libpvmfw", |
| 73 | ], |
Andrew Walbran | a5b7af5 | 2022-07-06 15:06:20 +0000 | [diff] [blame] | 74 | linker_scripts: [ |
| 75 | "image.ld", |
| 76 | ":vmbase_sections", |
| 77 | ], |
Jiyong Park | 17b8d75 | 2022-12-16 14:36:24 +0900 | [diff] [blame] | 78 | // `installable: false` is inherited from vmbase_elf_defaults, and that |
| 79 | // hides this module from Make, which makes it impossible for the Make world |
| 80 | // to place the unstripped binary to the symbols directory. Marking back as |
| 81 | // installable exposes this module to the Make world again. Note that this |
| 82 | // module (pvmfw) still is NOT installed to any of the filesystem images. It |
| 83 | // is fed into pvmfw_bin and then into pvmfw_img to become a standalone |
| 84 | // partition image. This is just to package the unstripped file into the |
| 85 | // symbols zip file for debugging purpose. |
| 86 | installable: true, |
Nikita Ioffe | 831b08b | 2023-03-13 21:18:40 +0000 | [diff] [blame] | 87 | native_coverage: false, |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 88 | } |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 89 | |
| 90 | raw_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 91 | name: "pvmfw_bin", |
| 92 | stem: "pvmfw.bin", |
| 93 | src: ":pvmfw", |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 94 | enabled: false, |
| 95 | target: { |
| 96 | android_arm64: { |
| 97 | enabled: true, |
| 98 | }, |
| 99 | }, |
| 100 | } |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 101 | |
Jaewan Kim | 2cf6f39 | 2023-02-10 01:35:47 +0900 | [diff] [blame] | 102 | // Provide pvmfw.bin binary regardless of the architecture for building test. |
| 103 | // Note that skipping tests on unsupported device is easy |
| 104 | // while configuring server configuration to make such tests to run on working |
| 105 | // devices. |
| 106 | prebuilt_etc { |
| 107 | name: "pvmfw_test", |
| 108 | filename: "pvmfw_test.bin", |
| 109 | target: { |
| 110 | android_arm64: { |
| 111 | src: ":pvmfw_bin", |
| 112 | }, |
| 113 | }, |
Alice Wang | 1c7e0eb | 2023-04-11 17:03:42 +0000 | [diff] [blame] | 114 | src: ":empty_file", |
Jaewan Kim | 2cf6f39 | 2023-02-10 01:35:47 +0900 | [diff] [blame] | 115 | installable: false, |
| 116 | } |
| 117 | |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 118 | prebuilt_etc { |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 119 | name: "pvmfw_embedded_key", |
| 120 | src: ":avb_testkey_rsa4096_pub_bin", |
| 121 | installable: false, |
| 122 | } |
| 123 | |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 124 | genrule { |
| 125 | name: "pvmfw_embedded_key_rs", |
| 126 | srcs: [":pvmfw_embedded_key"], |
| 127 | out: ["lib.rs"], |
| 128 | cmd: "(" + |
| 129 | " echo '#![no_std]';" + |
| 130 | " echo '#![allow(missing_docs)]';" + |
| 131 | " echo 'pub const PUBLIC_KEY: &[u8] = &[';" + |
| 132 | " xxd -i < $(in);" + |
| 133 | " echo '];';" + |
| 134 | ") > $(out)", |
| 135 | } |
| 136 | |
| 137 | rust_library_rlib { |
| 138 | name: "libpvmfw_embedded_key", |
| 139 | defaults: ["vmbase_ffi_defaults"], |
| 140 | prefer_rlib: true, |
| 141 | srcs: [":pvmfw_embedded_key_rs"], |
| 142 | crate_name: "pvmfw_embedded_key", |
| 143 | apex_available: ["com.android.virt"], |
| 144 | } |
| 145 | |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 146 | prebuilt_etc { |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 147 | name: "pvmfw_sign_key", |
| 148 | src: ":avb_testkey_rsa4096", |
| 149 | installable: false, |
| 150 | } |
| 151 | |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 152 | // platform.dts is passed to clang for macro preprocessing, and then compiled to dtbo using dtc. |
| 153 | // The raw content of the dtbo file is then written as a Rust byte array. |
| 154 | genrule { |
| 155 | name: "pvmfw_fdt_template_rs", |
| 156 | srcs: [ |
| 157 | "platform.dts", |
| 158 | ":arm_dt_bindings_headers", // implicit dependency |
| 159 | ], |
| 160 | out: ["lib.rs"], |
| 161 | tools: ["dtc"], |
Yi Kong | 8ba2eb4 | 2023-05-19 20:04:16 +0000 | [diff] [blame] | 162 | cmd: "prebuilts/clang/host/linux-x86/clang-r487747c/bin/clang " + // UGLY!!! |
Jiyong Park | 216793e | 2023-02-25 02:15:44 +0900 | [diff] [blame] | 163 | "-E -P -x assembler-with-cpp -I external/arm-trusted-firmware/include " + |
| 164 | "-o $(genDir)/preprocessed.dts $(location platform.dts) && " + |
| 165 | "$(location dtc) -I dts -O dtb -o $(genDir)/compiled.dtbo $(genDir)/preprocessed.dts && " + |
| 166 | "(" + |
| 167 | " echo '#![no_std]';" + |
| 168 | " echo '#![allow(missing_docs)]';" + |
| 169 | " echo 'pub const RAW: &[u8] = &[';" + |
| 170 | " xxd -i < $(genDir)/compiled.dtbo;" + |
| 171 | " echo '];';" + |
| 172 | ") > $(out)", |
| 173 | } |
| 174 | |
| 175 | rust_library_rlib { |
| 176 | name: "libpvmfw_fdt_template", |
| 177 | defaults: ["vmbase_ffi_defaults"], |
| 178 | prefer_rlib: true, |
| 179 | srcs: [":pvmfw_fdt_template_rs"], |
| 180 | crate_name: "pvmfw_fdt_template", |
| 181 | } |
| 182 | |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 183 | bootimg { |
| 184 | name: "pvmfw_img", |
| 185 | stem: "pvmfw.img", |
| 186 | kernel_prebuilt: ":pvmfw_bin", |
| 187 | header_version: "3", |
| 188 | partition_name: "pvmfw", |
| 189 | enabled: false, |
| 190 | target: { |
| 191 | android_arm64: { |
| 192 | enabled: true, |
| 193 | }, |
| 194 | }, |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 195 | use_avb: true, |
| 196 | avb_private_key: ":pvmfw_sign_key", |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 197 | } |