blob: ecaadf827993d01c6efe2ddbac74a5187f8b6f35 [file] [log] [blame]
Bob Badour2efc4762021-02-03 18:36:27 -08001package {
2 default_applicable_licenses: ["Android-Apache-2.0"],
3}
4
Inseob Kimdc2af862021-02-17 15:51:56 +09005microdroid_shell_and_utilities = [
6 "reboot",
7 "sh",
Victor Hsieh1ef3cb72021-07-21 08:49:10 -07008 "strace",
Inseob Kimdc2af862021-02-17 15:51:56 +09009 "toolbox",
10 "toybox",
11]
12
Inseob Kim5ffc0822021-02-09 21:23:36 +090013microdroid_rootdirs = [
14 "dev",
15 "proc",
16 "sys",
17
Inseob Kim5ffc0822021-02-09 21:23:36 +090018 "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +090019 "vendor",
Inseob Kim5ffc0822021-02-09 21:23:36 +090020 "debug_ramdisk",
21 "mnt",
Inseob Kimafd9dc02021-04-23 14:47:44 +090022 "data",
Inseob Kim5ffc0822021-02-09 21:23:36 +090023
24 "apex",
25 "linkerconfig",
26 "second_stage_resources",
Inseob Kim5ffc0822021-02-09 21:23:36 +090027]
28
29microdroid_symlinks = [
30 {
31 target: "/sys/kernel/debug",
32 name: "d",
33 },
Inseob Kim13ca2c82021-04-23 09:12:29 +090034 {
35 target: "/system/etc",
36 name: "etc",
37 },
Inseob Kim4e207a12021-08-04 03:36:47 +000038 {
39 target: "/system/bin",
40 name: "bin",
41 },
Inseob Kim5ffc0822021-02-09 21:23:36 +090042]
43
Jiyong Park92199ce2021-04-16 21:35:58 +090044android_system_image {
Jiyong Parkb552bb62021-01-25 19:12:47 +090045 name: "microdroid",
46 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +090047 avb_private_key: ":microdroid_sign_key",
Jiyong Parkb552bb62021-01-25 19:12:47 +090048 avb_algorithm: "SHA256_RSA4096",
Shikha Panwar85620722022-12-21 15:38:14 +000049 avb_hash_algorithm: "sha256",
Jiyong Parkd4326f32021-03-15 23:25:46 +090050 partition_name: "system",
Jiyong Parkb552bb62021-01-25 19:12:47 +090051 deps: [
52 "init_second_stage",
Inseob Kim23ce1582021-04-06 21:25:57 +090053 "microdroid_build_prop",
Jiyong Park40699612021-05-24 16:55:06 +090054 "microdroid_init_rc",
Jiyong Park4d228952021-10-18 18:28:57 +090055 "microdroid_ueventd_rc",
Jiyong Park40699612021-05-24 16:55:06 +090056 "microdroid_launcher",
Jooyung Han7ce2e532021-06-16 16:52:02 +090057
Inseob Kimdc2af862021-02-17 15:51:56 +090058 "libbinder",
Jooyung Han837eef52021-05-15 11:33:48 +090059 "libbinder_ndk",
Inseob Kimdc2af862021-02-17 15:51:56 +090060 "libstdc++",
Inseob Kimdc2af862021-02-17 15:51:56 +090061 "secilc",
Jooyung Han017916b2021-04-20 03:57:19 +090062
63 // "com.android.adbd" requires these,
64 "libadbd_auth",
65 "libadbd_fs",
66
Jooyung Han730b7b82021-05-12 14:09:38 +090067 // "com.android.art" requires
68 "heapprofd_client_api",
Victor Hsieh527b81d2021-06-11 10:41:11 -070069 "libartpalette-system",
Jooyung Han730b7b82021-05-12 14:09:38 +090070
Jooyung Hanb6a52152022-12-12 11:20:23 +090071 "apexd.microdroid",
Oleg Matcovschidca4c2c2022-03-14 06:29:44 -070072 "atrace",
Inseob Kimdc2af862021-02-17 15:51:56 +090073 "debuggerd",
74 "linker",
Nikita Ioffe664697c2022-10-24 15:22:33 +010075 "tombstoned.microdroid",
Shikha Panwar7afc1392022-03-24 08:54:43 +000076 "tombstone_transmit.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090077 "cgroups.json",
Inseob Kime60307a2022-04-14 03:48:38 +090078 "task_profiles.json",
Jooyung Han1c820732021-04-15 05:16:23 +090079 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090080
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070081 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090082 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070083 "microdroid_manifest",
84 "microdroid_plat_sepolicy_and_mapping.sha256",
Inseob Kimff43be22021-06-07 16:56:56 +090085 "microdroid_property_contexts",
Shikha Panwar5cb5b992022-12-12 11:51:07 +000086 "mke2fs.microdroid",
Jooyung Han8a17ef72021-08-04 15:39:54 +090087
Jooyung Hana704cbc2022-04-05 14:57:27 +090088 // TODO(b/195425111) these should be added automatically
89 "libcrypto", // used by many (init_second_stage, microdroid_manager, toybox, etc)
90 "liblzma", // used by init_second_stage
Alice Wang2e57b082022-10-27 10:39:01 +000091
92 "libvm_payload", // used by payload to interact with microdroid manager
Jiyong Park61eebed2022-12-20 19:24:48 +090093
Jiyong Park5f7ae032022-12-22 10:24:39 +090094 "prng_seeder_microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090095 ] + microdroid_shell_and_utilities,
96 multilib: {
97 common: {
98 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +090099 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900100 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900101
Inseob Kimff43be22021-06-07 16:56:56 +0900102 "microdroid_plat_sepolicy.cil",
103 "microdroid_plat_mapping_file",
Jiyong Park9117f012022-07-07 15:24:06 +0900104 "microdroid_crashdump_initrd",
Inseob Kimdc2af862021-02-17 15:51:56 +0900105 ],
106 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900107 lib64: {
108 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900109 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700110 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700111 "authfs_service",
Shikha Panwar566c9672022-11-15 14:39:58 +0000112 "encryptedstore",
Jiyong Park9e5ae632022-07-08 14:47:23 +0900113 "microdroid_crashdump_kernel",
114 "microdroid_kexec",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900115 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900116 "zipfuse",
117 ],
118 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900119 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900120 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900121 base_dir: "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +0900122 dirs: microdroid_rootdirs,
123 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900124 file_contexts: ":microdroid_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900125 // For deterministic output, use fake_timestamp, hard-coded uuid
126 fake_timestamp: "1611569676",
127 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/system'))"
128 uuid: "5fe079c6-f01a-52be-87d3-d415231a72ad",
Jiyong Parkb552bb62021-01-25 19:12:47 +0900129}
Jiyong Park153d3552021-02-04 08:54:31 +0900130
Inseob Kimdc2af862021-02-17 15:51:56 +0900131prebuilt_etc {
132 name: "microdroid_init_rc",
133 filename: "init.rc",
134 src: "init.rc",
135 relative_install_path: "init/hw",
136 installable: false, // avoid collision with system partition's init.rc
137}
138
Jiyong Park4d228952021-10-18 18:28:57 +0900139prebuilt_etc {
140 name: "microdroid_ueventd_rc",
141 filename: "ueventd.rc",
142 src: "ueventd.rc",
143 installable: false, // avoid collision with system partition's ueventd.rc
144}
145
Inseob Kim23ce1582021-04-06 21:25:57 +0900146prebuilt_root {
147 name: "microdroid_build_prop",
148 filename: "build.prop",
149 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900150 arch: {
151 x86_64: {
152 src: ":microdroid_build_prop_gen_x86_64",
153 },
154 arm64: {
155 src: ":microdroid_build_prop_gen_arm64",
156 },
157 },
Inseob Kim23ce1582021-04-06 21:25:57 +0900158 installable: false,
159}
160
Jiyong Park68f560c2021-05-24 17:38:27 +0900161genrule {
162 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900163 srcs: [
164 "build.prop",
165 ":buildinfo.prop",
166 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900167 out: ["build.prop.out"],
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900168 cmd: "(echo '# build properties from buildinfo.prop module' && " +
169 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
170 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
171 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
172 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
Jiyong Park71215c62022-06-21 10:46:55 +0900173 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900174 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900175 "echo ro.product.cpu.abilist=x86_64 && " +
176 "echo ro.product.cpu.abi=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900177}
178
179genrule {
180 name: "microdroid_build_prop_gen_arm64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900181 srcs: [
182 "build.prop",
183 ":buildinfo.prop",
184 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900185 out: ["build.prop.out"],
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900186 cmd: "(echo '# build properties from buildinfo.prop module' && " +
187 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
188 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
189 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
190 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
Jiyong Park71215c62022-06-21 10:46:55 +0900191 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900192 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900193 "echo ro.product.cpu.abilist=arm64-v8a && " +
194 "echo ro.product.cpu.abi=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900195}
196
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000197android_filesystem {
198 name: "microdroid_vendor",
Jiyong Park52ea0832021-09-01 12:10:18 +0900199 partition_name: "vendor",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000200 use_avb: true,
201 deps: [
Inseob Kimafd9dc02021-04-23 14:47:44 +0900202 "microdroid_fstab",
Inseob Kim28dddd82021-03-11 17:51:22 +0900203 "microdroid_precompiled_sepolicy.plat_sepolicy_and_mapping.sha256",
Inseob Kim8f095c92021-05-26 12:04:54 +0900204 "microdroid_vendor_manifest",
205 "microdroid_vendor_compatibility_matrix",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000206 ],
Inseob Kimabcd10a2021-03-25 15:43:07 +0900207 multilib: {
208 common: {
209 deps: [
210 "microdroid_vendor_sepolicy.cil",
211 "microdroid_plat_pub_versioned.cil",
Inseob Kimcd06dca2021-04-30 00:19:00 +0900212 "microdroid_plat_sepolicy_vers.txt",
Inseob Kim998c27f2021-09-27 13:44:09 +0000213 "microdroid_precompiled_sepolicy",
Inseob Kimabcd10a2021-03-25 15:43:07 +0900214 ],
215 },
216 },
Jooyung Hand35952e2021-11-08 17:53:47 +0900217 avb_private_key: ":microdroid_sign_key",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000218 avb_algorithm: "SHA256_RSA4096",
Shikha Panwar85620722022-12-21 15:38:14 +0000219 avb_hash_algorithm: "sha256",
Inseob Kimff43be22021-06-07 16:56:56 +0900220 file_contexts: ":microdroid_vendor_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900221 // For deterministic output, use fake_timestamp, hard-coded uuid
222 fake_timestamp: "1611569676",
223 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/vendor'))"
224 uuid: "156d40d7-8d8e-5c99-8913-ec82de549a70",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000225}
226
Jiyong Parkc1500e82021-02-24 01:39:51 +0900227logical_partition {
228 name: "microdroid_super",
229 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900230 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900231 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900232 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900233 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900234 filesystem: ":microdroid",
235 },
236 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900237 name: "vendor_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900238 filesystem: ":microdroid_vendor",
Jiyong Parkc1500e82021-02-24 01:39:51 +0900239 },
240 ],
241}
242
Jiyong Park153d3552021-02-04 08:54:31 +0900243bootimg {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900244 name: "microdroid_boot",
Jiyong Parkdfa3aec2021-03-09 20:32:15 +0900245 // We don't have kernel for arm and x86. But Soong demands one when it builds for
246 // arm or x86 target. Satisfy that by providing an empty file as the kernel.
247 kernel_prebuilt: "empty_kernel",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900248 arch: {
249 arm64: {
Jiyong Park2ad05442022-06-18 18:53:08 +0900250 kernel_prebuilt: ":microdroid_kernel_prebuilts-5.15-arm64",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900251 },
252 x86_64: {
Jiyong Park2ad05442022-06-18 18:53:08 +0900253 kernel_prebuilt: ":microdroid_kernel_prebuilts-5.15-x86_64",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900254 },
255 },
Jiyong Parkc8937172021-08-30 18:41:52 +0900256
Jiyong Park153d3552021-02-04 08:54:31 +0900257 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900258 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900259 partition_name: "boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900260 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900261 avb_private_key: ":microdroid_sign_key",
Jiyong Park153d3552021-02-04 08:54:31 +0900262}
263
Devin Mooredc9158e2022-01-10 18:51:12 +0000264bootimg {
265 name: "microdroid_init_boot",
Jiyong Park09a2bda2022-06-13 16:44:45 +0900266 ramdisk_module: "microdroid_ramdisk",
Devin Mooredc9158e2022-01-10 18:51:12 +0000267 kernel_prebuilt: "empty_kernel",
268 header_version: "4",
269 partition_name: "init_boot",
270 use_avb: true,
271 avb_private_key: ":microdroid_sign_key",
272}
273
Jiyong Park153d3552021-02-04 08:54:31 +0900274android_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900275 name: "microdroid_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900276 deps: [
Inseob Kim97330962021-06-11 12:59:59 +0900277 "init_first_stage",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900278 ],
279 dirs: [
280 "dev",
281 "proc",
282 "sys",
283
284 // TODO(jiyong): remove these
285 "mnt",
286 "debug_ramdisk",
287 "second_stage_resources",
288 ],
289 type: "compressed_cpio",
290}
291
292bootimg {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900293 name: "microdroid_vendor_boot",
294 ramdisk_module: "microdroid_vendor_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900295 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900296 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900297 vendor_boot: true,
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900298 arch: {
299 arm64: {
300 bootconfig: ":microdroid_bootconfig_arm64_gen",
301 },
302 x86_64: {
303 bootconfig: ":microdroid_bootconfig_x86_64_gen",
304 },
305 },
Jiyong Parkc8b40032021-02-18 23:15:41 +0900306 partition_name: "vendor_boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900307 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900308 avb_private_key: ":microdroid_sign_key",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900309}
310
Jiyong Parkb54646f2022-02-07 11:13:56 +0900311android_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900312 name: "microdroid_vendor_ramdisk",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900313 deps: [
314 "microdroid_fstab",
315 ],
316 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900317 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900318 symlinks: [
319 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900320 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900321 name: "first_stage_ramdisk/fstab.microdroid",
322 },
323 {
324 target: "first_stage_ramdisk/lib",
325 name: "lib",
326 },
327 ],
328}
329
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900330genrule {
331 name: "microdroid_bootconfig_arm64_gen",
332 srcs: [
333 "bootconfig.common",
334 "bootconfig.arm64",
335 ],
336 out: ["bootconfig"],
337 cmd: "cat $(in) > $(out)",
338}
339
340genrule {
341 name: "microdroid_bootconfig_x86_64_gen",
342 srcs: [
343 "bootconfig.common",
344 "bootconfig.x86_64",
345 ],
346 out: ["bootconfig"],
347 cmd: "cat $(in) > $(out)",
348}
349
Jiyong Parkacf31b02021-11-04 20:45:14 +0900350vbmeta {
351 name: "microdroid_vbmeta_bootconfig",
352 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900353 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900354 chained_partitions: [
355 {
356 name: "bootconfig",
Jooyung Hand35952e2021-11-08 17:53:47 +0900357 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900358 },
Jiyong Park34ad9182022-01-28 21:29:48 +0900359 {
360 name: "uboot_env",
361 private_key: ":microdroid_sign_key",
362 },
Jiyong Parkacf31b02021-11-04 20:45:14 +0900363 ],
364}
365
Jooyung Han64214832022-04-21 14:30:04 +0900366// python -c "import hashlib; print(hashlib.sha256(b'bootconfig').hexdigest())"
367bootconfig_salt = "e158851fbebb402e1f18ea9372ea2f76b4dea23eceb5c4b92e5b27ade8537f5b"
368
Andrew Sculld6267ae2022-06-13 13:47:59 +0000369avb_add_hash_footer {
370 name: "microdroid_bootconfig_normal",
371 src: "bootconfig.normal",
372 filename: "microdroid_bootconfig.normal",
373 partition_name: "bootconfig",
374 private_key: ":microdroid_sign_key",
375 salt: bootconfig_salt,
Jiyong Parkacf31b02021-11-04 20:45:14 +0900376}
377
Andrew Sculld6267ae2022-06-13 13:47:59 +0000378avb_add_hash_footer {
Seungjae Yooe85831e2022-12-12 09:34:58 +0900379 name: "microdroid_bootconfig_debuggable",
380 src: "bootconfig.debuggable",
381 filename: "microdroid_bootconfig.debuggable",
Andrew Sculld6267ae2022-06-13 13:47:59 +0000382 partition_name: "bootconfig",
383 private_key: ":microdroid_sign_key",
384 salt: bootconfig_salt,
Jiyong Parkacf31b02021-11-04 20:45:14 +0900385}
386
Jiyong Park3eb11f72021-02-23 12:53:30 +0900387prebuilt_etc {
388 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900389 src: "fstab.microdroid",
390 filename: "fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900391 installable: false,
Jiyong Park153d3552021-02-04 08:54:31 +0900392}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900393
394prebuilt_etc {
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900395 name: "microdroid_bootloader",
Andrew Sculld6267ae2022-06-13 13:47:59 +0000396 src: ":microdroid_bootloader_signed",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900397 arch: {
398 x86_64: {
399 // For unknown reason, the signed bootloader doesn't work on x86_64. Until the problem
400 // is fixed, let's use the unsigned bootloader for the architecture.
401 // TODO(b/185115783): remove this
Jooyung Hand35952e2021-11-08 17:53:47 +0900402 src: ":microdroid_bootloader_pubkey_replaced",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900403 },
404 },
Andrew Sculld6267ae2022-06-13 13:47:59 +0000405 relative_install_path: "fs",
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900406 filename: "microdroid_bootloader",
407}
408
Jooyung Han64214832022-04-21 14:30:04 +0900409// python -c "import hashlib; print(hashlib.sha256(b'bootloader').hexdigest())"
410bootloader_salt = "3b4a12881d11f33cff968a24d7c53723a8232cde9a8d91e29fdbd6a95ae6adf0"
411
Andrew Sculld6267ae2022-06-13 13:47:59 +0000412avb_add_hash_footer {
413 name: "microdroid_bootloader_signed",
414 src: ":microdroid_bootloader_pubkey_replaced",
415 filename: "microdroid_bootloader",
416 partition_name: "bootloader",
417 private_key: ":microdroid_sign_key",
418 salt: bootloader_salt,
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900419}
420
Jooyung Hand35952e2021-11-08 17:53:47 +0900421// Replace avbpubkey of prebuilt bootloader with the avbpubkey of the signing key
422genrule {
423 name: "microdroid_bootloader_pubkey_replaced",
424 tools: ["replace_bytes"],
425 srcs: [
Jooyung Han80245f22021-11-09 17:20:53 +0900426 ":microdroid_crosvm_bootloader", // input (bootloader)
427 ":microdroid_crosvm_bootloader.avbpubkey", // old bytes (old pubkey)
428 ":microdroid_bootloader_avbpubkey_gen", // new bytes (new pubkey)
Jooyung Hand35952e2021-11-08 17:53:47 +0900429 ],
430 out: ["bootloader-pubkey-replaced"],
431 // 1. Copy the input to the output (replace_bytes modifies the file in-place)
Andrew Sculld6267ae2022-06-13 13:47:59 +0000432 // 2. Replace embedded pubkey with new one.
Jooyung Hand35952e2021-11-08 17:53:47 +0900433 cmd: "cp $(location :microdroid_crosvm_bootloader) $(out) && " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900434 "$(location replace_bytes) $(out) " +
Jooyung Han80245f22021-11-09 17:20:53 +0900435 "$(location :microdroid_crosvm_bootloader.avbpubkey) " +
Andrew Sculld6267ae2022-06-13 13:47:59 +0000436 "$(location :microdroid_bootloader_avbpubkey_gen)",
Jooyung Han63513102021-10-29 14:59:59 +0900437}
438
Jooyung Hand35952e2021-11-08 17:53:47 +0900439// Apex keeps a copy of avbpubkey embedded in bootloader so that embedded avbpubkey can be replaced
440// while re-signing bootloader.
441prebuilt_etc {
442 name: "microdroid_bootloader.avbpubkey",
443 src: ":microdroid_bootloader_avbpubkey_gen",
444}
445
446// Generate avbpukey from the signing key
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900447genrule {
Jooyung Hand35952e2021-11-08 17:53:47 +0900448 name: "microdroid_bootloader_avbpubkey_gen",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900449 tools: ["avbtool"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900450 srcs: [":microdroid_sign_key"],
451 out: ["bootloader.pubkey"],
452 cmd: "$(location avbtool) extract_public_key " +
453 "--key $(location :microdroid_sign_key) " +
454 "--output $(out)",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900455}
456
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000457// python -c "import hashlib; print(hashlib.sha256(b'uboot_env').hexdigest())"
458uboot_env_salt = "cbf2d76827ece5ca8d176a40c94ac6355edcf6511b4b887364a8c0e05850df10"
459
Andrew Sculld6267ae2022-06-13 13:47:59 +0000460avb_add_hash_footer {
461 name: "microdroid_uboot_env",
462 src: ":microdroid_uboot_env_gen",
463 filename: "uboot_env.img",
464 partition_name: "uboot_env",
465 private_key: ":microdroid_sign_key",
466 salt: uboot_env_salt,
467}
468
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900469genrule {
470 name: "microdroid_uboot_env_gen",
Andrew Sculld6267ae2022-06-13 13:47:59 +0000471 tools: ["mkenvimage_slim"],
472 srcs: ["uboot-env.txt"],
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900473 out: ["output.img"],
Andrew Sculld6267ae2022-06-13 13:47:59 +0000474 cmd: "$(location mkenvimage_slim) -output_path $(out) -input_path $(location uboot-env.txt)",
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900475}
Inseob Kim28dddd82021-03-11 17:51:22 +0900476
Jooyung Hand35952e2021-11-08 17:53:47 +0900477// Note that keys can be different for filesystem images even though we're using the same key
478// for microdroid. However, the key signing VBmeta should match with the pubkey embedded in
479// bootloader.
480filegroup {
481 name: "microdroid_sign_key",
482 srcs: [":avb_testkey_rsa4096"],
483}
484
Jiyong Park80d8da82021-03-15 23:30:11 +0900485vbmeta {
486 name: "microdroid_vbmeta",
487 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900488 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900489 partitions: [
490 "microdroid_vendor",
Jiyong Park80d8da82021-03-15 23:30:11 +0900491 "microdroid",
492 ],
493}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900494
495prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900496 name: "microdroid.json",
497 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900498}
Jooyung Han017916b2021-04-20 03:57:19 +0900499
500prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900501 name: "microdroid_vendor_manifest",
502 src: "microdroid_vendor_manifest.xml",
503 filename: "manifest.xml",
504 relative_install_path: "vintf",
505 installable: false,
506}
507
508prebuilt_etc {
509 name: "microdroid_vendor_compatibility_matrix",
510 src: "microdroid_vendor_compatibility_matrix.xml",
511 filename: "compatibility_matrix.xml",
512 relative_install_path: "vintf",
513 installable: false,
514}
515
516prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900517 name: "microdroid_manifest",
518 src: "microdroid_manifest.xml",
519 filename: "manifest.xml",
520 relative_install_path: "vintf",
521 installable: false,
522}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700523
524prebuilt_etc {
525 name: "microdroid_event-log-tags",
526 src: "microdroid_event-log-tags",
527 filename: "event-log-tags",
528 installable: false,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900529}
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000530
531filegroup {
Seungjae Yooe85831e2022-12-12 09:34:58 +0900532 name: "microdroid_bootconfig_debuggable_src",
533 srcs: ["bootconfig.debuggable"],
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000534}
535
536filegroup {
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000537 name: "microdroid_bootconfig_normal_src",
538 srcs: ["bootconfig.normal"],
539}
Shikha Panwared8ace42022-09-28 12:52:16 +0000540
Shikha Panwared8ace42022-09-28 12:52:16 +0000541avb_add_hash_footer {
542 name: "microdroid_kernel_signed",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000543 src: "empty_kernel",
Shikha Panwared8ace42022-09-28 12:52:16 +0000544 filename: "microdroid_kernel",
545 partition_name: "bootloader",
546 private_key: ":microdroid_sign_key",
547 salt: bootloader_salt,
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000548 enabled: false,
549 arch: {
550 arm64: {
551 src: ":microdroid_kernel_prebuilts-5.15-arm64",
552 enabled: true,
553 },
554 x86_64: {
555 src: ":microdroid_kernel_prebuilts-5.15-x86_64",
556 enabled: true,
557 },
558 },
Jerry Huang6f473652023-01-10 02:51:48 +0000559 props: [
560 {
561 name: "trusted_ramdisk",
562 file: ":microdroid_initrd_hashes",
563 },
Jiyong Parke2bd27e2022-12-05 17:14:08 +0900564 ],
Shikha Panwared8ace42022-09-28 12:52:16 +0000565}
566
567prebuilt_etc {
568 name: "microdroid_kernel",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000569 src: "empty_kernel",
Shikha Panwared8ace42022-09-28 12:52:16 +0000570 relative_install_path: "fs",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000571 arch: {
572 arm64: {
573 src: ":microdroid_kernel_signed",
574 },
575 x86_64: {
576 src: ":microdroid_kernel_signed",
577 },
578 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000579}