blob: e19a34384a0d5420eb86a3d5691b66f5fbc87a1d [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 Ioffe3973d382023-08-31 17:53:25 +010058 ],
59}
60
61flag_aware_microdroid_system_image {
Jiyong Parkb552bb62021-01-25 19:12:47 +090062 name: "microdroid",
63 use_avb: true,
Jooyung Hand35952e2021-11-08 17:53:47 +090064 avb_private_key: ":microdroid_sign_key",
Jiyong Parkb552bb62021-01-25 19:12:47 +090065 avb_algorithm: "SHA256_RSA4096",
Shikha Panwar85620722022-12-21 15:38:14 +000066 avb_hash_algorithm: "sha256",
Jiyong Parkd4326f32021-03-15 23:25:46 +090067 partition_name: "system",
Jiyong Parkb552bb62021-01-25 19:12:47 +090068 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +010069 "init_second_stage.microdroid",
Inseob Kim23ce1582021-04-06 21:25:57 +090070 "microdroid_build_prop",
Jaewan Kimb24d1dc2023-02-13 15:34:56 +090071 "microdroid_init_debug_policy",
Jiyong Park40699612021-05-24 16:55:06 +090072 "microdroid_init_rc",
Jiyong Park4d228952021-10-18 18:28:57 +090073 "microdroid_ueventd_rc",
Jiyong Park40699612021-05-24 16:55:06 +090074 "microdroid_launcher",
Jooyung Han7ce2e532021-06-16 16:52:02 +090075
Jooyung Han837eef52021-05-15 11:33:48 +090076 "libbinder_ndk",
Inseob Kimdc2af862021-02-17 15:51:56 +090077 "libstdc++",
Jooyung Han017916b2021-04-20 03:57:19 +090078
79 // "com.android.adbd" requires these,
80 "libadbd_auth",
81 "libadbd_fs",
82
Jooyung Han730b7b82021-05-12 14:09:38 +090083 // "com.android.art" requires
84 "heapprofd_client_api",
Victor Hsieh527b81d2021-06-11 10:41:11 -070085 "libartpalette-system",
Jooyung Han730b7b82021-05-12 14:09:38 +090086
Jooyung Hanb6a52152022-12-12 11:20:23 +090087 "apexd.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090088 "debuggerd",
89 "linker",
Inseob Kimdc2af862021-02-17 15:51:56 +090090 "cgroups.json",
Inseob Kime60307a2022-04-14 03:48:38 +090091 "task_profiles.json",
Jooyung Han1c820732021-04-15 05:16:23 +090092 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090093
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070094 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090095 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070096 "microdroid_manifest",
Inseob Kimff43be22021-06-07 16:56:56 +090097 "microdroid_property_contexts",
Shikha Panwar5cb5b992022-12-12 11:51:07 +000098 "mke2fs.microdroid",
Nikita Ioffe57b4dfc2023-06-14 20:29:37 +000099 "microdroid_fstab",
Jooyung Han8a17ef72021-08-04 15:39:54 +0900100
Alice Wang2e57b082022-10-27 10:39:01 +0000101 "libvm_payload", // used by payload to interact with microdroid manager
Jiyong Park61eebed2022-12-20 19:24:48 +0900102
Jiyong Park5f7ae032022-12-22 10:24:39 +0900103 "prng_seeder_microdroid",
Nikita Ioffe858fa052023-03-03 00:46:35 +0000104
105 // Binaries required to capture traces in Microdroid.
106 "atrace",
107 "traced",
108 "traced_probes",
109 "perfetto",
Inseob Kimdc2af862021-02-17 15:51:56 +0900110 ] + microdroid_shell_and_utilities,
111 multilib: {
112 common: {
113 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900114 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900115 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900116
Jiyong Park9117f012022-07-07 15:24:06 +0900117 "microdroid_crashdump_initrd",
Nikita Ioffe536bc552023-06-14 20:29:37 +0000118 "microdroid_precompiled_sepolicy",
Inseob Kimdc2af862021-02-17 15:51:56 +0900119 ],
120 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900121 lib64: {
122 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900123 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700124 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700125 "authfs_service",
Shikha Panwar566c9672022-11-15 14:39:58 +0000126 "encryptedstore",
Jiyong Park9e5ae632022-07-08 14:47:23 +0900127 "microdroid_kexec",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900128 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900129 "zipfuse",
130 ],
131 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900132 },
Colin Crossca0049b2023-03-22 16:03:19 -0700133 arch: {
134 // b/273792258: These could be in multilib.lib64 except that
135 // microdroid_crashdump_kernel doesn't exist for riscv64 yet
136 arm64: {
137 deps: [
138 "microdroid_crashdump_kernel",
139 ],
140 },
141 x86_64: {
142 deps: [
143 "microdroid_crashdump_kernel",
144 ],
145 },
146 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900147 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900148 base_dir: "system",
Inseob Kim5ffc0822021-02-09 21:23:36 +0900149 dirs: microdroid_rootdirs,
150 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900151 file_contexts: ":microdroid_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900152 // For deterministic output, use fake_timestamp, hard-coded uuid
153 fake_timestamp: "1611569676",
154 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/system'))"
155 uuid: "5fe079c6-f01a-52be-87d3-d415231a72ad",
Nikita Ioffe3973d382023-08-31 17:53:25 +0100156
157 // Below are dependencies that are conditionally enabled depending on value of build flags.
158 soong_config_variables: {
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000159 release_avf_enable_dice_changes: {
Nikita Ioffe9da7b2d2024-03-05 00:27:28 +0000160 deps: [
161 "derive_microdroid_vendor_dice_node",
162 ],
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000163 dirs: [
164 "microdroid_resources",
165 ],
166 },
Nikita Ioffe3973d382023-08-31 17:53:25 +0100167 release_avf_enable_multi_tenant_microdroid_vm: {
168 deps: [
169 "microdroid_etc_passwd",
170 "microdroid_etc_group",
171 ],
172 },
173 },
Jiyong Parkb552bb62021-01-25 19:12:47 +0900174}
Jiyong Park153d3552021-02-04 08:54:31 +0900175
Inseob Kimdc2af862021-02-17 15:51:56 +0900176prebuilt_etc {
177 name: "microdroid_init_rc",
178 filename: "init.rc",
179 src: "init.rc",
180 relative_install_path: "init/hw",
181 installable: false, // avoid collision with system partition's init.rc
182}
183
Jiyong Park4d228952021-10-18 18:28:57 +0900184prebuilt_etc {
185 name: "microdroid_ueventd_rc",
186 filename: "ueventd.rc",
187 src: "ueventd.rc",
188 installable: false, // avoid collision with system partition's ueventd.rc
189}
190
Alan Stokes1294f942023-08-21 14:34:12 +0100191prebuilt_etc {
192 name: "microdroid_etc_passwd",
193 src: "microdroid_passwd",
194 filename: "passwd",
195 installable: false,
196}
197
198prebuilt_etc {
199 name: "microdroid_etc_group",
200 src: "microdroid_group",
201 filename: "group",
202 installable: false,
203}
204
Inseob Kim23ce1582021-04-06 21:25:57 +0900205prebuilt_root {
206 name: "microdroid_build_prop",
207 filename: "build.prop",
208 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900209 arch: {
210 x86_64: {
211 src: ":microdroid_build_prop_gen_x86_64",
212 },
213 arm64: {
214 src: ":microdroid_build_prop_gen_arm64",
215 },
216 },
Inseob Kim23ce1582021-04-06 21:25:57 +0900217 installable: false,
218}
219
Jiyong Park68f560c2021-05-24 17:38:27 +0900220genrule {
221 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900222 srcs: [
223 "build.prop",
224 ":buildinfo.prop",
225 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900226 out: ["build.prop.out"],
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900227 cmd: "(echo '# build properties from buildinfo.prop module' && " +
228 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
229 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
230 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
231 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
Jiyong Park71215c62022-06-21 10:46:55 +0900232 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900233 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900234 "echo ro.product.cpu.abilist=x86_64 && " +
235 "echo ro.product.cpu.abi=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900236}
237
238genrule {
239 name: "microdroid_build_prop_gen_arm64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900240 srcs: [
241 "build.prop",
242 ":buildinfo.prop",
243 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900244 out: ["build.prop.out"],
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900245 cmd: "(echo '# build properties from buildinfo.prop module' && " +
246 "grep ro\\.build\\.version\\.codename= $(location :buildinfo.prop) && " +
247 "grep ro\\.build\\.version\\.release= $(location :buildinfo.prop) && " +
248 "grep ro\\.build\\.version\\.sdk= $(location :buildinfo.prop) && " +
249 "grep ro\\.build\\.version\\.security_patch= $(location :buildinfo.prop) && " +
Jiyong Park71215c62022-06-21 10:46:55 +0900250 "grep ro\\.build\\.version\\.known_codenames= $(location :buildinfo.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900251 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900252 "echo ro.product.cpu.abilist=arm64-v8a && " +
253 "echo ro.product.cpu.abi=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900254}
255
Nikita Ioffee1112032023-11-13 15:09:39 +0000256// Need to keep microdroid_vendor for the release configurations that don't
257// have RELEASE_AVF_ENABLE_VENDOR_MODULES build flag enabled.
258android_filesystem {
259 name: "microdroid_vendor",
260 partition_name: "vendor",
261 use_avb: true,
262 avb_private_key: ":microdroid_sign_key",
263 avb_algorithm: "SHA256_RSA4096",
264 avb_hash_algorithm: "sha256",
265 file_contexts: ":microdroid_vendor_file_contexts.gen",
266 // For deterministic output, use fake_timestamp, hard-coded uuid
267 fake_timestamp: "1611569676",
268 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/vendor'))"
269 uuid: "156d40d7-8d8e-5c99-8913-ec82de549a70",
270}
271
272soong_config_module_type {
273 name: "flag_aware_microdroid_super_partition",
274 module_type: "logical_partition",
275 config_namespace: "ANDROID",
276 bool_variables: [
277 "release_avf_enable_vendor_modules",
278 ],
279 properties: [
280 "default_group",
281 ],
282}
283
284flag_aware_microdroid_super_partition {
Jiyong Parkc1500e82021-02-24 01:39:51 +0900285 name: "microdroid_super",
286 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900287 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900288 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900289 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900290 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900291 filesystem: ":microdroid",
292 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900293 ],
Nikita Ioffee1112032023-11-13 15:09:39 +0000294 soong_config_variables: {
295 release_avf_enable_vendor_modules: {
Nikita Ioffe2814dd32023-11-17 15:41:36 +0000296 conditions_default: {
297 default_group: [
298 {
299 name: "vendor_a",
300 filesystem: ":microdroid_vendor",
301 },
302 ],
303 },
Nikita Ioffee1112032023-11-13 15:09:39 +0000304 },
305 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900306}
307
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000308soong_config_module_type {
309 name: "flag_aware_microdroid_filesystem",
310 module_type: "android_filesystem",
311 config_namespace: "ANDROID",
312 bool_variables: [
313 "release_avf_enable_dice_changes",
314 ],
315 properties: [
316 "dirs",
317 ],
318}
319
320flag_aware_microdroid_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900321 name: "microdroid_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900322 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +0100323 "init_first_stage.microdroid",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900324 ],
325 dirs: [
326 "dev",
327 "proc",
328 "sys",
329
Jiyong Parkc8b40032021-02-18 23:15:41 +0900330 "mnt",
331 "debug_ramdisk",
332 "second_stage_resources",
333 ],
334 type: "compressed_cpio",
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000335
336 // Below are dependencies that are conditionally enabled depending on value of build flags.
337 soong_config_variables: {
338 release_avf_enable_dice_changes: {
339 dirs: [
340 "microdroid_resources",
341 ],
342 },
343 },
Jiyong Parkc8b40032021-02-18 23:15:41 +0900344}
345
Nikita Ioffe8ce8ce12024-03-12 15:37:03 +0000346// TODO(ioffe): rename to microdroid_first_stage_ramdisk
Jiyong Parkb54646f2022-02-07 11:13:56 +0900347android_filesystem {
Nikita Ioffe57b4dfc2023-06-14 20:29:37 +0000348 name: "microdroid_fstab_ramdisk",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900349 deps: [
350 "microdroid_fstab",
351 ],
352 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900353 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900354 symlinks: [
355 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900356 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900357 name: "first_stage_ramdisk/fstab.microdroid",
358 },
359 {
360 target: "first_stage_ramdisk/lib",
361 name: "lib",
362 },
363 ],
364}
365
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900366genrule {
367 name: "microdroid_bootconfig_arm64_gen",
368 srcs: [
369 "bootconfig.common",
370 "bootconfig.arm64",
371 ],
372 out: ["bootconfig"],
373 cmd: "cat $(in) > $(out)",
374}
375
376genrule {
377 name: "microdroid_bootconfig_x86_64_gen",
378 srcs: [
379 "bootconfig.common",
380 "bootconfig.x86_64",
381 ],
382 out: ["bootconfig"],
383 cmd: "cat $(in) > $(out)",
384}
385
Jiyong Park3eb11f72021-02-23 12:53:30 +0900386prebuilt_etc {
387 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900388 src: "fstab.microdroid",
389 filename: "fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900390 installable: false,
Jiyong Park153d3552021-02-04 08:54:31 +0900391}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900392
Jooyung Han64214832022-04-21 14:30:04 +0900393// python -c "import hashlib; print(hashlib.sha256(b'bootloader').hexdigest())"
394bootloader_salt = "3b4a12881d11f33cff968a24d7c53723a8232cde9a8d91e29fdbd6a95ae6adf0"
395
Jooyung Hand35952e2021-11-08 17:53:47 +0900396// Note that keys can be different for filesystem images even though we're using the same key
397// for microdroid. However, the key signing VBmeta should match with the pubkey embedded in
398// bootloader.
399filegroup {
400 name: "microdroid_sign_key",
401 srcs: [":avb_testkey_rsa4096"],
402}
403
Nikita Ioffee1112032023-11-13 15:09:39 +0000404soong_config_module_type {
405 name: "flag_aware_microdroid_vbmeta",
406 module_type: "vbmeta",
407 config_namespace: "ANDROID",
408 bool_variables: [
409 "release_avf_enable_vendor_modules",
410 ],
411 properties: [
412 "partitions",
413 ],
414}
415
416flag_aware_microdroid_vbmeta {
Jiyong Park80d8da82021-03-15 23:30:11 +0900417 name: "microdroid_vbmeta",
418 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900419 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900420 partitions: [
Jiyong Park80d8da82021-03-15 23:30:11 +0900421 "microdroid",
422 ],
Nikita Ioffee1112032023-11-13 15:09:39 +0000423 soong_config_variables: {
424 release_avf_enable_vendor_modules: {
Seungjae Yoo5c0d7322024-01-10 12:52:53 +0900425 conditions_default: {
426 partitions: ["microdroid_vendor"],
427 },
Nikita Ioffee1112032023-11-13 15:09:39 +0000428 },
429 },
Jiyong Park80d8da82021-03-15 23:30:11 +0900430}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900431
432prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900433 name: "microdroid.json",
434 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900435}
Jooyung Han017916b2021-04-20 03:57:19 +0900436
437prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900438 name: "microdroid_manifest",
439 src: "microdroid_manifest.xml",
440 filename: "manifest.xml",
441 relative_install_path: "vintf",
442 installable: false,
443}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700444
445prebuilt_etc {
446 name: "microdroid_event-log-tags",
447 src: "microdroid_event-log-tags",
448 filename: "event-log-tags",
449 installable: false,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900450}
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000451
452filegroup {
Seungjae Yooe85831e2022-12-12 09:34:58 +0900453 name: "microdroid_bootconfig_debuggable_src",
454 srcs: ["bootconfig.debuggable"],
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000455}
456
457filegroup {
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000458 name: "microdroid_bootconfig_normal_src",
459 srcs: ["bootconfig.normal"],
460}
Shikha Panwared8ace42022-09-28 12:52:16 +0000461
Alice Wangc5c966d2023-01-04 10:44:07 +0000462// python -c "import hashlib; print(hashlib.sha256(b'initrd_normal').hexdigest())"
463initrd_normal_salt = "8041a07d54ac82290f6d90bac1fa8d7fdbc4db974d101d60faf294749d1ebaf8"
464
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900465avb_gen_vbmeta_image_defaults {
466 name: "microdroid_initrd_defaults",
Alice Wangc5c966d2023-01-04 10:44:07 +0000467 enabled: false,
468 arch: {
469 // Microdroid kernel is only available in these architectures.
470 arm64: {
471 enabled: true,
472 },
473 x86_64: {
474 enabled: true,
475 },
476 },
477}
478
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900479avb_gen_vbmeta_image_defaults {
480 name: "microdroid_initrd_normal_defaults",
481 defaults: ["microdroid_initrd_defaults"],
Inseob Kim77c7f712023-11-06 17:01:02 +0900482 partition_name: "initrd_normal",
483 salt: initrd_normal_salt,
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900484}
485
486avb_gen_vbmeta_image {
487 name: "microdroid_initrd_normal_hashdesc",
488 defaults: ["microdroid_initrd_normal_defaults"],
489 src: ":microdroid_initrd_normal",
Inseob Kim77c7f712023-11-06 17:01:02 +0900490}
491
Alice Wangc5c966d2023-01-04 10:44:07 +0000492// python -c "import hashlib; print(hashlib.sha256(b'initrd_debug').hexdigest())"
493initrd_debug_salt = "8ab9dc9cb7e6456700ff6ef18c6b4c3acc24c5fa5381b829563f8d7a415d869a"
494
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900495avb_gen_vbmeta_image_defaults {
496 name: "microdroid_initrd_debug_defaults",
497 defaults: ["microdroid_initrd_defaults"],
Alice Wangc41ebfb2023-01-11 09:06:32 +0000498 partition_name: "initrd_debug",
Alice Wangc5c966d2023-01-04 10:44:07 +0000499 salt: initrd_debug_salt,
Alice Wangc5c966d2023-01-04 10:44:07 +0000500}
501
Inseob Kim77c7f712023-11-06 17:01:02 +0900502avb_gen_vbmeta_image {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900503 name: "microdroid_initrd_debug_hashdesc",
504 defaults: ["microdroid_initrd_debug_defaults"],
505 src: ":microdroid_initrd_debuggable",
Inseob Kim77c7f712023-11-06 17:01:02 +0900506}
507
Shikha Panwar2a788662023-09-11 14:04:24 +0000508soong_config_module_type {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900509 name: "flag_aware_avb_add_hash_footer_defaults",
510 module_type: "avb_add_hash_footer_defaults",
Shikha Panwar2a788662023-09-11 14:04:24 +0000511 config_namespace: "ANDROID",
512 bool_variables: [
513 "release_avf_enable_llpvm_changes",
514 ],
515 properties: [
516 "rollback_index",
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000517 "props",
Shikha Panwar2a788662023-09-11 14:04:24 +0000518 ],
519}
520
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900521flag_aware_avb_add_hash_footer_defaults {
522 name: "microdroid_kernel_signed_defaults",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100523 src: ":empty_file",
Alice Wang8aa3cb12023-01-11 09:04:04 +0000524 partition_name: "boot",
Shikha Panwared8ace42022-09-28 12:52:16 +0000525 private_key: ":microdroid_sign_key",
526 salt: bootloader_salt,
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000527 enabled: false,
528 arch: {
529 arm64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000530 enabled: true,
531 },
532 x86_64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000533 enabled: true,
534 },
535 },
Shikha Panwar2a788662023-09-11 14:04:24 +0000536 // Below are properties that are conditionally set depending on value of build flags.
537 soong_config_variables: {
538 release_avf_enable_llpvm_changes: {
539 rollback_index: 1,
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000540 props: [
541 {
542 name: "com.android.virt.cap",
543 value: "secretkeeper_protection",
544 },
545 ],
Shikha Panwar2a788662023-09-11 14:04:24 +0000546 },
547 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000548}
549
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900550avb_add_hash_footer {
551 name: "microdroid_kernel_signed",
552 defaults: ["microdroid_kernel_signed_defaults"],
553 filename: "microdroid_kernel",
Inseob Kim77c7f712023-11-06 17:01:02 +0900554 arch: {
555 arm64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000556 src: ":microdroid_kernel_prebuilt-arm64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900557 },
558 x86_64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000559 src: ":microdroid_kernel_prebuilt-x86_64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900560 },
561 },
562 include_descriptors_from_images: [
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900563 ":microdroid_initrd_normal_hashdesc",
564 ":microdroid_initrd_debug_hashdesc",
Inseob Kim77c7f712023-11-06 17:01:02 +0900565 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900566}
567
Shikha Panwared8ace42022-09-28 12:52:16 +0000568prebuilt_etc {
569 name: "microdroid_kernel",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100570 src: ":empty_file",
Shikha Panwared8ace42022-09-28 12:52:16 +0000571 relative_install_path: "fs",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000572 arch: {
573 arm64: {
574 src: ":microdroid_kernel_signed",
575 },
576 x86_64: {
577 src: ":microdroid_kernel_signed",
578 },
579 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000580}
Inseob Kim77c7f712023-11-06 17:01:02 +0900581
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900582///////////////////////////////////////
Inseob Kim0276f612023-12-07 17:25:18 +0900583// GKI-android14-6.1 modules
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900584///////////////////////////////////////
Inseob Kim77c7f712023-11-06 17:01:02 +0900585prebuilt_etc {
Inseob Kim0276f612023-12-07 17:25:18 +0900586 name: "microdroid_gki-android14-6.1.json",
587 src: "microdroid_gki-android14-6.1.json",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900588}
589
590avb_add_hash_footer {
Inseob Kim0276f612023-12-07 17:25:18 +0900591 name: "microdroid_gki-android14-6.1_kernel_signed",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900592 defaults: ["microdroid_kernel_signed_defaults"],
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900593 filename: "microdroid_gki-android14-6.1_kernel_signed",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900594 arch: {
595 arm64: {
596 src: ":microdroid_gki_kernel_prebuilts-6.1-arm64",
597 },
598 x86_64: {
599 src: ":microdroid_gki_kernel_prebuilts-6.1-x86_64",
600 },
601 },
602 include_descriptors_from_images: [
Inseob Kim0276f612023-12-07 17:25:18 +0900603 ":microdroid_gki-android14-6.1_initrd_normal_hashdesc",
604 ":microdroid_gki-android14-6.1_initrd_debug_hashdesc",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900605 ],
606}
607
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900608// HACK: use cc_genrule for arch-specific properties
609cc_genrule {
610 name: "microdroid_gki-android14-6.1_kernel_signed-lz4",
611 out: ["microdroid_gki-android14-6.1_kernel_signed-lz4"],
612 srcs: [":empty_file"],
613 arch: {
614 arm64: {
615 srcs: [":microdroid_gki-android14-6.1_kernel_signed"],
616 exclude_srcs: [":empty_file"],
617 },
618 },
619 tools: ["lz4"],
620 cmd: "$(location lz4) -9 $(in) $(out)",
621}
622
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900623prebuilt_etc {
Inseob Kim0276f612023-12-07 17:25:18 +0900624 name: "microdroid_gki-android14-6.1_kernel",
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900625 filename: "microdroid_gki-android14-6.1_kernel",
Inseob Kim77c7f712023-11-06 17:01:02 +0900626 src: ":empty_file",
627 relative_install_path: "fs",
628 arch: {
629 arm64: {
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900630 src: ":microdroid_gki-android14-6.1_kernel_signed-lz4",
Inseob Kim77c7f712023-11-06 17:01:02 +0900631 },
632 x86_64: {
Inseob Kim0276f612023-12-07 17:25:18 +0900633 src: ":microdroid_gki-android14-6.1_kernel_signed",
Inseob Kim77c7f712023-11-06 17:01:02 +0900634 },
635 },
636}
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900637
638avb_gen_vbmeta_image {
Inseob Kim0276f612023-12-07 17:25:18 +0900639 name: "microdroid_gki-android14-6.1_initrd_normal_hashdesc",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900640 defaults: ["microdroid_initrd_normal_defaults"],
Inseob Kim0276f612023-12-07 17:25:18 +0900641 src: ":microdroid_gki-android14-6.1_initrd_normal",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900642}
643
644avb_gen_vbmeta_image {
Inseob Kim0276f612023-12-07 17:25:18 +0900645 name: "microdroid_gki-android14-6.1_initrd_debug_hashdesc",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900646 defaults: ["microdroid_initrd_debug_defaults"],
Inseob Kim0276f612023-12-07 17:25:18 +0900647 src: ":microdroid_gki-android14-6.1_initrd_debuggable",
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900648}
Alice Wang89cae4f2024-02-22 14:40:00 +0000649
650python_binary_host {
651 name: "extract_microdroid_kernel_hashes",
652 srcs: ["extract_microdroid_kernel_hashes.py"],
653}
654
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900655// HACK: use cc_genrule for arch-specific properties
656cc_genrule {
Alice Wang89cae4f2024-02-22 14:40:00 +0000657 name: "microdroid_kernel_hashes_rs",
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900658 srcs: [":microdroid_kernel"],
659 arch: {
660 arm64: {
661 srcs: [":microdroid_gki-android14-6.1_kernel_signed"],
662 },
663 x86_64: {
664 srcs: [":microdroid_gki-android14-6.1_kernel_signed"],
665 },
666 },
Alice Wang89cae4f2024-02-22 14:40:00 +0000667 out: ["lib.rs"],
668 tools: [
669 "extract_microdroid_kernel_hashes",
670 "avbtool",
671 ],
672 cmd: "$(location extract_microdroid_kernel_hashes) --avbtool $(location avbtool) " +
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900673 "--kernel $(in) > $(out)",
Alice Wang89cae4f2024-02-22 14:40:00 +0000674}
675
676rust_library_rlib {
677 name: "libmicrodroid_kernel_hashes",
678 srcs: [":microdroid_kernel_hashes_rs"],
679 crate_name: "microdroid_kernel_hashes",
680 prefer_rlib: true,
681 no_stdlibs: true,
682 stdlibs: [
683 "libcompiler_builtins.rust_sysroot",
684 "libcore.rust_sysroot",
685 ],
686}