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", |
Pierre-Clément Tosi | e8726e4 | 2022-10-17 13:35:27 +0100 | [diff] [blame] | 11 | features: [ |
| 12 | "legacy", |
| 13 | ], |
Andrew Walbran | f259488 | 2022-03-15 17:32:53 +0000 | [diff] [blame] | 14 | rustlibs: [ |
Pierre-Clément Tosi | a8a4a20 | 2022-11-03 14:16:46 +0000 | [diff] [blame] | 15 | "libaarch64_paging", |
Pierre-Clément Tosi | fc53115 | 2022-10-20 12:22:23 +0100 | [diff] [blame] | 16 | "libbuddy_system_allocator", |
Alice Wang | cb9d2f9 | 2023-02-06 10:29:00 +0000 | [diff] [blame] | 17 | "libdice_nostd", // TODO(b/267575445): Remove this library once the migration is done. |
| 18 | "libdiced_open_dice_nostd", |
Andrew Walbran | 730375d | 2022-12-21 14:04:34 +0000 | [diff] [blame] | 19 | "libfdtpci", |
Pierre-Clément Tosi | a0934c1 | 2022-11-25 20:54:11 +0000 | [diff] [blame] | 20 | "liblibfdt", |
Pierre-Clément Tosi | 37105a6 | 2022-10-18 12:21:48 +0100 | [diff] [blame] | 21 | "liblog_rust_nostd", |
Andrew Walbran | b398fc8 | 2023-01-24 14:45:46 +0000 | [diff] [blame] | 22 | "libonce_cell_nostd", |
Pierre-Clément Tosi | 2d65298 | 2023-01-09 19:30:17 +0000 | [diff] [blame] | 23 | "libpvmfw_avb_nostd", |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 24 | "libpvmfw_embedded_key", |
Pierre-Clément Tosi | 328dfb6 | 2022-11-25 18:20:42 +0000 | [diff] [blame] | 25 | "libtinyvec_nostd", |
Andrew Walbran | d1d0318 | 2022-12-09 18:20:01 +0000 | [diff] [blame] | 26 | "libvirtio_drivers", |
Andrew Walbran | dd74b90 | 2022-04-14 16:12:50 +0000 | [diff] [blame] | 27 | "libvmbase", |
Pierre-Clément Tosi | 8383c54 | 2022-11-01 14:07:29 +0000 | [diff] [blame] | 28 | "libzeroize_nostd", |
Andrew Walbran | f259488 | 2022-03-15 17:32:53 +0000 | [diff] [blame] | 29 | ], |
Andrew Walbran | 68a8c16 | 2022-03-07 15:38:42 +0000 | [diff] [blame] | 30 | } |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 31 | |
| 32 | cc_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 33 | name: "pvmfw", |
David Brazdil | 30a7f08 | 2022-07-07 15:30:14 +0100 | [diff] [blame] | 34 | defaults: ["vmbase_elf_defaults"], |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 35 | srcs: [ |
Andrew Walbran | 267f6c1 | 2022-03-24 11:26:36 +0000 | [diff] [blame] | 36 | "idmap.S", |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 37 | ], |
| 38 | static_libs: [ |
| 39 | "libpvmfw", |
| 40 | ], |
Andrew Walbran | a5b7af5 | 2022-07-06 15:06:20 +0000 | [diff] [blame] | 41 | linker_scripts: [ |
| 42 | "image.ld", |
| 43 | ":vmbase_sections", |
| 44 | ], |
Jiyong Park | 17b8d75 | 2022-12-16 14:36:24 +0900 | [diff] [blame] | 45 | // `installable: false` is inherited from vmbase_elf_defaults, and that |
| 46 | // hides this module from Make, which makes it impossible for the Make world |
| 47 | // to place the unstripped binary to the symbols directory. Marking back as |
| 48 | // installable exposes this module to the Make world again. Note that this |
| 49 | // module (pvmfw) still is NOT installed to any of the filesystem images. It |
| 50 | // is fed into pvmfw_bin and then into pvmfw_img to become a standalone |
| 51 | // partition image. This is just to package the unstripped file into the |
| 52 | // symbols zip file for debugging purpose. |
| 53 | installable: true, |
Andrew Walbran | 15068b0 | 2022-03-22 15:57:34 +0000 | [diff] [blame] | 54 | } |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 55 | |
| 56 | raw_binary { |
Pierre-Clément Tosi | b130035 | 2022-09-09 11:01:06 +0100 | [diff] [blame] | 57 | name: "pvmfw_bin", |
| 58 | stem: "pvmfw.bin", |
| 59 | src: ":pvmfw", |
David Brazdil | 05d4e07 | 2022-04-25 14:47:06 +0100 | [diff] [blame] | 60 | enabled: false, |
| 61 | target: { |
| 62 | android_arm64: { |
| 63 | enabled: true, |
| 64 | }, |
| 65 | }, |
| 66 | } |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 67 | |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 68 | prebuilt_etc { |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 69 | name: "pvmfw_embedded_key", |
| 70 | src: ":avb_testkey_rsa4096_pub_bin", |
| 71 | installable: false, |
| 72 | } |
| 73 | |
Pierre-Clément Tosi | 4ef7522 | 2022-10-26 17:40:50 +0100 | [diff] [blame] | 74 | genrule { |
| 75 | name: "pvmfw_embedded_key_rs", |
| 76 | srcs: [":pvmfw_embedded_key"], |
| 77 | out: ["lib.rs"], |
| 78 | cmd: "(" + |
| 79 | " echo '#![no_std]';" + |
| 80 | " echo '#![allow(missing_docs)]';" + |
| 81 | " echo 'pub const PUBLIC_KEY: &[u8] = &[';" + |
| 82 | " xxd -i < $(in);" + |
| 83 | " echo '];';" + |
| 84 | ") > $(out)", |
| 85 | } |
| 86 | |
| 87 | rust_library_rlib { |
| 88 | name: "libpvmfw_embedded_key", |
| 89 | defaults: ["vmbase_ffi_defaults"], |
| 90 | prefer_rlib: true, |
| 91 | srcs: [":pvmfw_embedded_key_rs"], |
| 92 | crate_name: "pvmfw_embedded_key", |
| 93 | apex_available: ["com.android.virt"], |
| 94 | } |
| 95 | |
Pierre-Clément Tosi | 6ec2ae2 | 2022-10-26 15:14:45 +0100 | [diff] [blame] | 96 | prebuilt_etc { |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 97 | name: "pvmfw_sign_key", |
| 98 | src: ":avb_testkey_rsa4096", |
| 99 | installable: false, |
| 100 | } |
| 101 | |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 102 | bootimg { |
| 103 | name: "pvmfw_img", |
| 104 | stem: "pvmfw.img", |
| 105 | kernel_prebuilt: ":pvmfw_bin", |
| 106 | header_version: "3", |
| 107 | partition_name: "pvmfw", |
| 108 | enabled: false, |
| 109 | target: { |
| 110 | android_arm64: { |
| 111 | enabled: true, |
| 112 | }, |
| 113 | }, |
Pierre-Clément Tosi | b5771c0 | 2022-09-06 16:01:35 +0100 | [diff] [blame] | 114 | use_avb: true, |
| 115 | avb_private_key: ":pvmfw_sign_key", |
David Brazdil | ac216b5 | 2022-04-25 15:07:22 +0100 | [diff] [blame] | 116 | } |