blob: 289bc82302726c593758929d8a474ba088aa583e [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
Nikita Ioffe3973d382023-08-31 17:53:25 +010047soong_config_module_type {
48 name: "flag_aware_microdroid_system_image",
49 module_type: "android_system_image",
50 config_namespace: "ANDROID",
51 bool_variables: [
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +000052 "release_avf_enable_dice_changes",
Nikita Ioffe3973d382023-08-31 17:53:25 +010053 "release_avf_enable_multi_tenant_microdroid_vm",
54 ],
55 properties: [
56 "deps",
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +000057 "dirs",
Nikita Ioffeabb6d8a2024-03-12 23:01:47 +000058 "multilib",
Nikita Ioffe3973d382023-08-31 17:53:25 +010059 ],
60}
61
62flag_aware_microdroid_system_image {
Jiyong Parkb552bb62021-01-25 19:12:47 +090063 name: "microdroid",
64 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +090065 avb_private_key: ":microdroid_sign_key",
Jiyong Parkb552bb62021-01-25 19:12:47 +090066 avb_algorithm: "SHA256_RSA4096",
Shikha Panwar85620722022-12-21 15:38:14 +000067 avb_hash_algorithm: "sha256",
Jiyong Parkd4326f32021-03-15 23:25:46 +090068 partition_name: "system",
Jiyong Parkb552bb62021-01-25 19:12:47 +090069 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +010070 "init_second_stage.microdroid",
Inseob Kim23ce1582021-04-06 21:25:57 +090071 "microdroid_build_prop",
Jaewan Kimb24d1dc2023-02-13 15:34:56 +090072 "microdroid_init_debug_policy",
Jiyong Park40699612021-05-24 16:55:06 +090073 "microdroid_init_rc",
Jiyong Park4d228952021-10-18 18:28:57 +090074 "microdroid_ueventd_rc",
Jiyong Park40699612021-05-24 16:55:06 +090075 "microdroid_launcher",
Jooyung Han7ce2e532021-06-16 16:52:02 +090076
Jooyung Han837eef52021-05-15 11:33:48 +090077 "libbinder_ndk",
Inseob Kimdc2af862021-02-17 15:51:56 +090078 "libstdc++",
Jooyung Han017916b2021-04-20 03:57:19 +090079
80 // "com.android.adbd" requires these,
81 "libadbd_auth",
82 "libadbd_fs",
83
Jooyung Han730b7b82021-05-12 14:09:38 +090084 // "com.android.art" requires
85 "heapprofd_client_api",
Victor Hsieh527b81d2021-06-11 10:41:11 -070086 "libartpalette-system",
Jooyung Han730b7b82021-05-12 14:09:38 +090087
Jooyung Hanb6a52152022-12-12 11:20:23 +090088 "apexd.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090089 "debuggerd",
90 "linker",
Inseob Kimdc2af862021-02-17 15:51:56 +090091 "cgroups.json",
Inseob Kime60307a2022-04-14 03:48:38 +090092 "task_profiles.json",
Jooyung Han1c820732021-04-15 05:16:23 +090093 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090094
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070095 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090096 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070097 "microdroid_manifest",
Inseob Kimff43be22021-06-07 16:56:56 +090098 "microdroid_property_contexts",
Shikha Panwar5cb5b992022-12-12 11:51:07 +000099 "mke2fs.microdroid",
Nikita Ioffe57b4dfc2023-06-14 20:29:37 +0000100 "microdroid_fstab",
Jooyung Han8a17ef72021-08-04 15:39:54 +0900101
Alice Wang2e57b082022-10-27 10:39:01 +0000102 "libvm_payload", // used by payload to interact with microdroid manager
Jiyong Park61eebed2022-12-20 19:24:48 +0900103
Jiyong Park5f7ae032022-12-22 10:24:39 +0900104 "prng_seeder_microdroid",
Nikita Ioffe858fa052023-03-03 00:46:35 +0000105
106 // Binaries required to capture traces in Microdroid.
107 "atrace",
108 "traced",
109 "traced_probes",
110 "perfetto",
Inseob Kimdc2af862021-02-17 15:51:56 +0900111 ] + microdroid_shell_and_utilities,
112 multilib: {
113 common: {
114 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900115 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900116 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900117
Jiyong Park9117f012022-07-07 15:24:06 +0900118 "microdroid_crashdump_initrd",
Nikita Ioffe536bc552023-06-14 20:29:37 +0000119 "microdroid_precompiled_sepolicy",
Inseob Kimdc2af862021-02-17 15:51:56 +0900120 ],
121 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900122 lib64: {
123 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900124 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700125 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700126 "authfs_service",
Shikha Panwar566c9672022-11-15 14:39:58 +0000127 "encryptedstore",
Jiyong Park9e5ae632022-07-08 14:47:23 +0900128 "microdroid_kexec",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900129 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900130 "zipfuse",
131 ],
132 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900133 },
Colin Crossca0049b2023-03-22 16:03:19 -0700134 arch: {
135 // b/273792258: These could be in multilib.lib64 except that
136 // microdroid_crashdump_kernel doesn't exist for riscv64 yet
137 arm64: {
138 deps: [
139 "microdroid_crashdump_kernel",
140 ],
141 },
142 x86_64: {
143 deps: [
144 "microdroid_crashdump_kernel",
145 ],
146 },
147 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900148 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900149 base_dir: "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +0900150 dirs: microdroid_rootdirs,
151 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900152 file_contexts: ":microdroid_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900153 // For deterministic output, use fake_timestamp, hard-coded uuid
154 fake_timestamp: "1611569676",
155 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/system'))"
156 uuid: "5fe079c6-f01a-52be-87d3-d415231a72ad",
Nikita Ioffe3973d382023-08-31 17:53:25 +0100157
158 // Below are dependencies that are conditionally enabled depending on value of build flags.
159 soong_config_variables: {
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000160 release_avf_enable_dice_changes: {
Nikita Ioffeabb6d8a2024-03-12 23:01:47 +0000161 multilib: {
162 lib64: {
163 deps: ["derive_microdroid_vendor_dice_node"],
164 },
165 },
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000166 dirs: [
167 "microdroid_resources",
168 ],
169 },
Nikita Ioffe3973d382023-08-31 17:53:25 +0100170 release_avf_enable_multi_tenant_microdroid_vm: {
171 deps: [
172 "microdroid_etc_passwd",
173 "microdroid_etc_group",
174 ],
175 },
176 },
Jiyong Parkb552bb62021-01-25 19:12:47 +0900177}
Jiyong Park153d3552021-02-04 08:54:31 +0900178
Inseob Kimdc2af862021-02-17 15:51:56 +0900179prebuilt_etc {
180 name: "microdroid_init_rc",
181 filename: "init.rc",
182 src: "init.rc",
183 relative_install_path: "init/hw",
Jiyong Park5f939f92024-05-01 16:18:14 +0900184 no_full_install: true, // avoid collision with system partition's init.rc
Inseob Kimdc2af862021-02-17 15:51:56 +0900185}
186
Jiyong Park4d228952021-10-18 18:28:57 +0900187prebuilt_etc {
188 name: "microdroid_ueventd_rc",
189 filename: "ueventd.rc",
190 src: "ueventd.rc",
Jiyong Park5f939f92024-05-01 16:18:14 +0900191 no_full_install: true, // avoid collision with system partition's ueventd.rc
Jiyong Park4d228952021-10-18 18:28:57 +0900192}
193
Alan Stokes1294f942023-08-21 14:34:12 +0100194prebuilt_etc {
195 name: "microdroid_etc_passwd",
196 src: "microdroid_passwd",
197 filename: "passwd",
Jiyong Park5f939f92024-05-01 16:18:14 +0900198 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100199}
200
201prebuilt_etc {
202 name: "microdroid_etc_group",
203 src: "microdroid_group",
204 filename: "group",
Jiyong Park5f939f92024-05-01 16:18:14 +0900205 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100206}
207
Inseob Kim23ce1582021-04-06 21:25:57 +0900208prebuilt_root {
209 name: "microdroid_build_prop",
210 filename: "build.prop",
211 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900212 arch: {
213 x86_64: {
214 src: ":microdroid_build_prop_gen_x86_64",
215 },
216 arm64: {
217 src: ":microdroid_build_prop_gen_arm64",
218 },
219 },
Jiyong Park5f939f92024-05-01 16:18:14 +0900220 no_full_install: true,
Inseob Kim23ce1582021-04-06 21:25:57 +0900221}
222
Jiyong Park68f560c2021-05-24 17:38:27 +0900223genrule {
224 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900225 srcs: [
226 "build.prop",
Pechetty Sravani (xWF)5f2bc9c2024-07-25 09:21:09 +0000227 ":buildinfo.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900228 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900229 out: ["build.prop.out"],
Pechetty Sravani (xWF)5f2bc9c2024-07-25 09:21:09 +0000230 cmd: "(echo '# build properties from buildinfo.prop module' && " +
231 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
232 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
233 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
234 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
235 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900236 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900237 "echo ro.product.cpu.abilist=x86_64 && " +
238 "echo ro.product.cpu.abi=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900239}
240
241genrule {
242 name: "microdroid_build_prop_gen_arm64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900243 srcs: [
244 "build.prop",
Pechetty Sravani (xWF)5f2bc9c2024-07-25 09:21:09 +0000245 ":buildinfo.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900246 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900247 out: ["build.prop.out"],
Pechetty Sravani (xWF)5f2bc9c2024-07-25 09:21:09 +0000248 cmd: "(echo '# build properties from buildinfo.prop module' && " +
249 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
250 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
251 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
252 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
253 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900254 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900255 "echo ro.product.cpu.abilist=arm64-v8a && " +
256 "echo ro.product.cpu.abi=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900257}
258
Nikita Ioffee1112032023-11-13 15:09:39 +0000259// Need to keep microdroid_vendor for the release configurations that don't
260// have RELEASE_AVF_ENABLE_VENDOR_MODULES build flag enabled.
261android_filesystem {
262 name: "microdroid_vendor",
263 partition_name: "vendor",
264 use_avb: true,
265 avb_private_key: ":microdroid_sign_key",
266 avb_algorithm: "SHA256_RSA4096",
267 avb_hash_algorithm: "sha256",
268 file_contexts: ":microdroid_vendor_file_contexts.gen",
269 // For deterministic output, use fake_timestamp, hard-coded uuid
270 fake_timestamp: "1611569676",
271 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/vendor'))"
272 uuid: "156d40d7-8d8e-5c99-8913-ec82de549a70",
273}
274
275soong_config_module_type {
276 name: "flag_aware_microdroid_super_partition",
277 module_type: "logical_partition",
278 config_namespace: "ANDROID",
279 bool_variables: [
280 "release_avf_enable_vendor_modules",
281 ],
282 properties: [
283 "default_group",
284 ],
285}
286
287flag_aware_microdroid_super_partition {
Jiyong Parkc1500e82021-02-24 01:39:51 +0900288 name: "microdroid_super",
289 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900290 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900291 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900292 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900293 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900294 filesystem: ":microdroid",
295 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900296 ],
Nikita Ioffee1112032023-11-13 15:09:39 +0000297 soong_config_variables: {
298 release_avf_enable_vendor_modules: {
Nikita Ioffe2814dd32023-11-17 15:41:36 +0000299 conditions_default: {
300 default_group: [
301 {
302 name: "vendor_a",
303 filesystem: ":microdroid_vendor",
304 },
305 ],
306 },
Nikita Ioffee1112032023-11-13 15:09:39 +0000307 },
308 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900309}
310
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000311soong_config_module_type {
312 name: "flag_aware_microdroid_filesystem",
313 module_type: "android_filesystem",
314 config_namespace: "ANDROID",
315 bool_variables: [
316 "release_avf_enable_dice_changes",
317 ],
318 properties: [
319 "dirs",
320 ],
321}
322
323flag_aware_microdroid_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900324 name: "microdroid_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900325 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +0100326 "init_first_stage.microdroid",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900327 ],
328 dirs: [
329 "dev",
330 "proc",
331 "sys",
332
Jiyong Parkc8b40032021-02-18 23:15:41 +0900333 "mnt",
334 "debug_ramdisk",
335 "second_stage_resources",
336 ],
337 type: "compressed_cpio",
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000338
339 // Below are dependencies that are conditionally enabled depending on value of build flags.
340 soong_config_variables: {
341 release_avf_enable_dice_changes: {
342 dirs: [
343 "microdroid_resources",
344 ],
345 },
346 },
Jiyong Parkc8b40032021-02-18 23:15:41 +0900347}
348
Jiyong Parkb54646f2022-02-07 11:13:56 +0900349android_filesystem {
Nikita Ioffe2c3bc222024-03-26 20:51:00 +0000350 name: "microdroid_first_stage_ramdisk",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900351 deps: [
352 "microdroid_fstab",
353 ],
354 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900355 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900356 symlinks: [
357 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900358 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900359 name: "first_stage_ramdisk/fstab.microdroid",
360 },
361 {
362 target: "first_stage_ramdisk/lib",
363 name: "lib",
364 },
365 ],
366}
367
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900368genrule {
369 name: "microdroid_bootconfig_arm64_gen",
370 srcs: [
371 "bootconfig.common",
372 "bootconfig.arm64",
373 ],
374 out: ["bootconfig"],
375 cmd: "cat $(in) > $(out)",
376}
377
378genrule {
379 name: "microdroid_bootconfig_x86_64_gen",
380 srcs: [
381 "bootconfig.common",
382 "bootconfig.x86_64",
383 ],
384 out: ["bootconfig"],
385 cmd: "cat $(in) > $(out)",
386}
387
Jiyong Park3eb11f72021-02-23 12:53:30 +0900388prebuilt_etc {
389 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900390 src: "fstab.microdroid",
391 filename: "fstab.microdroid",
Jiyong Park5f939f92024-05-01 16:18:14 +0900392 no_full_install: true,
Jiyong Park153d3552021-02-04 08:54:31 +0900393}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900394
Jooyung Han64214832022-04-21 14:30:04 +0900395// python -c "import hashlib; print(hashlib.sha256(b'bootloader').hexdigest())"
396bootloader_salt = "3b4a12881d11f33cff968a24d7c53723a8232cde9a8d91e29fdbd6a95ae6adf0"
397
Jooyung Hand35952e2021-11-08 17:53:47 +0900398filegroup {
399 name: "microdroid_sign_key",
Pierre-Clément Tosi2188d802024-05-24 10:56:26 +0100400 srcs: [":pvmfw_embedded_key"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900401}
402
Nikita Ioffee1112032023-11-13 15:09:39 +0000403soong_config_module_type {
404 name: "flag_aware_microdroid_vbmeta",
405 module_type: "vbmeta",
406 config_namespace: "ANDROID",
407 bool_variables: [
408 "release_avf_enable_vendor_modules",
409 ],
410 properties: [
411 "partitions",
412 ],
413}
414
415flag_aware_microdroid_vbmeta {
Jiyong Park80d8da82021-03-15 23:30:11 +0900416 name: "microdroid_vbmeta",
417 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900418 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900419 partitions: [
Jiyong Park80d8da82021-03-15 23:30:11 +0900420 "microdroid",
421 ],
Nikita Ioffee1112032023-11-13 15:09:39 +0000422 soong_config_variables: {
423 release_avf_enable_vendor_modules: {
Seungjae Yoo5c0d7322024-01-10 12:52:53 +0900424 conditions_default: {
425 partitions: ["microdroid_vendor"],
426 },
Nikita Ioffee1112032023-11-13 15:09:39 +0000427 },
428 },
Jiyong Park80d8da82021-03-15 23:30:11 +0900429}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900430
431prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900432 name: "microdroid.json",
433 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900434}
Jooyung Han017916b2021-04-20 03:57:19 +0900435
436prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900437 name: "microdroid_manifest",
438 src: "microdroid_manifest.xml",
439 filename: "manifest.xml",
440 relative_install_path: "vintf",
Jiyong Park5f939f92024-05-01 16:18:14 +0900441 no_full_install: true,
Inseob Kim8f095c92021-05-26 12:04:54 +0900442}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700443
444prebuilt_etc {
445 name: "microdroid_event-log-tags",
446 src: "microdroid_event-log-tags",
447 filename: "event-log-tags",
Jiyong Park5f939f92024-05-01 16:18:14 +0900448 no_full_install: true,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900449}
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000450
451filegroup {
Seungjae Yooe85831e2022-12-12 09:34:58 +0900452 name: "microdroid_bootconfig_debuggable_src",
453 srcs: ["bootconfig.debuggable"],
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000454}
455
456filegroup {
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000457 name: "microdroid_bootconfig_normal_src",
458 srcs: ["bootconfig.normal"],
459}
Shikha Panwared8ace42022-09-28 12:52:16 +0000460
Alice Wangc5c966d2023-01-04 10:44:07 +0000461// python -c "import hashlib; print(hashlib.sha256(b'initrd_normal').hexdigest())"
462initrd_normal_salt = "8041a07d54ac82290f6d90bac1fa8d7fdbc4db974d101d60faf294749d1ebaf8"
463
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900464avb_gen_vbmeta_image_defaults {
465 name: "microdroid_initrd_defaults",
Alice Wangc5c966d2023-01-04 10:44:07 +0000466 enabled: false,
467 arch: {
468 // Microdroid kernel is only available in these architectures.
469 arm64: {
470 enabled: true,
471 },
472 x86_64: {
473 enabled: true,
474 },
475 },
476}
477
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900478avb_gen_vbmeta_image_defaults {
479 name: "microdroid_initrd_normal_defaults",
480 defaults: ["microdroid_initrd_defaults"],
Inseob Kim77c7f712023-11-06 17:01:02 +0900481 partition_name: "initrd_normal",
482 salt: initrd_normal_salt,
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900483}
484
485avb_gen_vbmeta_image {
486 name: "microdroid_initrd_normal_hashdesc",
487 defaults: ["microdroid_initrd_normal_defaults"],
488 src: ":microdroid_initrd_normal",
Inseob Kim77c7f712023-11-06 17:01:02 +0900489}
490
Alice Wangc5c966d2023-01-04 10:44:07 +0000491// python -c "import hashlib; print(hashlib.sha256(b'initrd_debug').hexdigest())"
492initrd_debug_salt = "8ab9dc9cb7e6456700ff6ef18c6b4c3acc24c5fa5381b829563f8d7a415d869a"
493
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900494avb_gen_vbmeta_image_defaults {
495 name: "microdroid_initrd_debug_defaults",
496 defaults: ["microdroid_initrd_defaults"],
Alice Wangc41ebfb2023-01-11 09:06:32 +0000497 partition_name: "initrd_debug",
Alice Wangc5c966d2023-01-04 10:44:07 +0000498 salt: initrd_debug_salt,
Alice Wangc5c966d2023-01-04 10:44:07 +0000499}
500
Inseob Kim77c7f712023-11-06 17:01:02 +0900501avb_gen_vbmeta_image {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900502 name: "microdroid_initrd_debug_hashdesc",
503 defaults: ["microdroid_initrd_debug_defaults"],
504 src: ":microdroid_initrd_debuggable",
Inseob Kim77c7f712023-11-06 17:01:02 +0900505}
506
Shikha Panwar2a788662023-09-11 14:04:24 +0000507soong_config_module_type {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900508 name: "flag_aware_avb_add_hash_footer_defaults",
509 module_type: "avb_add_hash_footer_defaults",
Shikha Panwar2a788662023-09-11 14:04:24 +0000510 config_namespace: "ANDROID",
511 bool_variables: [
512 "release_avf_enable_llpvm_changes",
513 ],
514 properties: [
515 "rollback_index",
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000516 "props",
Shikha Panwar2a788662023-09-11 14:04:24 +0000517 ],
518}
519
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900520flag_aware_avb_add_hash_footer_defaults {
521 name: "microdroid_kernel_signed_defaults",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100522 src: ":empty_file",
Alice Wang8aa3cb12023-01-11 09:04:04 +0000523 partition_name: "boot",
Shikha Panwared8ace42022-09-28 12:52:16 +0000524 private_key: ":microdroid_sign_key",
525 salt: bootloader_salt,
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000526 enabled: false,
527 arch: {
528 arm64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000529 enabled: true,
530 },
531 x86_64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000532 enabled: true,
533 },
534 },
Shikha Panwar2a788662023-09-11 14:04:24 +0000535 // Below are properties that are conditionally set depending on value of build flags.
536 soong_config_variables: {
537 release_avf_enable_llpvm_changes: {
538 rollback_index: 1,
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000539 props: [
540 {
541 name: "com.android.virt.cap",
542 value: "secretkeeper_protection",
543 },
544 ],
Shikha Panwar2a788662023-09-11 14:04:24 +0000545 },
546 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000547}
548
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900549avb_add_hash_footer {
550 name: "microdroid_kernel_signed",
551 defaults: ["microdroid_kernel_signed_defaults"],
552 filename: "microdroid_kernel",
Inseob Kim77c7f712023-11-06 17:01:02 +0900553 arch: {
554 arm64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000555 src: ":microdroid_kernel_prebuilt-arm64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900556 },
557 x86_64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000558 src: ":microdroid_kernel_prebuilt-x86_64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900559 },
560 },
561 include_descriptors_from_images: [
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900562 ":microdroid_initrd_normal_hashdesc",
563 ":microdroid_initrd_debug_hashdesc",
Inseob Kim77c7f712023-11-06 17:01:02 +0900564 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900565}
566
Shikha Panwared8ace42022-09-28 12:52:16 +0000567prebuilt_etc {
568 name: "microdroid_kernel",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100569 src: ":empty_file",
Shikha Panwared8ace42022-09-28 12:52:16 +0000570 relative_install_path: "fs",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000571 arch: {
572 arm64: {
573 src: ":microdroid_kernel_signed",
574 },
575 x86_64: {
576 src: ":microdroid_kernel_signed",
577 },
578 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000579}
Inseob Kim77c7f712023-11-06 17:01:02 +0900580
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900581///////////////////////////////////////
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000582// GKI-android15-6.6
583///////////////////////////////////////
584prebuilt_etc {
585 name: "microdroid_gki-android15-6.6.json",
586 src: "microdroid_gki-android15-6.6.json",
587}
588
589avb_add_hash_footer {
590 name: "microdroid_gki-android15-6.6_kernel_signed",
591 defaults: ["microdroid_kernel_signed_defaults"],
592 filename: "microdroid_gki-android15-6.6_kernel_signed",
593 arch: {
594 arm64: {
595 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-arm64",
596 },
597 x86_64: {
598 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-x86_64",
599 },
600 },
601 include_descriptors_from_images: [
602 ":microdroid_gki-android15-6.6_initrd_normal_hashdesc",
603 ":microdroid_gki-android15-6.6_initrd_debug_hashdesc",
604 ],
605}
606
607// HACK: use cc_genrule for arch-specific properties
608cc_genrule {
609 name: "microdroid_gki-android15-6.6_kernel_signed-lz4",
610 out: ["microdroid_gki-android15-6.6_kernel_signed-lz4"],
611 srcs: [":empty_file"],
612 arch: {
613 arm64: {
614 srcs: [":microdroid_gki-android15-6.6_kernel_signed"],
615 exclude_srcs: [":empty_file"],
616 },
617 },
618 tools: ["lz4"],
619 cmd: "$(location lz4) -9 $(in) $(out)",
620}
621
622prebuilt_etc {
623 name: "microdroid_gki-android15-6.6_kernel",
624 filename: "microdroid_gki-android15-6.6_kernel",
625 src: ":empty_file",
626 relative_install_path: "fs",
627 arch: {
628 arm64: {
629 src: ":microdroid_gki-android15-6.6_kernel_signed",
630 },
631 x86_64: {
632 src: ":microdroid_gki-android15-6.6_kernel_signed",
633 },
634 },
635}
636
637avb_gen_vbmeta_image {
638 name: "microdroid_gki-android15-6.6_initrd_normal_hashdesc",
639 defaults: ["microdroid_initrd_normal_defaults"],
640 src: ":microdroid_gki-android15-6.6_initrd_normal",
641}
642
643avb_gen_vbmeta_image {
644 name: "microdroid_gki-android15-6.6_initrd_debug_hashdesc",
645 defaults: ["microdroid_initrd_debug_defaults"],
646 src: ":microdroid_gki-android15-6.6_initrd_debuggable",
647}
648
Alice Wang89cae4f2024-02-22 14:40:00 +0000649python_binary_host {
650 name: "extract_microdroid_kernel_hashes",
651 srcs: ["extract_microdroid_kernel_hashes.py"],
652}
653
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900654// HACK: use cc_genrule for arch-specific properties
655cc_genrule {
Alice Wang89cae4f2024-02-22 14:40:00 +0000656 name: "microdroid_kernel_hashes_rs",
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900657 srcs: [":microdroid_kernel"],
658 arch: {
659 arm64: {
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000660 srcs: [
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000661 ":microdroid_gki-android15-6.6_kernel_signed",
662 ],
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900663 },
664 x86_64: {
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000665 srcs: [
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000666 ":microdroid_gki-android15-6.6_kernel_signed",
667 ],
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900668 },
669 },
Alice Wang89cae4f2024-02-22 14:40:00 +0000670 out: ["lib.rs"],
671 tools: [
672 "extract_microdroid_kernel_hashes",
673 "avbtool",
674 ],
675 cmd: "$(location extract_microdroid_kernel_hashes) --avbtool $(location avbtool) " +
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900676 "--kernel $(in) > $(out)",
Alice Wang89cae4f2024-02-22 14:40:00 +0000677}
678
679rust_library_rlib {
680 name: "libmicrodroid_kernel_hashes",
681 srcs: [":microdroid_kernel_hashes_rs"],
682 crate_name: "microdroid_kernel_hashes",
683 prefer_rlib: true,
684 no_stdlibs: true,
685 stdlibs: [
686 "libcompiler_builtins.rust_sysroot",
687 "libcore.rust_sysroot",
688 ],
689}