blob: 3eaf1247c2da769f0bcc13941b57510b57b0842f [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",
62 "run-as",
63 "secilc",
Jooyung Han017916b2021-04-20 03:57:19 +090064
65 // "com.android.adbd" requires these,
66 "libadbd_auth",
67 "libadbd_fs",
68
Jooyung Han730b7b82021-05-12 14:09:38 +090069 // "com.android.art" requires
70 "heapprofd_client_api",
Victor Hsieh527b81d2021-06-11 10:41:11 -070071 "libartpalette-system",
Jooyung Han730b7b82021-05-12 14:09:38 +090072
Inseob Kimdc2af862021-02-17 15:51:56 +090073 "apexd",
74 "debuggerd",
Jiyong Park1b3bcdc2021-09-30 16:40:19 +090075 "keystore2_microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090076 "linker",
Inseob Kim870e76b2021-02-25 17:38:32 +090077 "linkerconfig",
Inseob Kimdc2af862021-02-17 15:51:56 +090078 "servicemanager",
79 "tombstoned",
80 "cgroups.json",
Jooyung Han1c820732021-04-15 05:16:23 +090081 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090082
Inseob Kim8f095c92021-05-26 12:04:54 +090083 // TODO(b/185767624): remove hidl after full keymint support
84 "hwservicemanager",
85
Inseob Kimff43be22021-06-07 16:56:56 +090086 "microdroid_plat_sepolicy_and_mapping.sha256",
87 "microdroid_file_contexts",
88 "microdroid_hwservice_contexts",
89 "microdroid_property_contexts",
90 "microdroid_service_contexts",
91 "microdroid_keystore2_key_contexts",
Inseob Kim8f095c92021-05-26 12:04:54 +090092 "microdroid_compatibility_matrix",
93 "microdroid_manifest",
Jooyung Han8a17ef72021-08-04 15:39:54 +090094
95 // TODO(b/195425111) these four should be added automatically
96 "android.hardware.security.secureclock-V1-ndk",
97 "android.hardware.security.sharedsecret-V1-ndk",
98 "libcrypto",
99 "liblzma",
Inseob Kimdc2af862021-02-17 15:51:56 +0900100 ] + microdroid_shell_and_utilities,
101 multilib: {
102 common: {
103 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900104 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900105 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900106
Inseob Kimff43be22021-06-07 16:56:56 +0900107 "microdroid_plat_sepolicy.cil",
108 "microdroid_plat_mapping_file",
Inseob Kimdc2af862021-02-17 15:51:56 +0900109 ],
110 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900111 lib64: {
112 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900113 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700114 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700115 "authfs_service",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900116 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900117 "zipfuse",
Victor Hsieh2445e332021-06-04 16:44:53 -0700118
119 // TODO(b/184872979): Needed by authfs. Remove once the Rust API is created.
120 "libbinder_rpc_unstable",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900121 ],
122 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900123 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900124 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900125 base_dir: "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +0900126 dirs: microdroid_rootdirs,
127 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900128 file_contexts: ":microdroid_file_contexts.gen",
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",
163 srcs: ["build.prop"],
164 out: ["build.prop.out"],
165 cmd: "cp $(in) $(out); echo ro.product.cpu.abilist=x86_64 >> $(out)",
166}
167
168genrule {
169 name: "microdroid_build_prop_gen_arm64",
170 srcs: ["build.prop"],
171 out: ["build.prop.out"],
172 cmd: "cp $(in) $(out); echo ro.product.cpu.abilist=arm64-v8a >> $(out)",
173}
174
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000175android_filesystem {
176 name: "microdroid_vendor",
Jiyong Park52ea0832021-09-01 12:10:18 +0900177 partition_name: "vendor",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000178 use_avb: true,
179 deps: [
Andrew Scull9ba26572021-05-27 19:20:46 +0000180 "android.hardware.security.keymint-service.microdroid",
Inseob Kimafd9dc02021-04-23 14:47:44 +0900181 "microdroid_fstab",
Inseob Kim28dddd82021-03-11 17:51:22 +0900182 "microdroid_precompiled_sepolicy.plat_sepolicy_and_mapping.sha256",
Inseob Kim8f095c92021-05-26 12:04:54 +0900183 "microdroid_vendor_manifest",
184 "microdroid_vendor_compatibility_matrix",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000185 ],
Inseob Kimabcd10a2021-03-25 15:43:07 +0900186 multilib: {
187 common: {
188 deps: [
189 "microdroid_vendor_sepolicy.cil",
190 "microdroid_plat_pub_versioned.cil",
Inseob Kimcd06dca2021-04-30 00:19:00 +0900191 "microdroid_plat_sepolicy_vers.txt",
Inseob Kim998c27f2021-09-27 13:44:09 +0000192 "microdroid_precompiled_sepolicy",
Inseob Kimabcd10a2021-03-25 15:43:07 +0900193 ],
194 },
195 },
Jooyung Hand35952e2021-11-08 17:53:47 +0900196 avb_private_key: ":microdroid_sign_key",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000197 avb_algorithm: "SHA256_RSA4096",
Inseob Kimff43be22021-06-07 16:56:56 +0900198 file_contexts: ":microdroid_vendor_file_contexts.gen",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000199}
200
Jiyong Parkc1500e82021-02-24 01:39:51 +0900201logical_partition {
202 name: "microdroid_super",
203 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900204 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900205 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900206 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900207 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900208 filesystem: ":microdroid",
209 },
210 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900211 name: "vendor_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900212 filesystem: ":microdroid_vendor",
Jiyong Parkc1500e82021-02-24 01:39:51 +0900213 },
214 ],
215}
216
Jiyong Parkc8937172021-08-30 18:41:52 +0900217microdroid_boot_cmdline = [
218 "panic=-1",
219 "bootconfig",
220]
Jiyong Park89e81cb2021-04-13 13:13:55 +0900221
Jiyong Park153d3552021-02-04 08:54:31 +0900222bootimg {
Jiyong Parkc8b40032021-02-18 23:15:41 +0900223 name: "microdroid_boot-5.10",
Alistair Delva3c76abb2022-01-09 22:19:39 +0000224 ramdisk_module: "microdroid_ramdisk-5.10",
Jiyong Parkdfa3aec2021-03-09 20:32:15 +0900225 // We don't have kernel for arm and x86. But Soong demands one when it builds for
226 // arm or x86 target. Satisfy that by providing an empty file as the kernel.
227 kernel_prebuilt: "empty_kernel",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900228 arch: {
229 arm64: {
230 kernel_prebuilt: ":kernel_prebuilts-5.10-arm64",
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900231 cmdline: microdroid_boot_cmdline,
Jiyong Parkc8b40032021-02-18 23:15:41 +0900232 },
233 x86_64: {
234 kernel_prebuilt: ":kernel_prebuilts-5.10-x86_64",
Jiyong Park747d6362021-10-19 17:12:52 +0900235 cmdline: microdroid_boot_cmdline + [
236 // console=none is to work around the x86 specific u-boot behavior which when
237 // console= option is not found in the kernel commandline console=ttyS0 is
238 // automatically added. By adding console=none, we can prevent u-boot from doing
239 // that. Note that console is set to hvc0 by bootconfig if the VM is configured as
240 // debuggable.
241 "console=none",
242 "acpi=noirq",
243 ],
Jiyong Parkc8b40032021-02-18 23:15:41 +0900244 },
245 },
Jiyong Parkc8937172021-08-30 18:41:52 +0900246
Jiyong Park153d3552021-02-04 08:54:31 +0900247 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900248 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900249 partition_name: "boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900250 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900251 avb_private_key: ":microdroid_sign_key",
Jiyong Park153d3552021-02-04 08:54:31 +0900252}
253
254android_filesystem {
255 name: "microdroid_ramdisk-5.10",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900256 deps: [
Inseob Kim97330962021-06-11 12:59:59 +0900257 "init_first_stage",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900258 ],
259 dirs: [
260 "dev",
261 "proc",
262 "sys",
263
264 // TODO(jiyong): remove these
265 "mnt",
266 "debug_ramdisk",
267 "second_stage_resources",
268 ],
269 type: "compressed_cpio",
270}
271
272bootimg {
273 name: "microdroid_vendor_boot-5.10",
274 ramdisk_module: "microdroid_vendor_ramdisk-5.10",
275 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900276 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900277 vendor_boot: true,
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900278 arch: {
279 arm64: {
280 bootconfig: ":microdroid_bootconfig_arm64_gen",
281 },
282 x86_64: {
283 bootconfig: ":microdroid_bootconfig_x86_64_gen",
284 },
285 },
Jiyong Parkc8b40032021-02-18 23:15:41 +0900286 partition_name: "vendor_boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900287 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900288 avb_private_key: ":microdroid_sign_key",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900289}
290
291android_filesystem {
292 name: "microdroid_vendor_ramdisk-5.10",
Jiyong Park153d3552021-02-04 08:54:31 +0900293 arch: {
294 arm64: {
295 deps: ["virt_device_prebuilts_kernel_modules-5.10-arm64"],
296 },
297 x86_64: {
298 deps: ["virt_device_prebuilts_kernel_modules-5.10-x86_64"],
299 },
300 },
Jiyong Park3eb11f72021-02-23 12:53:30 +0900301 deps: [
302 "microdroid_fstab",
303 ],
304 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900305 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900306 symlinks: [
307 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900308 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900309 name: "first_stage_ramdisk/fstab.microdroid",
310 },
311 {
312 target: "first_stage_ramdisk/lib",
313 name: "lib",
314 },
315 ],
316}
317
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900318genrule {
319 name: "microdroid_bootconfig_arm64_gen",
320 srcs: [
321 "bootconfig.common",
322 "bootconfig.arm64",
323 ],
324 out: ["bootconfig"],
325 cmd: "cat $(in) > $(out)",
326}
327
328genrule {
329 name: "microdroid_bootconfig_x86_64_gen",
330 srcs: [
331 "bootconfig.common",
332 "bootconfig.x86_64",
333 ],
334 out: ["bootconfig"],
335 cmd: "cat $(in) > $(out)",
336}
337
Jiyong Parkacf31b02021-11-04 20:45:14 +0900338vbmeta {
339 name: "microdroid_vbmeta_bootconfig",
340 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900341 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900342 chained_partitions: [
343 {
344 name: "bootconfig",
Jooyung Hand35952e2021-11-08 17:53:47 +0900345 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900346 },
347 ],
348}
349
350// See external/avb/avbtool.py
351// MAX_VBMETA_SIZE=64KB, MAX_FOOTER_SIZE=4KB
352avb_hash_footer_kb = "68"
353
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900354prebuilt_etc {
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900355 name: "microdroid_bootconfig_normal",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900356 src: ":microdroid_bootconfig_normal_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900357 filename: "microdroid_bootconfig.normal",
358}
359
360prebuilt_etc {
361 name: "microdroid_bootconfig_app_debuggable",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900362 src: ":microdroid_bootconfig_app_debuggable_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900363 filename: "microdroid_bootconfig.app_debuggable",
364}
365
366prebuilt_etc {
367 name: "microdroid_bootconfig_full_debuggable",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900368 src: ":microdroid_bootconfig_full_debuggable_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900369 filename: "microdroid_bootconfig.full_debuggable",
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900370}
371
Jiyong Parkacf31b02021-11-04 20:45:14 +0900372// TODO(jiyong): make a new module type that does the avb signing
373genrule {
374 name: "microdroid_bootconfig_normal_gen",
375 tools: ["avbtool"],
376 srcs: [
377 "bootconfig.normal",
Jooyung Hand35952e2021-11-08 17:53:47 +0900378 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900379 ],
380 out: ["microdroid_bootconfig.normal"],
381 cmd: "cp $(location bootconfig.normal) $(out) && " +
382 "$(location avbtool) add_hash_footer " +
383 "--algorithm SHA256_RSA4096 " +
384 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900385 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900386 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
387 "--image $(out)",
388}
389
390genrule {
391 name: "microdroid_bootconfig_app_debuggable_gen",
392 tools: ["avbtool"],
393 srcs: [
394 "bootconfig.app_debuggable",
Jooyung Hand35952e2021-11-08 17:53:47 +0900395 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900396 ],
397 out: ["microdroid_bootconfig.app_debuggable"],
398 cmd: "cp $(location bootconfig.app_debuggable) $(out) && " +
399 "$(location avbtool) add_hash_footer " +
400 "--algorithm SHA256_RSA4096 " +
401 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900402 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900403 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
404 "--image $(out)",
405}
406
407genrule {
408 name: "microdroid_bootconfig_full_debuggable_gen",
409 tools: ["avbtool"],
410 srcs: [
411 "bootconfig.full_debuggable",
Jooyung Hand35952e2021-11-08 17:53:47 +0900412 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900413 ],
414 out: ["microdroid_bootconfig.full_debuggable"],
415 cmd: "cp $(location bootconfig.full_debuggable) $(out) && " +
416 "$(location avbtool) add_hash_footer " +
417 "--algorithm SHA256_RSA4096 " +
418 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900419 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900420 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
421 "--image $(out)",
422}
423
Jiyong Park3eb11f72021-02-23 12:53:30 +0900424prebuilt_etc {
425 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900426 src: "fstab.microdroid",
427 filename: "fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900428 installable: false,
Jiyong Park153d3552021-02-04 08:54:31 +0900429}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900430
431prebuilt_etc {
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900432 name: "microdroid_bootloader",
433 src: ":microdroid_bootloader_gen",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900434 arch: {
435 x86_64: {
436 // For unknown reason, the signed bootloader doesn't work on x86_64. Until the problem
437 // is fixed, let's use the unsigned bootloader for the architecture.
438 // TODO(b/185115783): remove this
Jooyung Hand35952e2021-11-08 17:53:47 +0900439 src: ":microdroid_bootloader_pubkey_replaced",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900440 },
441 },
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900442 filename: "microdroid_bootloader",
443}
444
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900445genrule {
446 name: "microdroid_bootloader_gen",
447 tools: ["avbtool"],
448 srcs: [
Jooyung Hand35952e2021-11-08 17:53:47 +0900449 ":microdroid_bootloader_pubkey_replaced",
450 ":microdroid_sign_key",
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900451 ],
452 out: ["bootloader-signed"],
453 // 1. Copy the input to the output becaise avbtool modifies --image in
454 // place.
455 // 2. Check if the file is big enough. For arm and x86 we have fake
456 // bootloader file whose size is 1. It can't pass avbtool.
457 // 3. Add the hash footer. The partition size is set to (image size + 68KB)
458 // rounded up to 4KB boundary.
Jooyung Hand35952e2021-11-08 17:53:47 +0900459 cmd: "cp $(location :microdroid_bootloader_pubkey_replaced) $(out) && " +
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900460 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
461 "$(location avbtool) add_hash_footer " +
462 "--algorithm SHA256_RSA4096 " +
463 "--partition_name bootloader " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900464 "--key $(location :microdroid_sign_key) " +
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900465 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
466 "--image $(out)" +
467 "; fi",
468}
469
Jooyung Hand35952e2021-11-08 17:53:47 +0900470// Replace avbpubkey of prebuilt bootloader with the avbpubkey of the signing key
471genrule {
472 name: "microdroid_bootloader_pubkey_replaced",
473 tools: ["replace_bytes"],
474 srcs: [
Jooyung Han80245f22021-11-09 17:20:53 +0900475 ":microdroid_crosvm_bootloader", // input (bootloader)
476 ":microdroid_crosvm_bootloader.avbpubkey", // old bytes (old pubkey)
477 ":microdroid_bootloader_avbpubkey_gen", // new bytes (new pubkey)
Jooyung Hand35952e2021-11-08 17:53:47 +0900478 ],
479 out: ["bootloader-pubkey-replaced"],
480 // 1. Copy the input to the output (replace_bytes modifies the file in-place)
481 // 2. Check if the file is big enough. For arm and x86 we have fake
482 // bootloader file whose size is 1. (replace_bytes fails if key not found)
483 // 3. Replace embedded pubkey with new one.
484 cmd: "cp $(location :microdroid_crosvm_bootloader) $(out) && " +
485 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
486 "$(location replace_bytes) $(out) " +
Jooyung Han80245f22021-11-09 17:20:53 +0900487 "$(location :microdroid_crosvm_bootloader.avbpubkey) " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900488 "$(location :microdroid_bootloader_avbpubkey_gen)" +
489 "; fi",
Jooyung Han63513102021-10-29 14:59:59 +0900490}
491
Jooyung Hand35952e2021-11-08 17:53:47 +0900492// Apex keeps a copy of avbpubkey embedded in bootloader so that embedded avbpubkey can be replaced
493// while re-signing bootloader.
494prebuilt_etc {
495 name: "microdroid_bootloader.avbpubkey",
496 src: ":microdroid_bootloader_avbpubkey_gen",
497}
498
499// Generate avbpukey from the signing key
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900500genrule {
Jooyung Hand35952e2021-11-08 17:53:47 +0900501 name: "microdroid_bootloader_avbpubkey_gen",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900502 tools: ["avbtool"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900503 srcs: [":microdroid_sign_key"],
504 out: ["bootloader.pubkey"],
505 cmd: "$(location avbtool) extract_public_key " +
506 "--key $(location :microdroid_sign_key) " +
507 "--output $(out)",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900508}
509
510prebuilt_etc {
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900511 name: "microdroid_uboot_env",
512 src: ":microdroid_uboot_env_gen",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900513 arch: {
514 x86_64: {
515 src: ":microdroid_uboot_env_gen_x86_64",
516 },
517 },
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900518 filename: "uboot_env.img",
519}
520
521genrule {
522 name: "microdroid_uboot_env_gen",
523 tools: ["mkenvimage_host"],
524 srcs: ["uboot-env.txt"],
525 out: ["output.img"],
526 cmd: "$(location mkenvimage_host) -s 4096 -o $(out) $(in)",
527}
Inseob Kim28dddd82021-03-11 17:51:22 +0900528
Jiyong Park89e81cb2021-04-13 13:13:55 +0900529genrule {
530 name: "microdroid_uboot_env_gen_x86_64",
531 tools: ["mkenvimage_host"],
532 srcs: ["uboot-env-x86_64.txt"],
533 out: ["output.img"],
534 cmd: "$(location mkenvimage_host) -s 4096 -o $(out) $(in)",
535}
536
Jooyung Hand35952e2021-11-08 17:53:47 +0900537// Note that keys can be different for filesystem images even though we're using the same key
538// for microdroid. However, the key signing VBmeta should match with the pubkey embedded in
539// bootloader.
540filegroup {
541 name: "microdroid_sign_key",
542 srcs: [":avb_testkey_rsa4096"],
543}
544
Jiyong Park80d8da82021-03-15 23:30:11 +0900545vbmeta {
546 name: "microdroid_vbmeta",
547 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900548 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900549 partitions: [
550 "microdroid_vendor",
551 "microdroid_vendor_boot-5.10",
Jiyong Park80d8da82021-03-15 23:30:11 +0900552 "microdroid",
Jiyong Park52ea0832021-09-01 12:10:18 +0900553 "microdroid_boot-5.10",
Jiyong Park80d8da82021-03-15 23:30:11 +0900554 ],
555}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900556
557prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900558 name: "microdroid.json",
559 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900560}
Jooyung Han017916b2021-04-20 03:57:19 +0900561
562prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900563 name: "microdroid_vendor_manifest",
564 src: "microdroid_vendor_manifest.xml",
565 filename: "manifest.xml",
566 relative_install_path: "vintf",
567 installable: false,
568}
569
570prebuilt_etc {
571 name: "microdroid_vendor_compatibility_matrix",
572 src: "microdroid_vendor_compatibility_matrix.xml",
573 filename: "compatibility_matrix.xml",
574 relative_install_path: "vintf",
575 installable: false,
576}
577
578prebuilt_etc {
579 name: "microdroid_compatibility_matrix",
580 src: "microdroid_compatibility_matrix.xml",
581 filename: "compatibility_matrix.current.xml",
582 relative_install_path: "vintf",
583 installable: false,
584}
585
586prebuilt_etc {
587 name: "microdroid_manifest",
588 src: "microdroid_manifest.xml",
589 filename: "manifest.xml",
590 relative_install_path: "vintf",
591 installable: false,
592}