blob: d1a93c3343b27a2d72f8839b9ca2ba36a6b6865d [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 Panwar94d7faa2022-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++",
61 "logcat",
62 "logd",
Inseob Kimdc2af862021-02-17 15:51:56 +090063 "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",
Oleg Matcovschidca4c2c2022-03-14 06:29:44 -070074 "atrace",
Inseob Kimdc2af862021-02-17 15:51:56 +090075 "debuggerd",
Jiyong Parkc5166842022-01-21 12:54:57 +090076 "diced.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090077 "linker",
Inseob Kim870e76b2021-02-25 17:38:32 +090078 "linkerconfig",
Jiyong Parkc5166842022-01-21 12:54:57 +090079 "servicemanager.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090080 "tombstoned",
Shikha Panwar7afc1392022-03-24 08:54:43 +000081 "tombstone_transmit.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090082 "cgroups.json",
Inseob Kime60307a2022-04-14 03:48:38 +090083 "task_profiles.json",
Jooyung Han1c820732021-04-15 05:16:23 +090084 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090085
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070086 "microdroid_compatibility_matrix",
87 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090088 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070089 "microdroid_manifest",
90 "microdroid_plat_sepolicy_and_mapping.sha256",
Inseob Kimff43be22021-06-07 16:56:56 +090091 "microdroid_property_contexts",
92 "microdroid_service_contexts",
Jooyung Han8a17ef72021-08-04 15:39:54 +090093
Jooyung Hana704cbc2022-04-05 14:57:27 +090094 // TODO(b/195425111) these should be added automatically
95 "libcrypto", // used by many (init_second_stage, microdroid_manager, toybox, etc)
96 "liblzma", // used by init_second_stage
Inseob Kimdc2af862021-02-17 15:51:56 +090097 ] + microdroid_shell_and_utilities,
98 multilib: {
99 common: {
100 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900101 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900102 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900103
Inseob Kimff43be22021-06-07 16:56:56 +0900104 "microdroid_plat_sepolicy.cil",
105 "microdroid_plat_mapping_file",
Inseob Kimdc2af862021-02-17 15:51:56 +0900106 ],
107 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900108 lib64: {
109 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900110 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700111 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700112 "authfs_service",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900113 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900114 "zipfuse",
115 ],
116 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900117 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900118 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900119 base_dir: "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +0900120 dirs: microdroid_rootdirs,
121 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900122 file_contexts: ":microdroid_file_contexts.gen",
Jiyong Parkb552bb62021-01-25 19:12:47 +0900123}
Jiyong Park153d3552021-02-04 08:54:31 +0900124
Inseob Kimdc2af862021-02-17 15:51:56 +0900125prebuilt_etc {
126 name: "microdroid_init_rc",
127 filename: "init.rc",
128 src: "init.rc",
129 relative_install_path: "init/hw",
130 installable: false, // avoid collision with system partition's init.rc
131}
132
Jiyong Park4d228952021-10-18 18:28:57 +0900133prebuilt_etc {
134 name: "microdroid_ueventd_rc",
135 filename: "ueventd.rc",
136 src: "ueventd.rc",
137 installable: false, // avoid collision with system partition's ueventd.rc
138}
139
Inseob Kim23ce1582021-04-06 21:25:57 +0900140prebuilt_root {
141 name: "microdroid_build_prop",
142 filename: "build.prop",
143 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900144 arch: {
145 x86_64: {
146 src: ":microdroid_build_prop_gen_x86_64",
147 },
148 arm64: {
149 src: ":microdroid_build_prop_gen_arm64",
150 },
151 },
Inseob Kim23ce1582021-04-06 21:25:57 +0900152 installable: false,
153}
154
Jiyong Park68f560c2021-05-24 17:38:27 +0900155genrule {
156 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim839ac862022-04-25 18:24:58 +0900157 srcs: [
158 "build.prop",
159 ":buildinfo.prop",
160 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900161 out: ["build.prop.out"],
Inseob Kim839ac862022-04-25 18:24:58 +0900162 cmd: "(echo '# build properties from buildinfo.prop module' && " +
163 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
164 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
165 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
166 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
167 "cat $(location build.prop) && " +
168 "echo ro.product.cpu.abilist=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900169}
170
171genrule {
172 name: "microdroid_build_prop_gen_arm64",
Inseob Kim839ac862022-04-25 18:24:58 +0900173 srcs: [
174 "build.prop",
175 ":buildinfo.prop",
176 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900177 out: ["build.prop.out"],
Inseob Kim839ac862022-04-25 18:24:58 +0900178 cmd: "(echo '# build properties from buildinfo.prop module' && " +
179 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
180 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
181 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
182 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
183 "cat $(location build.prop) && " +
184 "echo ro.product.cpu.abilist=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900185}
186
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000187android_filesystem {
188 name: "microdroid_vendor",
Jiyong Park52ea0832021-09-01 12:10:18 +0900189 partition_name: "vendor",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000190 use_avb: true,
191 deps: [
Andrew Scullf8195942022-01-13 17:37:52 +0000192 "android.hardware.security.dice-service.microdroid",
Inseob Kimafd9dc02021-04-23 14:47:44 +0900193 "microdroid_fstab",
Inseob Kim28dddd82021-03-11 17:51:22 +0900194 "microdroid_precompiled_sepolicy.plat_sepolicy_and_mapping.sha256",
Inseob Kim8f095c92021-05-26 12:04:54 +0900195 "microdroid_vendor_manifest",
196 "microdroid_vendor_compatibility_matrix",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000197 ],
Inseob Kimabcd10a2021-03-25 15:43:07 +0900198 multilib: {
199 common: {
200 deps: [
201 "microdroid_vendor_sepolicy.cil",
202 "microdroid_plat_pub_versioned.cil",
Inseob Kimcd06dca2021-04-30 00:19:00 +0900203 "microdroid_plat_sepolicy_vers.txt",
Inseob Kim998c27f2021-09-27 13:44:09 +0000204 "microdroid_precompiled_sepolicy",
Inseob Kimabcd10a2021-03-25 15:43:07 +0900205 ],
206 },
207 },
Jooyung Hand35952e2021-11-08 17:53:47 +0900208 avb_private_key: ":microdroid_sign_key",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000209 avb_algorithm: "SHA256_RSA4096",
Shikha Panwar94d7faa2022-12-21 15:38:14 +0000210 avb_hash_algorithm: "sha256",
Inseob Kimff43be22021-06-07 16:56:56 +0900211 file_contexts: ":microdroid_vendor_file_contexts.gen",
Jiyong Park6e2bc7c2021-03-03 14:56:18 +0000212}
213
Jiyong Parkc1500e82021-02-24 01:39:51 +0900214logical_partition {
215 name: "microdroid_super",
216 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900217 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900218 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900219 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900220 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900221 filesystem: ":microdroid",
222 },
223 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900224 name: "vendor_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900225 filesystem: ":microdroid_vendor",
Jiyong Parkc1500e82021-02-24 01:39:51 +0900226 },
227 ],
228}
229
Jiyong Parkc8937172021-08-30 18:41:52 +0900230microdroid_boot_cmdline = [
231 "panic=-1",
232 "bootconfig",
Pierre-Clément Tosi94ff9c72022-02-18 14:58:36 +0100233 "ioremap_guard",
Jiyong Parkc8937172021-08-30 18:41:52 +0900234]
Jiyong Park89e81cb2021-04-13 13:13:55 +0900235
Jiyong Park153d3552021-02-04 08:54:31 +0900236bootimg {
Jiyong Parkc8b40032021-02-18 23:15:41 +0900237 name: "microdroid_boot-5.10",
Jiyong Parkdfa3aec2021-03-09 20:32:15 +0900238 // We don't have kernel for arm and x86. But Soong demands one when it builds for
239 // arm or x86 target. Satisfy that by providing an empty file as the kernel.
240 kernel_prebuilt: "empty_kernel",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900241 arch: {
242 arm64: {
243 kernel_prebuilt: ":kernel_prebuilts-5.10-arm64",
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900244 cmdline: microdroid_boot_cmdline,
Jiyong Parkc8b40032021-02-18 23:15:41 +0900245 },
246 x86_64: {
247 kernel_prebuilt: ":kernel_prebuilts-5.10-x86_64",
Jiyong Park747d6362021-10-19 17:12:52 +0900248 cmdline: microdroid_boot_cmdline + [
249 // console=none is to work around the x86 specific u-boot behavior which when
250 // console= option is not found in the kernel commandline console=ttyS0 is
251 // automatically added. By adding console=none, we can prevent u-boot from doing
252 // that. Note that console is set to hvc0 by bootconfig if the VM is configured as
253 // debuggable.
254 "console=none",
255 "acpi=noirq",
256 ],
Jiyong Parkc8b40032021-02-18 23:15:41 +0900257 },
258 },
Jiyong Parkc8937172021-08-30 18:41:52 +0900259
Jiyong Park153d3552021-02-04 08:54:31 +0900260 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900261 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900262 partition_name: "boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900263 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900264 avb_private_key: ":microdroid_sign_key",
Jiyong Park153d3552021-02-04 08:54:31 +0900265}
266
Devin Mooredc9158e2022-01-10 18:51:12 +0000267bootimg {
268 name: "microdroid_init_boot",
269 ramdisk_module: "microdroid_ramdisk-5.10",
270 kernel_prebuilt: "empty_kernel",
271 header_version: "4",
272 partition_name: "init_boot",
273 use_avb: true,
274 avb_private_key: ":microdroid_sign_key",
275}
276
Jiyong Park153d3552021-02-04 08:54:31 +0900277android_filesystem {
278 name: "microdroid_ramdisk-5.10",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900279 deps: [
Inseob Kim97330962021-06-11 12:59:59 +0900280 "init_first_stage",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900281 ],
282 dirs: [
283 "dev",
284 "proc",
285 "sys",
286
287 // TODO(jiyong): remove these
288 "mnt",
289 "debug_ramdisk",
290 "second_stage_resources",
291 ],
292 type: "compressed_cpio",
293}
294
295bootimg {
296 name: "microdroid_vendor_boot-5.10",
297 ramdisk_module: "microdroid_vendor_ramdisk-5.10",
298 dtb_prebuilt: "dummy_dtb.img",
Jiyong Park9ecac552021-03-05 18:51:35 +0900299 header_version: "4",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900300 vendor_boot: true,
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900301 arch: {
302 arm64: {
303 bootconfig: ":microdroid_bootconfig_arm64_gen",
304 },
305 x86_64: {
306 bootconfig: ":microdroid_bootconfig_x86_64_gen",
307 },
308 },
Jiyong Parkc8b40032021-02-18 23:15:41 +0900309 partition_name: "vendor_boot",
Jiyong Parkd4326f32021-03-15 23:25:46 +0900310 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +0900311 avb_private_key: ":microdroid_sign_key",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900312}
313
Jiyong Parkb54646f2022-02-07 11:13:56 +0900314prebuilt_kernel_modules {
315 name: "microdroid_kernel_modules",
Jiyong Park153d3552021-02-04 08:54:31 +0900316 arch: {
317 arm64: {
Jiyong Parkb54646f2022-02-07 11:13:56 +0900318 srcs: [":virt_device_prebuilts_kernel_modules_microdroid-5.10-arm64"],
Jiyong Park153d3552021-02-04 08:54:31 +0900319 },
320 x86_64: {
Jiyong Parkb54646f2022-02-07 11:13:56 +0900321 srcs: [":virt_device_prebuilts_kernel_modules_microdroid-5.10-x86_64"],
Jiyong Park153d3552021-02-04 08:54:31 +0900322 },
323 },
Jiyong Parkb54646f2022-02-07 11:13:56 +0900324 kernel_version: "5.10",
325}
326
327android_filesystem {
328 name: "microdroid_vendor_ramdisk-5.10",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900329 deps: [
330 "microdroid_fstab",
Jiyong Parkb54646f2022-02-07 11:13:56 +0900331 "microdroid_kernel_modules",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900332 ],
333 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900334 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900335 symlinks: [
336 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900337 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900338 name: "first_stage_ramdisk/fstab.microdroid",
339 },
340 {
341 target: "first_stage_ramdisk/lib",
342 name: "lib",
343 },
344 ],
345}
346
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900347genrule {
348 name: "microdroid_bootconfig_arm64_gen",
349 srcs: [
350 "bootconfig.common",
351 "bootconfig.arm64",
352 ],
353 out: ["bootconfig"],
354 cmd: "cat $(in) > $(out)",
355}
356
357genrule {
358 name: "microdroid_bootconfig_x86_64_gen",
359 srcs: [
360 "bootconfig.common",
361 "bootconfig.x86_64",
362 ],
363 out: ["bootconfig"],
364 cmd: "cat $(in) > $(out)",
365}
366
Jiyong Parkacf31b02021-11-04 20:45:14 +0900367vbmeta {
368 name: "microdroid_vbmeta_bootconfig",
369 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900370 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900371 chained_partitions: [
372 {
373 name: "bootconfig",
Jooyung Hand35952e2021-11-08 17:53:47 +0900374 private_key: ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900375 },
Jiyong Park34ad9182022-01-28 21:29:48 +0900376 {
377 name: "uboot_env",
378 private_key: ":microdroid_sign_key",
379 },
Jiyong Parkacf31b02021-11-04 20:45:14 +0900380 ],
381}
382
383// See external/avb/avbtool.py
384// MAX_VBMETA_SIZE=64KB, MAX_FOOTER_SIZE=4KB
385avb_hash_footer_kb = "68"
386
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900387prebuilt_etc {
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900388 name: "microdroid_bootconfig_normal",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900389 src: ":microdroid_bootconfig_normal_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900390 filename: "microdroid_bootconfig.normal",
391}
392
393prebuilt_etc {
394 name: "microdroid_bootconfig_app_debuggable",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900395 src: ":microdroid_bootconfig_app_debuggable_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900396 filename: "microdroid_bootconfig.app_debuggable",
397}
398
399prebuilt_etc {
400 name: "microdroid_bootconfig_full_debuggable",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900401 src: ":microdroid_bootconfig_full_debuggable_gen",
Jiyong Parkc2a49cc2021-10-15 00:02:12 +0900402 filename: "microdroid_bootconfig.full_debuggable",
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900403}
404
Jiyong Parkacf31b02021-11-04 20:45:14 +0900405// TODO(jiyong): make a new module type that does the avb signing
406genrule {
407 name: "microdroid_bootconfig_normal_gen",
408 tools: ["avbtool"],
409 srcs: [
410 "bootconfig.normal",
Jooyung Hand35952e2021-11-08 17:53:47 +0900411 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900412 ],
413 out: ["microdroid_bootconfig.normal"],
414 cmd: "cp $(location bootconfig.normal) $(out) && " +
415 "$(location avbtool) add_hash_footer " +
416 "--algorithm SHA256_RSA4096 " +
417 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900418 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900419 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
420 "--image $(out)",
421}
422
423genrule {
424 name: "microdroid_bootconfig_app_debuggable_gen",
425 tools: ["avbtool"],
426 srcs: [
427 "bootconfig.app_debuggable",
Jooyung Hand35952e2021-11-08 17:53:47 +0900428 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900429 ],
430 out: ["microdroid_bootconfig.app_debuggable"],
431 cmd: "cp $(location bootconfig.app_debuggable) $(out) && " +
432 "$(location avbtool) add_hash_footer " +
433 "--algorithm SHA256_RSA4096 " +
434 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900435 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900436 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
437 "--image $(out)",
438}
439
440genrule {
441 name: "microdroid_bootconfig_full_debuggable_gen",
442 tools: ["avbtool"],
443 srcs: [
444 "bootconfig.full_debuggable",
Jooyung Hand35952e2021-11-08 17:53:47 +0900445 ":microdroid_sign_key",
Jiyong Parkacf31b02021-11-04 20:45:14 +0900446 ],
447 out: ["microdroid_bootconfig.full_debuggable"],
448 cmd: "cp $(location bootconfig.full_debuggable) $(out) && " +
449 "$(location avbtool) add_hash_footer " +
450 "--algorithm SHA256_RSA4096 " +
451 "--partition_name bootconfig " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900452 "--key $(location :microdroid_sign_key) " +
Jiyong Parkacf31b02021-11-04 20:45:14 +0900453 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
454 "--image $(out)",
455}
456
Jiyong Park3eb11f72021-02-23 12:53:30 +0900457prebuilt_etc {
458 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900459 src: "fstab.microdroid",
460 filename: "fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900461 installable: false,
Jiyong Park153d3552021-02-04 08:54:31 +0900462}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900463
464prebuilt_etc {
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900465 name: "microdroid_bootloader",
466 src: ":microdroid_bootloader_gen",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900467 arch: {
468 x86_64: {
469 // For unknown reason, the signed bootloader doesn't work on x86_64. Until the problem
470 // is fixed, let's use the unsigned bootloader for the architecture.
471 // TODO(b/185115783): remove this
Jooyung Hand35952e2021-11-08 17:53:47 +0900472 src: ":microdroid_bootloader_pubkey_replaced",
Jiyong Park89e81cb2021-04-13 13:13:55 +0900473 },
474 },
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900475 filename: "microdroid_bootloader",
476}
477
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900478genrule {
479 name: "microdroid_bootloader_gen",
480 tools: ["avbtool"],
481 srcs: [
Jooyung Hand35952e2021-11-08 17:53:47 +0900482 ":microdroid_bootloader_pubkey_replaced",
483 ":microdroid_sign_key",
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900484 ],
485 out: ["bootloader-signed"],
486 // 1. Copy the input to the output becaise avbtool modifies --image in
487 // place.
488 // 2. Check if the file is big enough. For arm and x86 we have fake
489 // bootloader file whose size is 1. It can't pass avbtool.
490 // 3. Add the hash footer. The partition size is set to (image size + 68KB)
491 // rounded up to 4KB boundary.
Jooyung Hand35952e2021-11-08 17:53:47 +0900492 cmd: "cp $(location :microdroid_bootloader_pubkey_replaced) $(out) && " +
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900493 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
494 "$(location avbtool) add_hash_footer " +
495 "--algorithm SHA256_RSA4096 " +
496 "--partition_name bootloader " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900497 "--key $(location :microdroid_sign_key) " +
Jiyong Park66aa0fb2021-04-08 19:10:44 +0900498 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
499 "--image $(out)" +
500 "; fi",
501}
502
Jooyung Hand35952e2021-11-08 17:53:47 +0900503// Replace avbpubkey of prebuilt bootloader with the avbpubkey of the signing key
504genrule {
505 name: "microdroid_bootloader_pubkey_replaced",
506 tools: ["replace_bytes"],
507 srcs: [
Jooyung Han80245f22021-11-09 17:20:53 +0900508 ":microdroid_crosvm_bootloader", // input (bootloader)
509 ":microdroid_crosvm_bootloader.avbpubkey", // old bytes (old pubkey)
510 ":microdroid_bootloader_avbpubkey_gen", // new bytes (new pubkey)
Jooyung Hand35952e2021-11-08 17:53:47 +0900511 ],
512 out: ["bootloader-pubkey-replaced"],
513 // 1. Copy the input to the output (replace_bytes modifies the file in-place)
514 // 2. Check if the file is big enough. For arm and x86 we have fake
515 // bootloader file whose size is 1. (replace_bytes fails if key not found)
516 // 3. Replace embedded pubkey with new one.
517 cmd: "cp $(location :microdroid_crosvm_bootloader) $(out) && " +
518 "if [ $$(stat --format=%s $(out)) -gt 4096 ]; then " +
519 "$(location replace_bytes) $(out) " +
Jooyung Han80245f22021-11-09 17:20:53 +0900520 "$(location :microdroid_crosvm_bootloader.avbpubkey) " +
Jooyung Hand35952e2021-11-08 17:53:47 +0900521 "$(location :microdroid_bootloader_avbpubkey_gen)" +
522 "; fi",
Jooyung Han63513102021-10-29 14:59:59 +0900523}
524
Jooyung Hand35952e2021-11-08 17:53:47 +0900525// Apex keeps a copy of avbpubkey embedded in bootloader so that embedded avbpubkey can be replaced
526// while re-signing bootloader.
527prebuilt_etc {
528 name: "microdroid_bootloader.avbpubkey",
529 src: ":microdroid_bootloader_avbpubkey_gen",
530}
531
532// Generate avbpukey from the signing key
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900533genrule {
Jooyung Hand35952e2021-11-08 17:53:47 +0900534 name: "microdroid_bootloader_avbpubkey_gen",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900535 tools: ["avbtool"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900536 srcs: [":microdroid_sign_key"],
537 out: ["bootloader.pubkey"],
538 cmd: "$(location avbtool) extract_public_key " +
539 "--key $(location :microdroid_sign_key) " +
540 "--output $(out)",
Jooyung Han31b1c2b2021-10-27 03:35:42 +0900541}
542
543prebuilt_etc {
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900544 name: "microdroid_uboot_env",
545 src: ":microdroid_uboot_env_gen",
546 filename: "uboot_env.img",
547}
548
549genrule {
550 name: "microdroid_uboot_env_gen",
Jiyong Park34ad9182022-01-28 21:29:48 +0900551 tools: [
Ram Muthiah3b031a62022-04-05 06:06:43 -0700552 "mkenvimage_slim",
Jiyong Park34ad9182022-01-28 21:29:48 +0900553 "avbtool",
554 ],
555 srcs: [
556 "uboot-env.txt",
557 ":microdroid_sign_key",
558 ],
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900559 out: ["output.img"],
Ram Muthiah3b031a62022-04-05 06:06:43 -0700560 cmd: "$(location mkenvimage_slim) -output_path $(out) -input_path $(location uboot-env.txt) && " +
Jiyong Park34ad9182022-01-28 21:29:48 +0900561 "$(location avbtool) add_hash_footer " +
562 "--algorithm SHA256_RSA4096 " +
563 "--partition_name uboot_env " +
564 "--key $(location :microdroid_sign_key) " +
565 "--partition_size $$(( " + avb_hash_footer_kb + " * 1024 + ( $$(stat --format=%s $(out)) + 4096 - 1 ) / 4096 * 4096 )) " +
566 "--image $(out)",
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900567}
Inseob Kim28dddd82021-03-11 17:51:22 +0900568
Jooyung Hand35952e2021-11-08 17:53:47 +0900569// Note that keys can be different for filesystem images even though we're using the same key
570// for microdroid. However, the key signing VBmeta should match with the pubkey embedded in
571// bootloader.
572filegroup {
573 name: "microdroid_sign_key",
574 srcs: [":avb_testkey_rsa4096"],
575}
576
Jiyong Park80d8da82021-03-15 23:30:11 +0900577vbmeta {
578 name: "microdroid_vbmeta",
579 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900580 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900581 partitions: [
582 "microdroid_vendor",
583 "microdroid_vendor_boot-5.10",
Jiyong Park80d8da82021-03-15 23:30:11 +0900584 "microdroid",
Jiyong Park52ea0832021-09-01 12:10:18 +0900585 "microdroid_boot-5.10",
Devin Mooredc9158e2022-01-10 18:51:12 +0000586 "microdroid_init_boot",
Jiyong Park80d8da82021-03-15 23:30:11 +0900587 ],
588}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900589
590prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900591 name: "microdroid.json",
592 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900593}
Jooyung Han017916b2021-04-20 03:57:19 +0900594
595prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900596 name: "microdroid_vendor_manifest",
597 src: "microdroid_vendor_manifest.xml",
598 filename: "manifest.xml",
599 relative_install_path: "vintf",
600 installable: false,
601}
602
603prebuilt_etc {
604 name: "microdroid_vendor_compatibility_matrix",
605 src: "microdroid_vendor_compatibility_matrix.xml",
606 filename: "compatibility_matrix.xml",
607 relative_install_path: "vintf",
608 installable: false,
609}
610
611prebuilt_etc {
612 name: "microdroid_compatibility_matrix",
613 src: "microdroid_compatibility_matrix.xml",
614 filename: "compatibility_matrix.current.xml",
615 relative_install_path: "vintf",
616 installable: false,
617}
618
619prebuilt_etc {
620 name: "microdroid_manifest",
621 src: "microdroid_manifest.xml",
622 filename: "manifest.xml",
623 relative_install_path: "vintf",
624 installable: false,
625}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700626
627prebuilt_etc {
628 name: "microdroid_event-log-tags",
629 src: "microdroid_event-log-tags",
630 filename: "event-log-tags",
631 installable: false,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900632}