blob: 490135185c326c1a0c19008b163181b99df0bd56 [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",
80 "cgroups.json",
Jooyung Han1c820732021-04-15 05:16:23 +090081 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090082
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070083 "microdroid_compatibility_matrix",
84 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090085 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070086 "microdroid_manifest",
87 "microdroid_plat_sepolicy_and_mapping.sha256",
Inseob Kimff43be22021-06-07 16:56:56 +090088 "microdroid_property_contexts",
89 "microdroid_service_contexts",
Jooyung Han8a17ef72021-08-04 15:39:54 +090090
Jooyung Hana704cbc2022-04-05 14:57:27 +090091 // TODO(b/195425111) these should be added automatically
92 "libcrypto", // used by many (init_second_stage, microdroid_manager, toybox, etc)
93 "liblzma", // used by init_second_stage
Inseob Kimdc2af862021-02-17 15:51:56 +090094 ] + microdroid_shell_and_utilities,
95 multilib: {
96 common: {
97 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +090098 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +090099 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900100
Inseob Kimff43be22021-06-07 16:56:56 +0900101 "microdroid_plat_sepolicy.cil",
102 "microdroid_plat_mapping_file",
Inseob Kimdc2af862021-02-17 15:51:56 +0900103 ],
104 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900105 lib64: {
106 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900107 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700108 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700109 "authfs_service",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900110 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900111 "zipfuse",
112 ],
113 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900114 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900115 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900116 base_dir: "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +0900117 dirs: microdroid_rootdirs,
118 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900119 file_contexts: ":microdroid_file_contexts.gen",
Jiyong Parkb552bb62021-01-25 19:12:47 +0900120}
Jiyong Park153d3552021-02-04 08:54:31 +0900121
Inseob Kimdc2af862021-02-17 15:51:56 +0900122prebuilt_etc {
123 name: "microdroid_init_rc",
124 filename: "init.rc",
125 src: "init.rc",
126 relative_install_path: "init/hw",
127 installable: false, // avoid collision with system partition's init.rc
128}
129
Jiyong Park4d228952021-10-18 18:28:57 +0900130prebuilt_etc {
131 name: "microdroid_ueventd_rc",
132 filename: "ueventd.rc",
133 src: "ueventd.rc",
134 installable: false, // avoid collision with system partition's ueventd.rc
135}
136
Inseob Kim23ce1582021-04-06 21:25:57 +0900137prebuilt_root {
138 name: "microdroid_build_prop",
139 filename: "build.prop",
140 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900141 arch: {
142 x86_64: {
143 src: ":microdroid_build_prop_gen_x86_64",
144 },
145 arm64: {
146 src: ":microdroid_build_prop_gen_arm64",
147 },
148 },
Inseob Kim23ce1582021-04-06 21:25:57 +0900149 installable: false,
150}
151
Jiyong Park68f560c2021-05-24 17:38:27 +0900152genrule {
153 name: "microdroid_build_prop_gen_x86_64",
154 srcs: ["build.prop"],
155 out: ["build.prop.out"],
156 cmd: "cp $(in) $(out); echo ro.product.cpu.abilist=x86_64 >> $(out)",
157}
158
159genrule {
160 name: "microdroid_build_prop_gen_arm64",
161 srcs: ["build.prop"],
162 out: ["build.prop.out"],
163 cmd: "cp $(in) $(out); echo ro.product.cpu.abilist=arm64-v8a >> $(out)",
164}
165
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000166android_filesystem {
167 name: "microdroid_vendor",
Jiyong Park52ea0832021-09-01 12:10:18 +0900168 partition_name: "vendor",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000169 use_avb: true,
170 deps: [
Andrew Scullf8195942022-01-13 17:37:52 +0000171 "android.hardware.security.dice-service.microdroid",
Inseob Kimafd9dc02021-04-23 14:47:44 +0900172 "microdroid_fstab",
Inseob Kim28dddd82021-03-11 17:51:22 +0900173 "microdroid_precompiled_sepolicy.plat_sepolicy_and_mapping.sha256",
Inseob Kim8f095c92021-05-26 12:04:54 +0900174 "microdroid_vendor_manifest",
175 "microdroid_vendor_compatibility_matrix",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000176 ],
Inseob Kimabcd10a2021-03-25 15:43:07 +0900177 multilib: {
178 common: {
179 deps: [
180 "microdroid_vendor_sepolicy.cil",
181 "microdroid_plat_pub_versioned.cil",
Inseob Kimcd06dca2021-04-30 00:19:00 +0900182 "microdroid_plat_sepolicy_vers.txt",
Inseob Kim998c27f2021-09-27 13:44:09 +0000183 "microdroid_precompiled_sepolicy",
Inseob Kimabcd10a2021-03-25 15:43:07 +0900184 ],
185 },
186 },
Jooyung Hand35952e2021-11-08 17:53:47 +0900187 avb_private_key: ":microdroid_sign_key",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000188 avb_algorithm: "SHA256_RSA4096",
Inseob Kimff43be22021-06-07 16:56:56 +0900189 file_contexts: ":microdroid_vendor_file_contexts.gen",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000190}
191
Jiyong Parkc1500e82021-02-24 01:39:51 +0900192logical_partition {
193 name: "microdroid_super",
194 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900195 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900196 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900197 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900198 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900199 filesystem: ":microdroid",
200 },
201 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900202 name: "vendor_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900203 filesystem: ":microdroid_vendor",
Jiyong Parkc1500e82021-02-24 01:39:51 +0900204 },
205 ],
206}
207
Jiyong Parkc8937172021-08-30 18:41:52 +0900208microdroid_boot_cmdline = [
209 "panic=-1",
210 "bootconfig",
Pierre-Clément Tosi94ff9c72022-02-18 14:58:36 +0100211 "ioremap_guard",
Jiyong Parkc8937172021-08-30 18:41:52 +0900212]
Jiyong Park89e81cb2021-04-13 13:13:55 +0900213
Jiyong Park153d3552021-02-04 08:54:31 +0900214bootimg {
Jiyong Parkc8b40032021-02-18 23:15:41 +0900215 name: "microdroid_boot-5.10",
Jiyong Parkdfa3aec2021-03-09 20:32:15 +0900216 // We don't have kernel for arm and x86. But Soong demands one when it builds for
217 // arm or x86 target. Satisfy that by providing an empty file as the kernel.
218 kernel_prebuilt: "empty_kernel",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900219 arch: {
220 arm64: {
221 kernel_prebuilt: ":kernel_prebuilts-5.10-arm64",
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900222 cmdline: microdroid_boot_cmdline,
Jiyong Parkc8b40032021-02-18 23:15:41 +0900223 },
224 x86_64: {
225 kernel_prebuilt: ":kernel_prebuilts-5.10-x86_64",
Jiyong Park747d6362021-10-19 17:12:52 +0900226 cmdline: microdroid_boot_cmdline + [
227 // console=none is to work around the x86 specific u-boot behavior which when
228 // console= option is not found in the kernel commandline console=ttyS0 is
229 // automatically added. By adding console=none, we can prevent u-boot from doing
230 // that. Note that console is set to hvc0 by bootconfig if the VM is configured as
231 // debuggable.
232 "console=none",
233 "acpi=noirq",
234 ],
Jiyong Parkc8b40032021-02-18 23:15:41 +0900235 },
236 },
Jiyong Parkc8937172021-08-30 18:41:52 +0900237
Jiyong Park153d3552021-02-04 08:54:31 +0900238 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900239 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900240 partition_name: "boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900241 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900242 avb_private_key: ":microdroid_sign_key",
Jiyong Park153d3552021-02-04 08:54:31 +0900243}
244
Devin Mooredc9158e2022-01-10 18:51:12 +0000245bootimg {
246 name: "microdroid_init_boot",
247 ramdisk_module: "microdroid_ramdisk-5.10",
248 kernel_prebuilt: "empty_kernel",
249 header_version: "4",
250 partition_name: "init_boot",
251 use_avb: true,
252 avb_private_key: ":microdroid_sign_key",
253}
254
Jiyong Park153d3552021-02-04 08:54:31 +0900255android_filesystem {
256 name: "microdroid_ramdisk-5.10",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900257 deps: [
Inseob Kim97330962021-06-11 12:59:59 +0900258 "init_first_stage",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900259 ],
260 dirs: [
261 "dev",
262 "proc",
263 "sys",
264
265 // TODO(jiyong): remove these
266 "mnt",
267 "debug_ramdisk",
268 "second_stage_resources",
269 ],
270 type: "compressed_cpio",
271}
272
273bootimg {
274 name: "microdroid_vendor_boot-5.10",
275 ramdisk_module: "microdroid_vendor_ramdisk-5.10",
276 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900277 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900278 vendor_boot: true,
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900279 arch: {
280 arm64: {
281 bootconfig: ":microdroid_bootconfig_arm64_gen",
282 },
283 x86_64: {
284 bootconfig: ":microdroid_bootconfig_x86_64_gen",
285 },
286 },
Jiyong Parkc8b40032021-02-18 23:15:41 +0900287 partition_name: "vendor_boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900288 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900289 avb_private_key: ":microdroid_sign_key",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900290}
291
Jiyong Parkb54646f2022-02-07 11:13:56 +0900292prebuilt_kernel_modules {
293 name: "microdroid_kernel_modules",
Jiyong Park153d3552021-02-04 08:54:31 +0900294 arch: {
295 arm64: {
Jiyong Parkb54646f2022-02-07 11:13:56 +0900296 srcs: [":virt_device_prebuilts_kernel_modules_microdroid-5.10-arm64"],
Jiyong Park153d3552021-02-04 08:54:31 +0900297 },
298 x86_64: {
Jiyong Parkb54646f2022-02-07 11:13:56 +0900299 srcs: [":virt_device_prebuilts_kernel_modules_microdroid-5.10-x86_64"],
Jiyong Park153d3552021-02-04 08:54:31 +0900300 },
301 },
Jiyong Parkb54646f2022-02-07 11:13:56 +0900302 kernel_version: "5.10",
303}
304
305android_filesystem {
306 name: "microdroid_vendor_ramdisk-5.10",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900307 deps: [
308 "microdroid_fstab",
Jiyong Parkb54646f2022-02-07 11:13:56 +0900309 "microdroid_kernel_modules",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900310 ],
311 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900312 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900313 symlinks: [
314 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900315 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900316 name: "first_stage_ramdisk/fstab.microdroid",
317 },
318 {
319 target: "first_stage_ramdisk/lib",
320 name: "lib",
321 },
322 ],
323}
324
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900325genrule {
326 name: "microdroid_bootconfig_arm64_gen",
327 srcs: [
328 "bootconfig.common",
329 "bootconfig.arm64",
330 ],
331 out: ["bootconfig"],
332 cmd: "cat $(in) > $(out)",
333}
334
335genrule {
336 name: "microdroid_bootconfig_x86_64_gen",
337 srcs: [
338 "bootconfig.common",
339 "bootconfig.x86_64",
340 ],
341 out: ["bootconfig"],
342 cmd: "cat $(in) > $(out)",
343}
344
Jiyong Parkacf31b02021-11-04 20:45:14 +0900345vbmeta {
346 name: "microdroid_vbmeta_bootconfig",
347 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900348 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900349 chained_partitions: [
350 {
351 name: "bootconfig",
Jooyung Hand35952e2021-11-08 17:53:47 +0900352 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900353 },
Jiyong Park34ad9182022-01-28 21:29:48 +0900354 {
355 name: "uboot_env",
356 private_key: ":microdroid_sign_key",
357 },
Jiyong Parkacf31b02021-11-04 20:45:14 +0900358 ],
359}
360
361// See external/avb/avbtool.py
362// MAX_VBMETA_SIZE=64KB, MAX_FOOTER_SIZE=4KB
363avb_hash_footer_kb = "68"
364
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900365prebuilt_etc {
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900366 name: "microdroid_bootconfig_normal",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900367 src: ":microdroid_bootconfig_normal_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900368 filename: "microdroid_bootconfig.normal",
369}
370
371prebuilt_etc {
372 name: "microdroid_bootconfig_app_debuggable",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900373 src: ":microdroid_bootconfig_app_debuggable_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900374 filename: "microdroid_bootconfig.app_debuggable",
375}
376
377prebuilt_etc {
378 name: "microdroid_bootconfig_full_debuggable",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900379 src: ":microdroid_bootconfig_full_debuggable_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900380 filename: "microdroid_bootconfig.full_debuggable",
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900381}
382
Jiyong Parkacf31b02021-11-04 20:45:14 +0900383// TODO(jiyong): make a new module type that does the avb signing
384genrule {
385 name: "microdroid_bootconfig_normal_gen",
386 tools: ["avbtool"],
387 srcs: [
388 "bootconfig.normal",
Jooyung Hand35952e2021-11-08 17:53:47 +0900389 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900390 ],
391 out: ["microdroid_bootconfig.normal"],
392 cmd: "cp $(location bootconfig.normal) $(out) && " +
393 "$(location avbtool) add_hash_footer " +
394 "--algorithm SHA256_RSA4096 " +
395 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900396 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900397 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
398 "--image $(out)",
399}
400
401genrule {
402 name: "microdroid_bootconfig_app_debuggable_gen",
403 tools: ["avbtool"],
404 srcs: [
405 "bootconfig.app_debuggable",
Jooyung Hand35952e2021-11-08 17:53:47 +0900406 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900407 ],
408 out: ["microdroid_bootconfig.app_debuggable"],
409 cmd: "cp $(location bootconfig.app_debuggable) $(out) && " +
410 "$(location avbtool) add_hash_footer " +
411 "--algorithm SHA256_RSA4096 " +
412 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900413 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900414 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
415 "--image $(out)",
416}
417
418genrule {
419 name: "microdroid_bootconfig_full_debuggable_gen",
420 tools: ["avbtool"],
421 srcs: [
422 "bootconfig.full_debuggable",
Jooyung Hand35952e2021-11-08 17:53:47 +0900423 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900424 ],
425 out: ["microdroid_bootconfig.full_debuggable"],
426 cmd: "cp $(location bootconfig.full_debuggable) $(out) && " +
427 "$(location avbtool) add_hash_footer " +
428 "--algorithm SHA256_RSA4096 " +
429 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900430 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900431 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
432 "--image $(out)",
433}
434
Jiyong Park3eb11f72021-02-23 12:53:30 +0900435prebuilt_etc {
436 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900437 src: "fstab.microdroid",
438 filename: "fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900439 installable: false,
Jiyong Park153d3552021-02-04 08:54:31 +0900440}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900441
442prebuilt_etc {
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900443 name: "microdroid_bootloader",
444 src: ":microdroid_bootloader_gen",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900445 arch: {
446 x86_64: {
447 // For unknown reason, the signed bootloader doesn't work on x86_64. Until the problem
448 // is fixed, let's use the unsigned bootloader for the architecture.
449 // TODO(b/185115783): remove this
Jooyung Hand35952e2021-11-08 17:53:47 +0900450 src: ":microdroid_bootloader_pubkey_replaced",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900451 },
452 },
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900453 filename: "microdroid_bootloader",
454}
455
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900456genrule {
457 name: "microdroid_bootloader_gen",
458 tools: ["avbtool"],
459 srcs: [
Jooyung Hand35952e2021-11-08 17:53:47 +0900460 ":microdroid_bootloader_pubkey_replaced",
461 ":microdroid_sign_key",
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900462 ],
463 out: ["bootloader-signed"],
464 // 1. Copy the input to the output becaise avbtool modifies --image in
465 // place.
466 // 2. Check if the file is big enough. For arm and x86 we have fake
467 // bootloader file whose size is 1. It can't pass avbtool.
468 // 3. Add the hash footer. The partition size is set to (image size + 68KB)
469 // rounded up to 4KB boundary.
Jooyung Hand35952e2021-11-08 17:53:47 +0900470 cmd: "cp $(location :microdroid_bootloader_pubkey_replaced) $(out) && " +
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900471 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
472 "$(location avbtool) add_hash_footer " +
473 "--algorithm SHA256_RSA4096 " +
474 "--partition_name bootloader " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900475 "--key $(location :microdroid_sign_key) " +
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900476 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
477 "--image $(out)" +
478 "; fi",
479}
480
Jooyung Hand35952e2021-11-08 17:53:47 +0900481// Replace avbpubkey of prebuilt bootloader with the avbpubkey of the signing key
482genrule {
483 name: "microdroid_bootloader_pubkey_replaced",
484 tools: ["replace_bytes"],
485 srcs: [
Jooyung Han80245f22021-11-09 17:20:53 +0900486 ":microdroid_crosvm_bootloader", // input (bootloader)
487 ":microdroid_crosvm_bootloader.avbpubkey", // old bytes (old pubkey)
488 ":microdroid_bootloader_avbpubkey_gen", // new bytes (new pubkey)
Jooyung Hand35952e2021-11-08 17:53:47 +0900489 ],
490 out: ["bootloader-pubkey-replaced"],
491 // 1. Copy the input to the output (replace_bytes modifies the file in-place)
492 // 2. Check if the file is big enough. For arm and x86 we have fake
493 // bootloader file whose size is 1. (replace_bytes fails if key not found)
494 // 3. Replace embedded pubkey with new one.
495 cmd: "cp $(location :microdroid_crosvm_bootloader) $(out) && " +
496 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
497 "$(location replace_bytes) $(out) " +
Jooyung Han80245f22021-11-09 17:20:53 +0900498 "$(location :microdroid_crosvm_bootloader.avbpubkey) " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900499 "$(location :microdroid_bootloader_avbpubkey_gen)" +
500 "; fi",
Jooyung Han63513102021-10-29 14:59:59 +0900501}
502
Jooyung Hand35952e2021-11-08 17:53:47 +0900503// Apex keeps a copy of avbpubkey embedded in bootloader so that embedded avbpubkey can be replaced
504// while re-signing bootloader.
505prebuilt_etc {
506 name: "microdroid_bootloader.avbpubkey",
507 src: ":microdroid_bootloader_avbpubkey_gen",
508}
509
510// Generate avbpukey from the signing key
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900511genrule {
Jooyung Hand35952e2021-11-08 17:53:47 +0900512 name: "microdroid_bootloader_avbpubkey_gen",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900513 tools: ["avbtool"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900514 srcs: [":microdroid_sign_key"],
515 out: ["bootloader.pubkey"],
516 cmd: "$(location avbtool) extract_public_key " +
517 "--key $(location :microdroid_sign_key) " +
518 "--output $(out)",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900519}
520
521prebuilt_etc {
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900522 name: "microdroid_uboot_env",
523 src: ":microdroid_uboot_env_gen",
524 filename: "uboot_env.img",
525}
526
527genrule {
528 name: "microdroid_uboot_env_gen",
Jiyong Park34ad9182022-01-28 21:29:48 +0900529 tools: [
530 "mkenvimage_host",
531 "avbtool",
532 ],
533 srcs: [
534 "uboot-env.txt",
535 ":microdroid_sign_key",
536 ],
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900537 out: ["output.img"],
Jiyong Park34ad9182022-01-28 21:29:48 +0900538 cmd: "$(location mkenvimage_host) -s 4096 -o $(out) $(location uboot-env.txt) && " +
539 "$(location avbtool) add_hash_footer " +
540 "--algorithm SHA256_RSA4096 " +
541 "--partition_name uboot_env " +
542 "--key $(location :microdroid_sign_key) " +
543 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
544 "--image $(out)",
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900545}
Inseob Kim28dddd82021-03-11 17:51:22 +0900546
Jooyung Hand35952e2021-11-08 17:53:47 +0900547// Note that keys can be different for filesystem images even though we're using the same key
548// for microdroid. However, the key signing VBmeta should match with the pubkey embedded in
549// bootloader.
550filegroup {
551 name: "microdroid_sign_key",
552 srcs: [":avb_testkey_rsa4096"],
553}
554
Jiyong Park80d8da82021-03-15 23:30:11 +0900555vbmeta {
556 name: "microdroid_vbmeta",
557 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900558 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900559 partitions: [
560 "microdroid_vendor",
561 "microdroid_vendor_boot-5.10",
Jiyong Park80d8da82021-03-15 23:30:11 +0900562 "microdroid",
Jiyong Park52ea0832021-09-01 12:10:18 +0900563 "microdroid_boot-5.10",
Devin Mooredc9158e2022-01-10 18:51:12 +0000564 "microdroid_init_boot",
Jiyong Park80d8da82021-03-15 23:30:11 +0900565 ],
566}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900567
568prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900569 name: "microdroid.json",
570 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900571}
Jooyung Han017916b2021-04-20 03:57:19 +0900572
573prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900574 name: "microdroid_vendor_manifest",
575 src: "microdroid_vendor_manifest.xml",
576 filename: "manifest.xml",
577 relative_install_path: "vintf",
578 installable: false,
579}
580
581prebuilt_etc {
582 name: "microdroid_vendor_compatibility_matrix",
583 src: "microdroid_vendor_compatibility_matrix.xml",
584 filename: "compatibility_matrix.xml",
585 relative_install_path: "vintf",
586 installable: false,
587}
588
589prebuilt_etc {
590 name: "microdroid_compatibility_matrix",
591 src: "microdroid_compatibility_matrix.xml",
592 filename: "compatibility_matrix.current.xml",
593 relative_install_path: "vintf",
594 installable: false,
595}
596
597prebuilt_etc {
598 name: "microdroid_manifest",
599 src: "microdroid_manifest.xml",
600 filename: "manifest.xml",
601 relative_install_path: "vintf",
602 installable: false,
603}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700604
605prebuilt_etc {
606 name: "microdroid_event-log-tags",
607 src: "microdroid_event-log-tags",
608 filename: "event-log-tags",
609 installable: false,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900610}