blob: fac212a992ecb1ff607c15fd9ee78ceae1a3bf76 [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 "debug_ramdisk",
20 "mnt",
Inseob Kimafd9dc02021-04-23 14:47:44 +090021 "data",
Inseob Kim5ffc0822021-02-09 21:23:36 +090022
23 "apex",
24 "linkerconfig",
25 "second_stage_resources",
Nikita Ioffeaa6858c2023-07-04 01:37:41 +010026
27 // Ideally we should only create the /vendor for Microdroid VMs that will mount /vendor, but
28 // for the time being we will just create it unconditionally.
29 "vendor",
Inseob Kim5ffc0822021-02-09 21:23:36 +090030]
31
32microdroid_symlinks = [
33 {
34 target: "/sys/kernel/debug",
35 name: "d",
36 },
Inseob Kim13ca2c82021-04-23 09:12:29 +090037 {
38 target: "/system/etc",
39 name: "etc",
40 },
Inseob Kim4e207a12021-08-04 03:36:47 +000041 {
42 target: "/system/bin",
43 name: "bin",
44 },
Inseob Kim5ffc0822021-02-09 21:23:36 +090045]
46
Inseob Kim7e0ba432024-07-26 11:15:31 +090047android_system_image {
Jiyong Parkb552bb62021-01-25 19:12:47 +090048 name: "microdroid",
49 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +090050 avb_private_key: ":microdroid_sign_key",
Jiyong Parkb552bb62021-01-25 19:12:47 +090051 avb_algorithm: "SHA256_RSA4096",
Shikha Panwar85620722022-12-21 15:38:14 +000052 avb_hash_algorithm: "sha256",
Cole Fausta4448a42024-12-04 13:27:24 -080053 use_fec: false,
Jiyong Parkd4326f32021-03-15 23:25:46 +090054 partition_name: "system",
Jiyong Parkb552bb62021-01-25 19:12:47 +090055 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +010056 "init_second_stage.microdroid",
Inseob Kim23ce1582021-04-06 21:25:57 +090057 "microdroid_build_prop",
Jaewan Kimb24d1dc2023-02-13 15:34:56 +090058 "microdroid_init_debug_policy",
Jiyong Park40699612021-05-24 16:55:06 +090059 "microdroid_init_rc",
Jiyong Park4d228952021-10-18 18:28:57 +090060 "microdroid_ueventd_rc",
Jiyong Park40699612021-05-24 16:55:06 +090061 "microdroid_launcher",
Jooyung Han7ce2e532021-06-16 16:52:02 +090062
Jooyung Han837eef52021-05-15 11:33:48 +090063 "libbinder_ndk",
Inseob Kimdc2af862021-02-17 15:51:56 +090064 "libstdc++",
Jooyung Han017916b2021-04-20 03:57:19 +090065
66 // "com.android.adbd" requires these,
67 "libadbd_auth",
68 "libadbd_fs",
69
Jooyung Han730b7b82021-05-12 14:09:38 +090070 // "com.android.art" requires
71 "heapprofd_client_api",
Victor Hsieh527b81d2021-06-11 10:41:11 -070072 "libartpalette-system",
Jooyung Han730b7b82021-05-12 14:09:38 +090073
Jooyung Hanb6a52152022-12-12 11:20:23 +090074 "apexd.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090075 "debuggerd",
76 "linker",
Inseob Kimdc2af862021-02-17 15:51:56 +090077 "cgroups.json",
Inseob Kime60307a2022-04-14 03:48:38 +090078 "task_profiles.json",
Jooyung Han1c820732021-04-15 05:16:23 +090079 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090080
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070081 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090082 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070083 "microdroid_manifest",
Inseob Kimff43be22021-06-07 16:56:56 +090084 "microdroid_property_contexts",
Shraddha Basantwania9a9c4f2025-02-25 09:51:48 -080085 "e2fsck.microdroid",
Shikha Panwar5cb5b992022-12-12 11:51:07 +000086 "mke2fs.microdroid",
Shraddha Basantwania9a9c4f2025-02-25 09:51:48 -080087 "resize2fs.microdroid",
Nikita Ioffe57b4dfc2023-06-14 20:29:37 +000088 "microdroid_fstab",
Jooyung Han8a17ef72021-08-04 15:39:54 +090089
Alice Wang2e57b082022-10-27 10:39:01 +000090 "libvm_payload", // used by payload to interact with microdroid manager
Jiyong Park61eebed2022-12-20 19:24:48 +090091
Jiyong Park5f7ae032022-12-22 10:24:39 +090092 "prng_seeder_microdroid",
Nikita Ioffe858fa052023-03-03 00:46:35 +000093
94 // Binaries required to capture traces in Microdroid.
95 "atrace",
96 "traced",
97 "traced_probes",
98 "perfetto",
Inseob Kim7e0ba432024-07-26 11:15:31 +090099 ] + select(release_flag("RELEASE_AVF_ENABLE_MULTI_TENANT_MICRODROID_VM"), {
100 true: [
101 "microdroid_etc_passwd",
102 "microdroid_etc_group",
103 ],
104 default: [],
105 }) + microdroid_shell_and_utilities,
Inseob Kimdc2af862021-02-17 15:51:56 +0900106 multilib: {
107 common: {
108 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900109 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900110 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900111
Jiyong Park9117f012022-07-07 15:24:06 +0900112 "microdroid_crashdump_initrd",
Nikita Ioffe536bc552023-06-14 20:29:37 +0000113 "microdroid_precompiled_sepolicy",
Inseob Kimdc2af862021-02-17 15:51:56 +0900114 ],
115 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900116 lib64: {
117 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900118 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700119 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700120 "authfs_service",
Shikha Panwar566c9672022-11-15 14:39:58 +0000121 "encryptedstore",
Jiyong Park9e5ae632022-07-08 14:47:23 +0900122 "microdroid_kexec",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900123 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900124 "zipfuse",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900125 ] + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
126 true: ["derive_microdroid_vendor_dice_node"],
127 default: [],
128 }),
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900129 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900130 },
Colin Crossca0049b2023-03-22 16:03:19 -0700131 arch: {
132 // b/273792258: These could be in multilib.lib64 except that
133 // microdroid_crashdump_kernel doesn't exist for riscv64 yet
134 arm64: {
135 deps: [
136 "microdroid_crashdump_kernel",
137 ],
138 },
139 x86_64: {
140 deps: [
141 "microdroid_crashdump_kernel",
142 ],
143 },
144 },
Spandan Dasc2180fc2024-11-11 21:27:05 +0000145 linker_config: {
Kiyoung Kim27cbf4c2024-11-07 17:13:26 +0900146 gen_linker_config: true,
147 linker_config_srcs: ["linker.config.json"],
148 },
Inseob Kima313e562021-02-15 17:04:39 +0900149 base_dir: "system",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900150 dirs: microdroid_rootdirs + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
151 true: ["microdroid_resources"],
152 default: [],
153 }),
Inseob Kim5ffc0822021-02-09 21:23:36 +0900154 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900155 file_contexts: ":microdroid_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900156 // For deterministic output, use fake_timestamp, hard-coded uuid
157 fake_timestamp: "1611569676",
158 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/system'))"
159 uuid: "5fe079c6-f01a-52be-87d3-d415231a72ad",
Jiyong Parkb552bb62021-01-25 19:12:47 +0900160}
Jiyong Park153d3552021-02-04 08:54:31 +0900161
Inseob Kimdc2af862021-02-17 15:51:56 +0900162prebuilt_etc {
163 name: "microdroid_init_rc",
164 filename: "init.rc",
165 src: "init.rc",
166 relative_install_path: "init/hw",
Jiyong Park5f939f92024-05-01 16:18:14 +0900167 no_full_install: true, // avoid collision with system partition's init.rc
Inseob Kimdc2af862021-02-17 15:51:56 +0900168}
169
Jiyong Park4d228952021-10-18 18:28:57 +0900170prebuilt_etc {
171 name: "microdroid_ueventd_rc",
172 filename: "ueventd.rc",
173 src: "ueventd.rc",
Jiyong Park5f939f92024-05-01 16:18:14 +0900174 no_full_install: true, // avoid collision with system partition's ueventd.rc
Jiyong Park4d228952021-10-18 18:28:57 +0900175}
176
Alan Stokes1294f942023-08-21 14:34:12 +0100177prebuilt_etc {
178 name: "microdroid_etc_passwd",
179 src: "microdroid_passwd",
180 filename: "passwd",
Jiyong Park5f939f92024-05-01 16:18:14 +0900181 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100182}
183
184prebuilt_etc {
185 name: "microdroid_etc_group",
186 src: "microdroid_group",
187 filename: "group",
Jiyong Park5f939f92024-05-01 16:18:14 +0900188 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100189}
190
Inseob Kim23ce1582021-04-06 21:25:57 +0900191prebuilt_root {
192 name: "microdroid_build_prop",
193 filename: "build.prop",
194 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900195 arch: {
196 x86_64: {
197 src: ":microdroid_build_prop_gen_x86_64",
198 },
199 arm64: {
200 src: ":microdroid_build_prop_gen_arm64",
201 },
202 },
Jiyong Park5f939f92024-05-01 16:18:14 +0900203 no_full_install: true,
Inseob Kim23ce1582021-04-06 21:25:57 +0900204}
205
Cole Faust316e6422024-10-22 16:31:03 -0700206java_genrule {
Jiyong Park68f560c2021-05-24 17:38:27 +0900207 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900208 srcs: [
209 "build.prop",
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000210 ":system-build.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900211 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900212 out: ["build.prop.out"],
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000213 cmd: "(echo '# build properties from system/build.prop' && " +
214 "grep ro\\.build\\.version\\.codename= $(location :system-build.prop) && " +
215 "grep ro\\.build\\.version\\.release= $(location :system-build.prop) && " +
216 "grep ro\\.build\\.version\\.sdk= $(location :system-build.prop) && " +
217 "grep ro\\.build\\.version\\.security_patch= $(location :system-build.prop) && " +
218 "grep ro\\.build\\.version\\.known_codenames= $(location :system-build.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900219 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900220 "echo ro.product.cpu.abilist=x86_64 && " +
221 "echo ro.product.cpu.abi=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900222}
223
Cole Faust316e6422024-10-22 16:31:03 -0700224java_genrule {
Jiyong Park68f560c2021-05-24 17:38:27 +0900225 name: "microdroid_build_prop_gen_arm64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900226 srcs: [
227 "build.prop",
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000228 ":system-build.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900229 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900230 out: ["build.prop.out"],
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000231 cmd: "(echo '# build properties from system/build.prop' && " +
232 "grep ro\\.build\\.version\\.codename= $(location :system-build.prop) && " +
233 "grep ro\\.build\\.version\\.release= $(location :system-build.prop) && " +
234 "grep ro\\.build\\.version\\.sdk= $(location :system-build.prop) && " +
235 "grep ro\\.build\\.version\\.security_patch= $(location :system-build.prop) && " +
236 "grep ro\\.build\\.version\\.known_codenames= $(location :system-build.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900237 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900238 "echo ro.product.cpu.abilist=arm64-v8a && " +
239 "echo ro.product.cpu.abi=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900240}
241
Nikita Ioffee1112032023-11-13 15:09:39 +0000242// Need to keep microdroid_vendor for the release configurations that don't
243// have RELEASE_AVF_ENABLE_VENDOR_MODULES build flag enabled.
244android_filesystem {
245 name: "microdroid_vendor",
246 partition_name: "vendor",
247 use_avb: true,
248 avb_private_key: ":microdroid_sign_key",
249 avb_algorithm: "SHA256_RSA4096",
250 avb_hash_algorithm: "sha256",
Cole Fausta4448a42024-12-04 13:27:24 -0800251 use_fec: false,
Nikita Ioffee1112032023-11-13 15:09:39 +0000252 file_contexts: ":microdroid_vendor_file_contexts.gen",
253 // For deterministic output, use fake_timestamp, hard-coded uuid
254 fake_timestamp: "1611569676",
255 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/vendor'))"
256 uuid: "156d40d7-8d8e-5c99-8913-ec82de549a70",
257}
258
259soong_config_module_type {
260 name: "flag_aware_microdroid_super_partition",
261 module_type: "logical_partition",
262 config_namespace: "ANDROID",
263 bool_variables: [
264 "release_avf_enable_vendor_modules",
265 ],
266 properties: [
267 "default_group",
268 ],
269}
270
271flag_aware_microdroid_super_partition {
Jiyong Parkc1500e82021-02-24 01:39:51 +0900272 name: "microdroid_super",
273 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900274 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900275 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900276 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900277 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900278 filesystem: ":microdroid",
279 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900280 ],
Nikita Ioffee1112032023-11-13 15:09:39 +0000281 soong_config_variables: {
282 release_avf_enable_vendor_modules: {
Nikita Ioffe2814dd32023-11-17 15:41:36 +0000283 conditions_default: {
284 default_group: [
285 {
286 name: "vendor_a",
287 filesystem: ":microdroid_vendor",
288 },
289 ],
290 },
Nikita Ioffee1112032023-11-13 15:09:39 +0000291 },
292 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900293}
294
Inseob Kim7e0ba432024-07-26 11:15:31 +0900295android_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900296 name: "microdroid_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900297 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +0100298 "init_first_stage.microdroid",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900299 ],
300 dirs: [
301 "dev",
302 "proc",
303 "sys",
304
Jiyong Parkc8b40032021-02-18 23:15:41 +0900305 "mnt",
306 "debug_ramdisk",
307 "second_stage_resources",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900308 ] + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
309 true: ["microdroid_resources"],
310 default: [],
311 }),
Jiyong Parkc8b40032021-02-18 23:15:41 +0900312 type: "compressed_cpio",
313}
314
Jiyong Parkb54646f2022-02-07 11:13:56 +0900315android_filesystem {
Nikita Ioffe2c3bc222024-03-26 20:51:00 +0000316 name: "microdroid_first_stage_ramdisk",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900317 deps: [
318 "microdroid_fstab",
319 ],
320 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900321 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900322 symlinks: [
323 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900324 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900325 name: "first_stage_ramdisk/fstab.microdroid",
326 },
327 {
328 target: "first_stage_ramdisk/lib",
329 name: "lib",
330 },
331 ],
332}
333
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900334genrule {
335 name: "microdroid_bootconfig_arm64_gen",
336 srcs: [
337 "bootconfig.common",
338 "bootconfig.arm64",
339 ],
340 out: ["bootconfig"],
341 cmd: "cat $(in) > $(out)",
342}
343
344genrule {
345 name: "microdroid_bootconfig_x86_64_gen",
346 srcs: [
347 "bootconfig.common",
348 "bootconfig.x86_64",
349 ],
350 out: ["bootconfig"],
351 cmd: "cat $(in) > $(out)",
352}
353
Nikita Ioffef49350e2024-11-01 16:11:48 +0000354filegroup {
355 name: "microdroid_16k_bootconfig_x86_64_gen",
356 srcs: ["bootconfig.x86_64_16k"],
357}
358
Jiyong Park3eb11f72021-02-23 12:53:30 +0900359prebuilt_etc {
360 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900361 src: "fstab.microdroid",
362 filename: "fstab.microdroid",
Jiyong Park5f939f92024-05-01 16:18:14 +0900363 no_full_install: true,
Jiyong Park153d3552021-02-04 08:54:31 +0900364}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900365
Jooyung Han64214832022-04-21 14:30:04 +0900366// python -c "import hashlib; print(hashlib.sha256(b'bootloader').hexdigest())"
367bootloader_salt = "3b4a12881d11f33cff968a24d7c53723a8232cde9a8d91e29fdbd6a95ae6adf0"
368
Jooyung Hand35952e2021-11-08 17:53:47 +0900369filegroup {
370 name: "microdroid_sign_key",
Pierre-Clément Tosi2188d802024-05-24 10:56:26 +0100371 srcs: [":pvmfw_embedded_key"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900372}
373
Inseob Kim7e0ba432024-07-26 11:15:31 +0900374vbmeta {
Jiyong Park80d8da82021-03-15 23:30:11 +0900375 name: "microdroid_vbmeta",
376 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900377 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900378 partitions: [
Jiyong Park80d8da82021-03-15 23:30:11 +0900379 "microdroid",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900380 ] + select(release_flag("RELEASE_AVF_ENABLE_VENDOR_MODULES"), {
381 true: [],
382 default: ["microdroid_vendor"],
383 }),
Jiyong Park80d8da82021-03-15 23:30:11 +0900384}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900385
386prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900387 name: "microdroid.json",
388 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900389}
Jooyung Han017916b2021-04-20 03:57:19 +0900390
391prebuilt_etc {
Nikita Ioffef49350e2024-11-01 16:11:48 +0000392 name: "microdroid_16k.json",
393 src: "microdroid_16k.json",
394}
395
396prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900397 name: "microdroid_manifest",
398 src: "microdroid_manifest.xml",
399 filename: "manifest.xml",
400 relative_install_path: "vintf",
Jiyong Park5f939f92024-05-01 16:18:14 +0900401 no_full_install: true,
Inseob Kim8f095c92021-05-26 12:04:54 +0900402}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700403
404prebuilt_etc {
405 name: "microdroid_event-log-tags",
406 src: "microdroid_event-log-tags",
407 filename: "event-log-tags",
Jiyong Park5f939f92024-05-01 16:18:14 +0900408 no_full_install: true,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900409}
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000410
411filegroup {
Seungjae Yooe85831e2022-12-12 09:34:58 +0900412 name: "microdroid_bootconfig_debuggable_src",
413 srcs: ["bootconfig.debuggable"],
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000414}
415
416filegroup {
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000417 name: "microdroid_bootconfig_normal_src",
418 srcs: ["bootconfig.normal"],
419}
Shikha Panwared8ace42022-09-28 12:52:16 +0000420
Alice Wangc5c966d2023-01-04 10:44:07 +0000421// python -c "import hashlib; print(hashlib.sha256(b'initrd_normal').hexdigest())"
422initrd_normal_salt = "8041a07d54ac82290f6d90bac1fa8d7fdbc4db974d101d60faf294749d1ebaf8"
423
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900424avb_gen_vbmeta_image_defaults {
425 name: "microdroid_initrd_defaults",
Alice Wangc5c966d2023-01-04 10:44:07 +0000426 enabled: false,
427 arch: {
428 // Microdroid kernel is only available in these architectures.
429 arm64: {
430 enabled: true,
431 },
432 x86_64: {
433 enabled: true,
434 },
435 },
436}
437
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900438avb_gen_vbmeta_image_defaults {
439 name: "microdroid_initrd_normal_defaults",
440 defaults: ["microdroid_initrd_defaults"],
Inseob Kim77c7f712023-11-06 17:01:02 +0900441 partition_name: "initrd_normal",
442 salt: initrd_normal_salt,
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900443}
444
445avb_gen_vbmeta_image {
446 name: "microdroid_initrd_normal_hashdesc",
447 defaults: ["microdroid_initrd_normal_defaults"],
448 src: ":microdroid_initrd_normal",
Inseob Kim77c7f712023-11-06 17:01:02 +0900449}
450
Nikita Ioffef49350e2024-11-01 16:11:48 +0000451avb_gen_vbmeta_image {
452 name: "microdroid_16k_initrd_normal_hashdesc",
453 defaults: ["microdroid_initrd_normal_defaults"],
454 src: ":microdroid_16k_initrd_normal",
455}
456
Alice Wangc5c966d2023-01-04 10:44:07 +0000457// python -c "import hashlib; print(hashlib.sha256(b'initrd_debug').hexdigest())"
458initrd_debug_salt = "8ab9dc9cb7e6456700ff6ef18c6b4c3acc24c5fa5381b829563f8d7a415d869a"
459
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900460avb_gen_vbmeta_image_defaults {
461 name: "microdroid_initrd_debug_defaults",
462 defaults: ["microdroid_initrd_defaults"],
Alice Wangc41ebfb2023-01-11 09:06:32 +0000463 partition_name: "initrd_debug",
Alice Wangc5c966d2023-01-04 10:44:07 +0000464 salt: initrd_debug_salt,
Alice Wangc5c966d2023-01-04 10:44:07 +0000465}
466
Inseob Kim77c7f712023-11-06 17:01:02 +0900467avb_gen_vbmeta_image {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900468 name: "microdroid_initrd_debug_hashdesc",
469 defaults: ["microdroid_initrd_debug_defaults"],
470 src: ":microdroid_initrd_debuggable",
Inseob Kim77c7f712023-11-06 17:01:02 +0900471}
472
Nikita Ioffef49350e2024-11-01 16:11:48 +0000473avb_gen_vbmeta_image {
474 name: "microdroid_16k_initrd_debug_hashdesc",
475 defaults: ["microdroid_initrd_debug_defaults"],
476 src: ":microdroid_16k_initrd_debuggable",
477}
478
Nikolina Ilicda207762024-12-04 13:55:46 +0000479avb_add_hash_footer_defaults {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900480 name: "microdroid_kernel_signed_defaults",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100481 src: ":empty_file",
Alice Wang8aa3cb12023-01-11 09:04:04 +0000482 partition_name: "boot",
Shikha Panwared8ace42022-09-28 12:52:16 +0000483 private_key: ":microdroid_sign_key",
484 salt: bootloader_salt,
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000485 enabled: false,
486 arch: {
487 arm64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000488 enabled: true,
489 },
490 x86_64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000491 enabled: true,
492 },
493 },
Nikolina Ilicda207762024-12-04 13:55:46 +0000494}
495
Shikha Panwar86f041f2025-03-06 12:36:03 +0000496MICRODROID_GKI_ROLLBACK_INDEX = 2
Nikolina Ilicda207762024-12-04 13:55:46 +0000497
Shikha Panwar3b763342025-03-18 17:55:30 +0000498avb_add_hash_footer_defaults {
Nikolina Ilicda207762024-12-04 13:55:46 +0000499 name: "microdroid_kernel_cap_defaults",
Shikha Panwar2a788662023-09-11 14:04:24 +0000500 // Below are properties that are conditionally set depending on value of build flags.
Shikha Panwar3b763342025-03-18 17:55:30 +0000501 props: [
502 {
503 name: "com.android.virt.cap",
504 value: "secretkeeper_protection",
Shikha Panwar2a788662023-09-11 14:04:24 +0000505 },
Shikha Panwar3b763342025-03-18 17:55:30 +0000506 ],
507 rollback_index: MICRODROID_GKI_ROLLBACK_INDEX,
Shikha Panwared8ace42022-09-28 12:52:16 +0000508}
509
Shikha Panwar3b763342025-03-18 17:55:30 +0000510avb_add_hash_footer_defaults {
Nikolina Ilicda207762024-12-04 13:55:46 +0000511 name: "microdroid_kernel_cap_with_uefi_defaults",
Shikha Panwar3b763342025-03-18 17:55:30 +0000512 rollback_index: MICRODROID_GKI_ROLLBACK_INDEX,
513 props: [
514 {
515 name: "com.android.virt.cap",
516 value: "secretkeeper_protection|supports_uefi_boot",
Nikolina Ilicda207762024-12-04 13:55:46 +0000517 },
Shikha Panwar3b763342025-03-18 17:55:30 +0000518 ],
Nikolina Ilicda207762024-12-04 13:55:46 +0000519}
520
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900521avb_add_hash_footer {
522 name: "microdroid_kernel_signed",
Nikolina Ilicda207762024-12-04 13:55:46 +0000523 defaults: [
524 "microdroid_kernel_signed_defaults",
525 "microdroid_kernel_cap_defaults",
526 ],
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900527 filename: "microdroid_kernel",
Inseob Kim77c7f712023-11-06 17:01:02 +0900528 arch: {
529 arm64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000530 src: ":microdroid_kernel_prebuilt-arm64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900531 },
532 x86_64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000533 src: ":microdroid_kernel_prebuilt-x86_64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900534 },
535 },
536 include_descriptors_from_images: [
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900537 ":microdroid_initrd_normal_hashdesc",
538 ":microdroid_initrd_debug_hashdesc",
Inseob Kim77c7f712023-11-06 17:01:02 +0900539 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900540}
541
Shikha Panwared8ace42022-09-28 12:52:16 +0000542prebuilt_etc {
543 name: "microdroid_kernel",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100544 src: ":empty_file",
Shikha Panwared8ace42022-09-28 12:52:16 +0000545 relative_install_path: "fs",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000546 arch: {
547 arm64: {
548 src: ":microdroid_kernel_signed",
549 },
550 x86_64: {
551 src: ":microdroid_kernel_signed",
552 },
553 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000554}
Inseob Kim77c7f712023-11-06 17:01:02 +0900555
Nikita Ioffef49350e2024-11-01 16:11:48 +0000556avb_add_hash_footer {
557 name: "microdroid_kernel_16k_signed",
Nikolina Ilicda207762024-12-04 13:55:46 +0000558 defaults: [
559 "microdroid_kernel_signed_defaults",
560 "microdroid_kernel_cap_defaults",
561 ],
Nikita Ioffef49350e2024-11-01 16:11:48 +0000562 filename: "microdroid_kernel_16k",
563 arch: {
564 arm64: {
565 src: ":microdroid_kernel_16k_prebuilt-arm64",
566 },
567 // There is no 16k x86_64 kernel. Instead the 16k emulation is triggered by adding
568 // `page_shift=14` to the kernel cmdline or bootconfig.
569 x86_64: {
570 src: ":microdroid_kernel_prebuilt-x86_64",
571 },
572 },
Pierre-Clément Tosi9fbbaf32024-11-26 14:00:01 +0000573 props: [
574 {
575 name: "com.android.virt.page_size",
576 value: "16",
577 },
578 ],
Nikita Ioffef49350e2024-11-01 16:11:48 +0000579 include_descriptors_from_images: [
580 ":microdroid_16k_initrd_normal_hashdesc",
581 ":microdroid_16k_initrd_debug_hashdesc",
582 ],
583}
584
585prebuilt_etc {
586 name: "microdroid_kernel_16k",
587 src: ":empty_file",
588 relative_install_path: "fs",
589 arch: {
590 arm64: {
591 src: ":microdroid_kernel_16k_signed",
592 },
593 x86_64: {
594 src: ":microdroid_kernel_16k_signed",
595 },
596 },
597}
598
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900599///////////////////////////////////////
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000600// GKI-android15-6.6
601///////////////////////////////////////
602prebuilt_etc {
603 name: "microdroid_gki-android15-6.6.json",
604 src: "microdroid_gki-android15-6.6.json",
605}
606
Nikolina Ilicda207762024-12-04 13:55:46 +0000607avb_add_hash_footer_defaults {
Andrei Homescu25b82062025-01-30 06:26:40 +0000608 name: "microdroid_gki-android15-6.6_kernel_signed_defaults",
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000609 defaults: ["microdroid_kernel_signed_defaults"],
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000610 arch: {
611 arm64: {
612 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-arm64",
613 },
614 x86_64: {
615 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-x86_64",
616 },
617 },
618 include_descriptors_from_images: [
619 ":microdroid_gki-android15-6.6_initrd_normal_hashdesc",
620 ":microdroid_gki-android15-6.6_initrd_debug_hashdesc",
621 ],
622}
623
Nikolina Ilicda207762024-12-04 13:55:46 +0000624avb_add_hash_footer {
625 name: "microdroid_gki-android15-6.6_kernel_signed",
626 defaults: [
Andrei Homescu25b82062025-01-30 06:26:40 +0000627 "microdroid_gki-android15-6.6_kernel_signed_defaults",
Nikolina Ilicda207762024-12-04 13:55:46 +0000628 "microdroid_kernel_cap_defaults",
629 ],
630 filename: "microdroid_gki-android15-6.6_kernel_signed",
631}
632
633avb_add_hash_footer {
634 name: "microdroid_gki-android15-6.6_kernel_signed_supports_uefi_boot",
635 defaults: [
Andrei Homescu25b82062025-01-30 06:26:40 +0000636 "microdroid_gki-android15-6.6_kernel_signed_defaults",
Nikolina Ilicda207762024-12-04 13:55:46 +0000637 "microdroid_kernel_cap_with_uefi_defaults",
638 ],
639 filename: "microdroid_gki-android15-6.6_kernel_signed_supports_uefi_boot",
640}
641
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000642// HACK: use cc_genrule for arch-specific properties
643cc_genrule {
644 name: "microdroid_gki-android15-6.6_kernel_signed-lz4",
645 out: ["microdroid_gki-android15-6.6_kernel_signed-lz4"],
646 srcs: [":empty_file"],
647 arch: {
648 arm64: {
649 srcs: [":microdroid_gki-android15-6.6_kernel_signed"],
650 exclude_srcs: [":empty_file"],
651 },
652 },
653 tools: ["lz4"],
654 cmd: "$(location lz4) -9 $(in) $(out)",
655}
656
657prebuilt_etc {
658 name: "microdroid_gki-android15-6.6_kernel",
659 filename: "microdroid_gki-android15-6.6_kernel",
660 src: ":empty_file",
661 relative_install_path: "fs",
662 arch: {
663 arm64: {
664 src: ":microdroid_gki-android15-6.6_kernel_signed",
665 },
666 x86_64: {
667 src: ":microdroid_gki-android15-6.6_kernel_signed",
668 },
669 },
670}
671
672avb_gen_vbmeta_image {
673 name: "microdroid_gki-android15-6.6_initrd_normal_hashdesc",
674 defaults: ["microdroid_initrd_normal_defaults"],
675 src: ":microdroid_gki-android15-6.6_initrd_normal",
676}
677
678avb_gen_vbmeta_image {
679 name: "microdroid_gki-android15-6.6_initrd_debug_hashdesc",
680 defaults: ["microdroid_initrd_debug_defaults"],
681 src: ":microdroid_gki-android15-6.6_initrd_debuggable",
682}
683
Andrei Homescu25b82062025-01-30 06:26:40 +0000684///////////////////////////////////////
685// GKI-android16-6.12
686///////////////////////////////////////
687prebuilt_etc {
688 name: "microdroid_gki-android16-6.12.json",
689 src: "microdroid_gki-android16-6.12.json",
690}
691
692avb_add_hash_footer_defaults {
693 name: "microdroid_gki-android16-6.12_kernel_signed_defaults",
694 defaults: ["microdroid_kernel_signed_defaults"],
695 arch: {
696 arm64: {
697 src: ":microdroid_gki_kernel_prebuilts-android16-6.12-arm64",
698 },
699 x86_64: {
700 src: ":microdroid_gki_kernel_prebuilts-android16-6.12-x86_64",
701 },
702 },
703 include_descriptors_from_images: [
704 ":microdroid_gki-android16-6.12_initrd_normal_hashdesc",
705 ":microdroid_gki-android16-6.12_initrd_debug_hashdesc",
706 ],
707}
708
709avb_add_hash_footer {
710 name: "microdroid_gki-android16-6.12_kernel_signed",
711 defaults: [
712 "microdroid_gki-android16-6.12_kernel_signed_defaults",
713 "microdroid_kernel_cap_defaults",
714 ],
715 filename: "microdroid_gki-android16-6.12_kernel_signed",
716}
717
718avb_add_hash_footer {
719 name: "microdroid_gki-android16-6.12_kernel_signed_supports_uefi_boot",
720 defaults: [
721 "microdroid_gki-android16-6.12_kernel_signed_defaults",
722 "microdroid_kernel_cap_with_uefi_defaults",
723 ],
724 filename: "microdroid_gki-android16-6.12_kernel_signed_supports_uefi_boot",
725}
726
727// HACK: use cc_genrule for arch-specific properties
728cc_genrule {
729 name: "microdroid_gki-android16-6.12_kernel_signed-lz4",
730 out: ["microdroid_gki-android16-6.12_kernel_signed-lz4"],
731 srcs: [":empty_file"],
732 arch: {
733 arm64: {
734 srcs: [":microdroid_gki-android16-6.12_kernel_signed"],
735 exclude_srcs: [":empty_file"],
736 },
737 },
738 tools: ["lz4"],
739 cmd: "$(location lz4) -9 $(in) $(out)",
740}
741
742prebuilt_etc {
743 name: "microdroid_gki-android16-6.12_kernel",
744 filename: "microdroid_gki-android16-6.12_kernel",
745 src: ":empty_file",
746 relative_install_path: "fs",
747 arch: {
748 arm64: {
749 src: ":microdroid_gki-android16-6.12_kernel_signed",
750 },
751 x86_64: {
752 src: ":microdroid_gki-android16-6.12_kernel_signed",
753 },
754 },
755}
756
757avb_gen_vbmeta_image {
758 name: "microdroid_gki-android16-6.12_initrd_normal_hashdesc",
759 defaults: ["microdroid_initrd_normal_defaults"],
760 src: ":microdroid_gki-android16-6.12_initrd_normal",
761}
762
763avb_gen_vbmeta_image {
764 name: "microdroid_gki-android16-6.12_initrd_debug_hashdesc",
765 defaults: ["microdroid_initrd_debug_defaults"],
766 src: ":microdroid_gki-android16-6.12_initrd_debuggable",
767}
768
Alice Wang89cae4f2024-02-22 14:40:00 +0000769python_binary_host {
770 name: "extract_microdroid_kernel_hashes",
771 srcs: ["extract_microdroid_kernel_hashes.py"],
772}
773
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900774// HACK: use cc_genrule for arch-specific properties
775cc_genrule {
Alice Wang89cae4f2024-02-22 14:40:00 +0000776 name: "microdroid_kernel_hashes_rs",
Cole Faust2b944092024-10-23 16:37:21 -0700777 compile_multilib: "first",
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900778 srcs: [":microdroid_kernel"],
779 arch: {
780 arm64: {
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000781 srcs: [
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000782 ":microdroid_gki-android15-6.6_kernel_signed",
Andrei Homescu25b82062025-01-30 06:26:40 +0000783 ":microdroid_gki-android16-6.12_kernel_signed",
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000784 ],
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900785 },
786 x86_64: {
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000787 srcs: [
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000788 ":microdroid_gki-android15-6.6_kernel_signed",
Andrei Homescu25b82062025-01-30 06:26:40 +0000789 ":microdroid_gki-android16-6.12_kernel_signed",
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000790 ],
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900791 },
792 },
Alice Wang89cae4f2024-02-22 14:40:00 +0000793 out: ["lib.rs"],
794 tools: [
795 "extract_microdroid_kernel_hashes",
796 "avbtool",
797 ],
798 cmd: "$(location extract_microdroid_kernel_hashes) --avbtool $(location avbtool) " +
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900799 "--kernel $(in) > $(out)",
Alice Wang89cae4f2024-02-22 14:40:00 +0000800}
801
802rust_library_rlib {
803 name: "libmicrodroid_kernel_hashes",
Cole Faust2b944092024-10-23 16:37:21 -0700804 compile_multilib: "first",
Alice Wang89cae4f2024-02-22 14:40:00 +0000805 srcs: [":microdroid_kernel_hashes_rs"],
806 crate_name: "microdroid_kernel_hashes",
807 prefer_rlib: true,
808 no_stdlibs: true,
809 stdlibs: [
810 "libcompiler_builtins.rust_sysroot",
811 "libcore.rust_sysroot",
812 ],
813}