blob: c6ea28d5c1b1167d97bc114504ce6eb76614cc8e [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",
Jiyong Parkd4326f32021-03-15 23:25:46 +090049 partition_name: "system",
Jiyong Parkb552bb62021-01-25 19:12:47 +090050 deps: [
51 "init_second_stage",
Inseob Kim23ce1582021-04-06 21:25:57 +090052 "microdroid_build_prop",
Jiyong Park40699612021-05-24 16:55:06 +090053 "microdroid_init_rc",
Jiyong Park4d228952021-10-18 18:28:57 +090054 "microdroid_ueventd_rc",
Jiyong Park40699612021-05-24 16:55:06 +090055 "microdroid_launcher",
Jooyung Han7ce2e532021-06-16 16:52:02 +090056
Inseob Kimdc2af862021-02-17 15:51:56 +090057 "libbinder",
Jooyung Han837eef52021-05-15 11:33:48 +090058 "libbinder_ndk",
Inseob Kimdc2af862021-02-17 15:51:56 +090059 "libstdc++",
60 "logcat",
61 "logd",
Inseob Kimdc2af862021-02-17 15:51:56 +090062 "secilc",
Jooyung Han017916b2021-04-20 03:57:19 +090063
64 // "com.android.adbd" requires these,
65 "libadbd_auth",
66 "libadbd_fs",
67
Jooyung Han730b7b82021-05-12 14:09:38 +090068 // "com.android.art" requires
69 "heapprofd_client_api",
Victor Hsieh527b81d2021-06-11 10:41:11 -070070 "libartpalette-system",
Jooyung Han730b7b82021-05-12 14:09:38 +090071
Inseob Kimdc2af862021-02-17 15:51:56 +090072 "apexd",
Oleg Matcovschidca4c2c2022-03-14 06:29:44 -070073 "atrace",
Inseob Kimdc2af862021-02-17 15:51:56 +090074 "debuggerd",
Jiyong Parkc5166842022-01-21 12:54:57 +090075 "diced.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090076 "linker",
Inseob Kim870e76b2021-02-25 17:38:32 +090077 "linkerconfig",
Jiyong Parkc5166842022-01-21 12:54:57 +090078 "servicemanager.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090079 "tombstoned",
Shikha Panwar7afc1392022-03-24 08:54:43 +000080 "tombstone_transmit.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090081 "cgroups.json",
Inseob Kime60307a2022-04-14 03:48:38 +090082 "task_profiles.json",
Jooyung Han1c820732021-04-15 05:16:23 +090083 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090084
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070085 "microdroid_compatibility_matrix",
86 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090087 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070088 "microdroid_manifest",
89 "microdroid_plat_sepolicy_and_mapping.sha256",
Inseob Kimff43be22021-06-07 16:56:56 +090090 "microdroid_property_contexts",
91 "microdroid_service_contexts",
Jooyung Han8a17ef72021-08-04 15:39:54 +090092
Jooyung Hana704cbc2022-04-05 14:57:27 +090093 // TODO(b/195425111) these should be added automatically
94 "libcrypto", // used by many (init_second_stage, microdroid_manager, toybox, etc)
95 "liblzma", // used by init_second_stage
Inseob Kimdc2af862021-02-17 15:51:56 +090096 ] + microdroid_shell_and_utilities,
97 multilib: {
98 common: {
99 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900100 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900101 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900102
Inseob Kimff43be22021-06-07 16:56:56 +0900103 "microdroid_plat_sepolicy.cil",
104 "microdroid_plat_mapping_file",
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",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900112 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900113 "zipfuse",
114 ],
115 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900116 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900117 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900118 base_dir: "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +0900119 dirs: microdroid_rootdirs,
120 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900121 file_contexts: ":microdroid_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900122 // For deterministic output, use fake_timestamp, hard-coded uuid
123 fake_timestamp: "1611569676",
124 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/system'))"
125 uuid: "5fe079c6-f01a-52be-87d3-d415231a72ad",
Jiyong Parkb552bb62021-01-25 19:12:47 +0900126}
Jiyong Park153d3552021-02-04 08:54:31 +0900127
Inseob Kimdc2af862021-02-17 15:51:56 +0900128prebuilt_etc {
129 name: "microdroid_init_rc",
130 filename: "init.rc",
131 src: "init.rc",
132 relative_install_path: "init/hw",
133 installable: false, // avoid collision with system partition's init.rc
134}
135
Jiyong Park4d228952021-10-18 18:28:57 +0900136prebuilt_etc {
137 name: "microdroid_ueventd_rc",
138 filename: "ueventd.rc",
139 src: "ueventd.rc",
140 installable: false, // avoid collision with system partition's ueventd.rc
141}
142
Inseob Kim23ce1582021-04-06 21:25:57 +0900143prebuilt_root {
144 name: "microdroid_build_prop",
145 filename: "build.prop",
146 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900147 arch: {
148 x86_64: {
149 src: ":microdroid_build_prop_gen_x86_64",
150 },
151 arm64: {
152 src: ":microdroid_build_prop_gen_arm64",
153 },
154 },
Inseob Kim23ce1582021-04-06 21:25:57 +0900155 installable: false,
156}
157
Jiyong Park68f560c2021-05-24 17:38:27 +0900158genrule {
159 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900160 srcs: [
161 "build.prop",
162 ":buildinfo.prop",
163 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900164 out: ["build.prop.out"],
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900165 cmd: "(echo '# build properties from buildinfo.prop module' && " +
166 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
167 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
168 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
169 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
Jiyong Park71215c62022-06-21 10:46:55 +0900170 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900171 "cat $(location build.prop) && " +
172 "echo ro.product.cpu.abilist=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900173}
174
175genrule {
176 name: "microdroid_build_prop_gen_arm64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900177 srcs: [
178 "build.prop",
179 ":buildinfo.prop",
180 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900181 out: ["build.prop.out"],
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900182 cmd: "(echo '# build properties from buildinfo.prop module' && " +
183 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
184 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
185 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
186 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
Jiyong Park71215c62022-06-21 10:46:55 +0900187 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900188 "cat $(location build.prop) && " +
189 "echo ro.product.cpu.abilist=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900190}
191
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000192android_filesystem {
193 name: "microdroid_vendor",
Jiyong Park52ea0832021-09-01 12:10:18 +0900194 partition_name: "vendor",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000195 use_avb: true,
196 deps: [
Andrew Scullf8195942022-01-13 17:37:52 +0000197 "android.hardware.security.dice-service.microdroid",
Inseob Kimafd9dc02021-04-23 14:47:44 +0900198 "microdroid_fstab",
Inseob Kim28dddd82021-03-11 17:51:22 +0900199 "microdroid_precompiled_sepolicy.plat_sepolicy_and_mapping.sha256",
Inseob Kim8f095c92021-05-26 12:04:54 +0900200 "microdroid_vendor_manifest",
201 "microdroid_vendor_compatibility_matrix",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000202 ],
Inseob Kimabcd10a2021-03-25 15:43:07 +0900203 multilib: {
204 common: {
205 deps: [
206 "microdroid_vendor_sepolicy.cil",
207 "microdroid_plat_pub_versioned.cil",
Inseob Kimcd06dca2021-04-30 00:19:00 +0900208 "microdroid_plat_sepolicy_vers.txt",
Inseob Kim998c27f2021-09-27 13:44:09 +0000209 "microdroid_precompiled_sepolicy",
Inseob Kimabcd10a2021-03-25 15:43:07 +0900210 ],
211 },
212 },
Jooyung Hand35952e2021-11-08 17:53:47 +0900213 avb_private_key: ":microdroid_sign_key",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000214 avb_algorithm: "SHA256_RSA4096",
Inseob Kimff43be22021-06-07 16:56:56 +0900215 file_contexts: ":microdroid_vendor_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900216 // For deterministic output, use fake_timestamp, hard-coded uuid
217 fake_timestamp: "1611569676",
218 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/vendor'))"
219 uuid: "156d40d7-8d8e-5c99-8913-ec82de549a70",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000220}
221
Jiyong Parkc1500e82021-02-24 01:39:51 +0900222logical_partition {
223 name: "microdroid_super",
224 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900225 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900226 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900227 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900228 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900229 filesystem: ":microdroid",
230 },
231 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900232 name: "vendor_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900233 filesystem: ":microdroid_vendor",
Jiyong Parkc1500e82021-02-24 01:39:51 +0900234 },
235 ],
236}
237
Jiyong Parkc8937172021-08-30 18:41:52 +0900238microdroid_boot_cmdline = [
239 "panic=-1",
240 "bootconfig",
Pierre-Clément Tosi94ff9c72022-02-18 14:58:36 +0100241 "ioremap_guard",
Jiyong Parkc8937172021-08-30 18:41:52 +0900242]
Jiyong Park89e81cb2021-04-13 13:13:55 +0900243
Jiyong Park153d3552021-02-04 08:54:31 +0900244bootimg {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900245 name: "microdroid_boot",
Jiyong Parkdfa3aec2021-03-09 20:32:15 +0900246 // We don't have kernel for arm and x86. But Soong demands one when it builds for
247 // arm or x86 target. Satisfy that by providing an empty file as the kernel.
248 kernel_prebuilt: "empty_kernel",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900249 arch: {
250 arm64: {
Jiyong Park2ad05442022-06-18 18:53:08 +0900251 kernel_prebuilt: ":microdroid_kernel_prebuilts-5.15-arm64",
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900252 cmdline: microdroid_boot_cmdline,
Jiyong Parkc8b40032021-02-18 23:15:41 +0900253 },
254 x86_64: {
Jiyong Park2ad05442022-06-18 18:53:08 +0900255 kernel_prebuilt: ":microdroid_kernel_prebuilts-5.15-x86_64",
Jiyong Park747d6362021-10-19 17:12:52 +0900256 cmdline: microdroid_boot_cmdline + [
257 // console=none is to work around the x86 specific u-boot behavior which when
258 // console= option is not found in the kernel commandline console=ttyS0 is
259 // automatically added. By adding console=none, we can prevent u-boot from doing
260 // that. Note that console is set to hvc0 by bootconfig if the VM is configured as
261 // debuggable.
262 "console=none",
263 "acpi=noirq",
264 ],
Jiyong Parkc8b40032021-02-18 23:15:41 +0900265 },
266 },
Jiyong Parkc8937172021-08-30 18:41:52 +0900267
Jiyong Park153d3552021-02-04 08:54:31 +0900268 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900269 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900270 partition_name: "boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900271 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900272 avb_private_key: ":microdroid_sign_key",
Jiyong Park153d3552021-02-04 08:54:31 +0900273}
274
Devin Mooredc9158e2022-01-10 18:51:12 +0000275bootimg {
276 name: "microdroid_init_boot",
Jiyong Park09a2bda2022-06-13 16:44:45 +0900277 ramdisk_module: "microdroid_ramdisk",
Devin Mooredc9158e2022-01-10 18:51:12 +0000278 kernel_prebuilt: "empty_kernel",
279 header_version: "4",
280 partition_name: "init_boot",
281 use_avb: true,
282 avb_private_key: ":microdroid_sign_key",
283}
284
Jiyong Park153d3552021-02-04 08:54:31 +0900285android_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900286 name: "microdroid_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900287 deps: [
Inseob Kim97330962021-06-11 12:59:59 +0900288 "init_first_stage",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900289 ],
290 dirs: [
291 "dev",
292 "proc",
293 "sys",
294
295 // TODO(jiyong): remove these
296 "mnt",
297 "debug_ramdisk",
298 "second_stage_resources",
299 ],
300 type: "compressed_cpio",
301}
302
303bootimg {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900304 name: "microdroid_vendor_boot",
305 ramdisk_module: "microdroid_vendor_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900306 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900307 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900308 vendor_boot: true,
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900309 arch: {
310 arm64: {
311 bootconfig: ":microdroid_bootconfig_arm64_gen",
312 },
313 x86_64: {
314 bootconfig: ":microdroid_bootconfig_x86_64_gen",
315 },
316 },
Jiyong Parkc8b40032021-02-18 23:15:41 +0900317 partition_name: "vendor_boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900318 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900319 avb_private_key: ":microdroid_sign_key",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900320}
321
Jiyong Park2ad05442022-06-18 18:53:08 +0900322// TODO(b/231117670) remove this when VirtualizationTestCases moves to the
323// microdroid kernel
Jiyong Parkb54646f2022-02-07 11:13:56 +0900324prebuilt_kernel_modules {
325 name: "microdroid_kernel_modules",
Jiyong Park153d3552021-02-04 08:54:31 +0900326 arch: {
327 arm64: {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900328 srcs: [":virt_device_prebuilts_kernel_modules_microdroid-5.15-arm64"],
Jiyong Park153d3552021-02-04 08:54:31 +0900329 },
330 x86_64: {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900331 srcs: [":virt_device_prebuilts_kernel_modules_microdroid-5.15-x86_64"],
Jiyong Park153d3552021-02-04 08:54:31 +0900332 },
333 },
Jiyong Park09a2bda2022-06-13 16:44:45 +0900334 kernel_version: "5.15",
Jiyong Parkb54646f2022-02-07 11:13:56 +0900335}
336
337android_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900338 name: "microdroid_vendor_ramdisk",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900339 deps: [
340 "microdroid_fstab",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900341 ],
342 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900343 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900344 symlinks: [
345 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900346 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900347 name: "first_stage_ramdisk/fstab.microdroid",
348 },
349 {
350 target: "first_stage_ramdisk/lib",
351 name: "lib",
352 },
353 ],
354}
355
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900356genrule {
357 name: "microdroid_bootconfig_arm64_gen",
358 srcs: [
359 "bootconfig.common",
360 "bootconfig.arm64",
361 ],
362 out: ["bootconfig"],
363 cmd: "cat $(in) > $(out)",
364}
365
366genrule {
367 name: "microdroid_bootconfig_x86_64_gen",
368 srcs: [
369 "bootconfig.common",
370 "bootconfig.x86_64",
371 ],
372 out: ["bootconfig"],
373 cmd: "cat $(in) > $(out)",
374}
375
Jiyong Parkacf31b02021-11-04 20:45:14 +0900376vbmeta {
377 name: "microdroid_vbmeta_bootconfig",
378 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900379 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900380 chained_partitions: [
381 {
382 name: "bootconfig",
Jooyung Hand35952e2021-11-08 17:53:47 +0900383 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900384 },
Jiyong Park34ad9182022-01-28 21:29:48 +0900385 {
386 name: "uboot_env",
387 private_key: ":microdroid_sign_key",
388 },
Jiyong Parkacf31b02021-11-04 20:45:14 +0900389 ],
390}
391
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000392// See external/avb/avbtool.py
393// MAX_VBMETA_SIZE=64KB, MAX_FOOTER_SIZE=4KB
394avb_hash_footer_kb = "68"
395
396prebuilt_etc {
397 name: "microdroid_bootconfig_normal",
398 src: ":microdroid_bootconfig_normal_gen",
399 filename: "microdroid_bootconfig.normal",
400}
401
402prebuilt_etc {
403 name: "microdroid_bootconfig_app_debuggable",
404 src: ":microdroid_bootconfig_app_debuggable_gen",
405 filename: "microdroid_bootconfig.app_debuggable",
406}
407
408prebuilt_etc {
409 name: "microdroid_bootconfig_full_debuggable",
410 src: ":microdroid_bootconfig_full_debuggable_gen",
411 filename: "microdroid_bootconfig.full_debuggable",
412}
413
Jooyung Han64214832022-04-21 14:30:04 +0900414// python -c "import hashlib; print(hashlib.sha256(b'bootconfig').hexdigest())"
415bootconfig_salt = "e158851fbebb402e1f18ea9372ea2f76b4dea23eceb5c4b92e5b27ade8537f5b"
416
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000417// TODO(jiyong): make a new module type that does the avb signing
418genrule {
419 name: "microdroid_bootconfig_normal_gen",
420 tools: ["avbtool"],
421 srcs: [
422 "bootconfig.normal",
423 ":microdroid_sign_key",
424 ],
425 out: ["microdroid_bootconfig.normal"],
426 cmd: "cp $(location bootconfig.normal) $(out) && " +
427 "$(location avbtool) add_hash_footer " +
428 "--algorithm SHA256_RSA4096 " +
429 "--salt " + bootconfig_salt + " " +
430 "--partition_name bootconfig " +
431 "--key $(location :microdroid_sign_key) " +
432 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
433 "--image $(out)",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900434}
435
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000436genrule {
437 name: "microdroid_bootconfig_app_debuggable_gen",
438 tools: ["avbtool"],
439 srcs: [
440 "bootconfig.app_debuggable",
441 ":microdroid_sign_key",
442 ],
443 out: ["microdroid_bootconfig.app_debuggable"],
444 cmd: "cp $(location bootconfig.app_debuggable) $(out) && " +
445 "$(location avbtool) add_hash_footer " +
446 "--algorithm SHA256_RSA4096 " +
447 "--salt " + bootconfig_salt + " " +
448 "--partition_name bootconfig " +
449 "--key $(location :microdroid_sign_key) " +
450 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
451 "--image $(out)",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900452}
453
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000454genrule {
455 name: "microdroid_bootconfig_full_debuggable_gen",
456 tools: ["avbtool"],
457 srcs: [
458 "bootconfig.full_debuggable",
459 ":microdroid_sign_key",
460 ],
461 out: ["microdroid_bootconfig.full_debuggable"],
462 cmd: "cp $(location bootconfig.full_debuggable) $(out) && " +
463 "$(location avbtool) add_hash_footer " +
464 "--algorithm SHA256_RSA4096 " +
465 "--salt " + bootconfig_salt + " " +
466 "--partition_name bootconfig " +
467 "--key $(location :microdroid_sign_key) " +
468 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
469 "--image $(out)",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900470}
471
Jiyong Park3eb11f72021-02-23 12:53:30 +0900472prebuilt_etc {
473 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900474 src: "fstab.microdroid",
475 filename: "fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900476 installable: false,
Jiyong Park153d3552021-02-04 08:54:31 +0900477}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900478
479prebuilt_etc {
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900480 name: "microdroid_bootloader",
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000481 src: ":microdroid_bootloader_gen",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900482 arch: {
483 x86_64: {
484 // For unknown reason, the signed bootloader doesn't work on x86_64. Until the problem
485 // is fixed, let's use the unsigned bootloader for the architecture.
486 // TODO(b/185115783): remove this
Jooyung Hand35952e2021-11-08 17:53:47 +0900487 src: ":microdroid_bootloader_pubkey_replaced",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900488 },
489 },
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900490 filename: "microdroid_bootloader",
491}
492
Jooyung Han64214832022-04-21 14:30:04 +0900493// python -c "import hashlib; print(hashlib.sha256(b'bootloader').hexdigest())"
494bootloader_salt = "3b4a12881d11f33cff968a24d7c53723a8232cde9a8d91e29fdbd6a95ae6adf0"
495
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000496genrule {
497 name: "microdroid_bootloader_gen",
498 tools: ["avbtool"],
499 srcs: [
500 ":microdroid_bootloader_pubkey_replaced",
501 ":microdroid_sign_key",
502 ],
503 out: ["bootloader-signed"],
504 // 1. Copy the input to the output becaise avbtool modifies --image in
505 // place.
506 // 2. Check if the file is big enough. For arm and x86 we have fake
507 // bootloader file whose size is 1. It can't pass avbtool.
508 // 3. Add the hash footer. The partition size is set to (image size + 68KB)
509 // rounded up to 4KB boundary.
510 cmd: "cp $(location :microdroid_bootloader_pubkey_replaced) $(out) && " +
511 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
512 "$(location avbtool) add_hash_footer " +
513 "--algorithm SHA256_RSA4096 " +
514 "--salt " + bootloader_salt + " " +
515 "--partition_name bootloader " +
516 "--key $(location :microdroid_sign_key) " +
517 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
518 "--image $(out)" +
519 "; fi",
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900520}
521
Jooyung Hand35952e2021-11-08 17:53:47 +0900522// Replace avbpubkey of prebuilt bootloader with the avbpubkey of the signing key
523genrule {
524 name: "microdroid_bootloader_pubkey_replaced",
525 tools: ["replace_bytes"],
526 srcs: [
Jooyung Han80245f22021-11-09 17:20:53 +0900527 ":microdroid_crosvm_bootloader", // input (bootloader)
528 ":microdroid_crosvm_bootloader.avbpubkey", // old bytes (old pubkey)
529 ":microdroid_bootloader_avbpubkey_gen", // new bytes (new pubkey)
Jooyung Hand35952e2021-11-08 17:53:47 +0900530 ],
531 out: ["bootloader-pubkey-replaced"],
532 // 1. Copy the input to the output (replace_bytes modifies the file in-place)
533 // 2. Check if the file is big enough. For arm and x86 we have fake
534 // bootloader file whose size is 1. (replace_bytes fails if key not found)
535 // 3. Replace embedded pubkey with new one.
536 cmd: "cp $(location :microdroid_crosvm_bootloader) $(out) && " +
537 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
538 "$(location replace_bytes) $(out) " +
Jooyung Han80245f22021-11-09 17:20:53 +0900539 "$(location :microdroid_crosvm_bootloader.avbpubkey) " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900540 "$(location :microdroid_bootloader_avbpubkey_gen)" +
541 "; fi",
Jooyung Han63513102021-10-29 14:59:59 +0900542}
543
Jooyung Hand35952e2021-11-08 17:53:47 +0900544// Apex keeps a copy of avbpubkey embedded in bootloader so that embedded avbpubkey can be replaced
545// while re-signing bootloader.
546prebuilt_etc {
547 name: "microdroid_bootloader.avbpubkey",
548 src: ":microdroid_bootloader_avbpubkey_gen",
549}
550
551// Generate avbpukey from the signing key
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900552genrule {
Jooyung Hand35952e2021-11-08 17:53:47 +0900553 name: "microdroid_bootloader_avbpubkey_gen",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900554 tools: ["avbtool"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900555 srcs: [":microdroid_sign_key"],
556 out: ["bootloader.pubkey"],
557 cmd: "$(location avbtool) extract_public_key " +
558 "--key $(location :microdroid_sign_key) " +
559 "--output $(out)",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900560}
561
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000562prebuilt_etc {
Andrew Scull26eca1f2022-06-09 15:57:26 +0000563 name: "microdroid_uboot_env",
564 src: ":microdroid_uboot_env_gen",
565 filename: "uboot_env.img",
Andrew Scull26eca1f2022-06-09 15:57:26 +0000566}
567
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000568// python -c "import hashlib; print(hashlib.sha256(b'uboot_env').hexdigest())"
569uboot_env_salt = "cbf2d76827ece5ca8d176a40c94ac6355edcf6511b4b887364a8c0e05850df10"
570
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900571genrule {
572 name: "microdroid_uboot_env_gen",
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000573 tools: [
574 "mkenvimage_slim",
575 "avbtool",
576 ],
577 srcs: [
578 "uboot-env.txt",
579 ":microdroid_sign_key",
580 ],
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900581 out: ["output.img"],
Andrew Sculled0fd2d2022-06-13 13:22:41 +0000582 cmd: "$(location mkenvimage_slim) -output_path $(out) -input_path $(location uboot-env.txt) && " +
583 "$(location avbtool) add_hash_footer " +
584 "--algorithm SHA256_RSA4096 " +
585 "--salt " + uboot_env_salt + " " +
586 "--partition_name uboot_env " +
587 "--key $(location :microdroid_sign_key) " +
588 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
589 "--image $(out)",
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900590}
Inseob Kim28dddd82021-03-11 17:51:22 +0900591
Jooyung Hand35952e2021-11-08 17:53:47 +0900592// Note that keys can be different for filesystem images even though we're using the same key
593// for microdroid. However, the key signing VBmeta should match with the pubkey embedded in
594// bootloader.
595filegroup {
596 name: "microdroid_sign_key",
597 srcs: [":avb_testkey_rsa4096"],
598}
599
Jiyong Park80d8da82021-03-15 23:30:11 +0900600vbmeta {
601 name: "microdroid_vbmeta",
602 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900603 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900604 partitions: [
605 "microdroid_vendor",
Jiyong Park09a2bda2022-06-13 16:44:45 +0900606 "microdroid_vendor_boot",
Jiyong Park80d8da82021-03-15 23:30:11 +0900607 "microdroid",
Jiyong Park09a2bda2022-06-13 16:44:45 +0900608 "microdroid_boot",
Devin Mooredc9158e2022-01-10 18:51:12 +0000609 "microdroid_init_boot",
Jiyong Park80d8da82021-03-15 23:30:11 +0900610 ],
611}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900612
613prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900614 name: "microdroid.json",
615 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900616}
Jooyung Han017916b2021-04-20 03:57:19 +0900617
618prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900619 name: "microdroid_vendor_manifest",
620 src: "microdroid_vendor_manifest.xml",
621 filename: "manifest.xml",
622 relative_install_path: "vintf",
623 installable: false,
624}
625
626prebuilt_etc {
627 name: "microdroid_vendor_compatibility_matrix",
628 src: "microdroid_vendor_compatibility_matrix.xml",
629 filename: "compatibility_matrix.xml",
630 relative_install_path: "vintf",
631 installable: false,
632}
633
634prebuilt_etc {
635 name: "microdroid_compatibility_matrix",
636 src: "microdroid_compatibility_matrix.xml",
637 filename: "compatibility_matrix.current.xml",
638 relative_install_path: "vintf",
639 installable: false,
640}
641
642prebuilt_etc {
643 name: "microdroid_manifest",
644 src: "microdroid_manifest.xml",
645 filename: "manifest.xml",
646 relative_install_path: "vintf",
647 installable: false,
648}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700649
650prebuilt_etc {
651 name: "microdroid_event-log-tags",
652 src: "microdroid_event-log-tags",
653 filename: "event-log-tags",
654 installable: false,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900655}