blob: dea0bf3999066755f808577aa7bcd620f851728c [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",
Shikha Panwar5cb5b992022-12-12 11:51:07 +000085 "mke2fs.microdroid",
Nikita Ioffe57b4dfc2023-06-14 20:29:37 +000086 "microdroid_fstab",
Jooyung Han8a17ef72021-08-04 15:39:54 +090087
Alice Wang2e57b082022-10-27 10:39:01 +000088 "libvm_payload", // used by payload to interact with microdroid manager
Jiyong Park61eebed2022-12-20 19:24:48 +090089
Jiyong Park5f7ae032022-12-22 10:24:39 +090090 "prng_seeder_microdroid",
Nikita Ioffe858fa052023-03-03 00:46:35 +000091
92 // Binaries required to capture traces in Microdroid.
93 "atrace",
94 "traced",
95 "traced_probes",
96 "perfetto",
Inseob Kim7e0ba432024-07-26 11:15:31 +090097 ] + select(release_flag("RELEASE_AVF_ENABLE_MULTI_TENANT_MICRODROID_VM"), {
98 true: [
99 "microdroid_etc_passwd",
100 "microdroid_etc_group",
101 ],
102 default: [],
103 }) + microdroid_shell_and_utilities,
Inseob Kimdc2af862021-02-17 15:51:56 +0900104 multilib: {
105 common: {
106 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900107 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900108 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900109
Jiyong Park9117f012022-07-07 15:24:06 +0900110 "microdroid_crashdump_initrd",
Nikita Ioffe536bc552023-06-14 20:29:37 +0000111 "microdroid_precompiled_sepolicy",
Inseob Kimdc2af862021-02-17 15:51:56 +0900112 ],
113 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900114 lib64: {
115 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900116 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700117 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700118 "authfs_service",
Shikha Panwar566c9672022-11-15 14:39:58 +0000119 "encryptedstore",
Jiyong Park9e5ae632022-07-08 14:47:23 +0900120 "microdroid_kexec",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900121 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900122 "zipfuse",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900123 ] + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
124 true: ["derive_microdroid_vendor_dice_node"],
125 default: [],
126 }),
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900127 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900128 },
Colin Crossca0049b2023-03-22 16:03:19 -0700129 arch: {
130 // b/273792258: These could be in multilib.lib64 except that
131 // microdroid_crashdump_kernel doesn't exist for riscv64 yet
132 arm64: {
133 deps: [
134 "microdroid_crashdump_kernel",
135 ],
136 },
137 x86_64: {
138 deps: [
139 "microdroid_crashdump_kernel",
140 ],
141 },
142 },
Spandan Dasc2180fc2024-11-11 21:27:05 +0000143 linker_config: {
Kiyoung Kim27cbf4c2024-11-07 17:13:26 +0900144 gen_linker_config: true,
145 linker_config_srcs: ["linker.config.json"],
146 },
Inseob Kima313e562021-02-15 17:04:39 +0900147 base_dir: "system",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900148 dirs: microdroid_rootdirs + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
149 true: ["microdroid_resources"],
150 default: [],
151 }),
Inseob Kim5ffc0822021-02-09 21:23:36 +0900152 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900153 file_contexts: ":microdroid_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900154 // For deterministic output, use fake_timestamp, hard-coded uuid
155 fake_timestamp: "1611569676",
156 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/system'))"
157 uuid: "5fe079c6-f01a-52be-87d3-d415231a72ad",
Jiyong Parkb552bb62021-01-25 19:12:47 +0900158}
Jiyong Park153d3552021-02-04 08:54:31 +0900159
Inseob Kimdc2af862021-02-17 15:51:56 +0900160prebuilt_etc {
161 name: "microdroid_init_rc",
162 filename: "init.rc",
163 src: "init.rc",
164 relative_install_path: "init/hw",
Jiyong Park5f939f92024-05-01 16:18:14 +0900165 no_full_install: true, // avoid collision with system partition's init.rc
Inseob Kimdc2af862021-02-17 15:51:56 +0900166}
167
Jiyong Park4d228952021-10-18 18:28:57 +0900168prebuilt_etc {
169 name: "microdroid_ueventd_rc",
170 filename: "ueventd.rc",
171 src: "ueventd.rc",
Jiyong Park5f939f92024-05-01 16:18:14 +0900172 no_full_install: true, // avoid collision with system partition's ueventd.rc
Jiyong Park4d228952021-10-18 18:28:57 +0900173}
174
Alan Stokes1294f942023-08-21 14:34:12 +0100175prebuilt_etc {
176 name: "microdroid_etc_passwd",
177 src: "microdroid_passwd",
178 filename: "passwd",
Jiyong Park5f939f92024-05-01 16:18:14 +0900179 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100180}
181
182prebuilt_etc {
183 name: "microdroid_etc_group",
184 src: "microdroid_group",
185 filename: "group",
Jiyong Park5f939f92024-05-01 16:18:14 +0900186 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100187}
188
Inseob Kim23ce1582021-04-06 21:25:57 +0900189prebuilt_root {
190 name: "microdroid_build_prop",
191 filename: "build.prop",
192 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900193 arch: {
194 x86_64: {
195 src: ":microdroid_build_prop_gen_x86_64",
196 },
197 arm64: {
198 src: ":microdroid_build_prop_gen_arm64",
199 },
200 },
Jiyong Park5f939f92024-05-01 16:18:14 +0900201 no_full_install: true,
Inseob Kim23ce1582021-04-06 21:25:57 +0900202}
203
Cole Faust316e6422024-10-22 16:31:03 -0700204java_genrule {
Jiyong Park68f560c2021-05-24 17:38:27 +0900205 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900206 srcs: [
207 "build.prop",
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000208 ":system-build.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900209 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900210 out: ["build.prop.out"],
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000211 cmd: "(echo '# build properties from system/build.prop' && " +
212 "grep ro\\.build\\.version\\.codename= $(location :system-build.prop) && " +
213 "grep ro\\.build\\.version\\.release= $(location :system-build.prop) && " +
214 "grep ro\\.build\\.version\\.sdk= $(location :system-build.prop) && " +
215 "grep ro\\.build\\.version\\.security_patch= $(location :system-build.prop) && " +
216 "grep ro\\.build\\.version\\.known_codenames= $(location :system-build.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900217 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900218 "echo ro.product.cpu.abilist=x86_64 && " +
219 "echo ro.product.cpu.abi=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900220}
221
Cole Faust316e6422024-10-22 16:31:03 -0700222java_genrule {
Jiyong Park68f560c2021-05-24 17:38:27 +0900223 name: "microdroid_build_prop_gen_arm64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900224 srcs: [
225 "build.prop",
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000226 ":system-build.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900227 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900228 out: ["build.prop.out"],
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000229 cmd: "(echo '# build properties from system/build.prop' && " +
230 "grep ro\\.build\\.version\\.codename= $(location :system-build.prop) && " +
231 "grep ro\\.build\\.version\\.release= $(location :system-build.prop) && " +
232 "grep ro\\.build\\.version\\.sdk= $(location :system-build.prop) && " +
233 "grep ro\\.build\\.version\\.security_patch= $(location :system-build.prop) && " +
234 "grep ro\\.build\\.version\\.known_codenames= $(location :system-build.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900235 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900236 "echo ro.product.cpu.abilist=arm64-v8a && " +
237 "echo ro.product.cpu.abi=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900238}
239
Nikita Ioffee1112032023-11-13 15:09:39 +0000240// Need to keep microdroid_vendor for the release configurations that don't
241// have RELEASE_AVF_ENABLE_VENDOR_MODULES build flag enabled.
242android_filesystem {
243 name: "microdroid_vendor",
244 partition_name: "vendor",
245 use_avb: true,
246 avb_private_key: ":microdroid_sign_key",
247 avb_algorithm: "SHA256_RSA4096",
248 avb_hash_algorithm: "sha256",
Cole Fausta4448a42024-12-04 13:27:24 -0800249 use_fec: false,
Nikita Ioffee1112032023-11-13 15:09:39 +0000250 file_contexts: ":microdroid_vendor_file_contexts.gen",
251 // For deterministic output, use fake_timestamp, hard-coded uuid
252 fake_timestamp: "1611569676",
253 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/vendor'))"
254 uuid: "156d40d7-8d8e-5c99-8913-ec82de549a70",
255}
256
257soong_config_module_type {
258 name: "flag_aware_microdroid_super_partition",
259 module_type: "logical_partition",
260 config_namespace: "ANDROID",
261 bool_variables: [
262 "release_avf_enable_vendor_modules",
263 ],
264 properties: [
265 "default_group",
266 ],
267}
268
269flag_aware_microdroid_super_partition {
Jiyong Parkc1500e82021-02-24 01:39:51 +0900270 name: "microdroid_super",
271 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900272 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900273 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900274 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900275 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900276 filesystem: ":microdroid",
277 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900278 ],
Nikita Ioffee1112032023-11-13 15:09:39 +0000279 soong_config_variables: {
280 release_avf_enable_vendor_modules: {
Nikita Ioffe2814dd32023-11-17 15:41:36 +0000281 conditions_default: {
282 default_group: [
283 {
284 name: "vendor_a",
285 filesystem: ":microdroid_vendor",
286 },
287 ],
288 },
Nikita Ioffee1112032023-11-13 15:09:39 +0000289 },
290 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900291}
292
Inseob Kim7e0ba432024-07-26 11:15:31 +0900293android_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900294 name: "microdroid_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900295 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +0100296 "init_first_stage.microdroid",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900297 ],
298 dirs: [
299 "dev",
300 "proc",
301 "sys",
302
Jiyong Parkc8b40032021-02-18 23:15:41 +0900303 "mnt",
304 "debug_ramdisk",
305 "second_stage_resources",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900306 ] + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
307 true: ["microdroid_resources"],
308 default: [],
309 }),
Jiyong Parkc8b40032021-02-18 23:15:41 +0900310 type: "compressed_cpio",
311}
312
Jiyong Parkb54646f2022-02-07 11:13:56 +0900313android_filesystem {
Nikita Ioffe2c3bc222024-03-26 20:51:00 +0000314 name: "microdroid_first_stage_ramdisk",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900315 deps: [
316 "microdroid_fstab",
317 ],
318 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900319 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900320 symlinks: [
321 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900322 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900323 name: "first_stage_ramdisk/fstab.microdroid",
324 },
325 {
326 target: "first_stage_ramdisk/lib",
327 name: "lib",
328 },
329 ],
330}
331
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900332genrule {
333 name: "microdroid_bootconfig_arm64_gen",
334 srcs: [
335 "bootconfig.common",
336 "bootconfig.arm64",
337 ],
338 out: ["bootconfig"],
339 cmd: "cat $(in) > $(out)",
340}
341
342genrule {
343 name: "microdroid_bootconfig_x86_64_gen",
344 srcs: [
345 "bootconfig.common",
346 "bootconfig.x86_64",
347 ],
348 out: ["bootconfig"],
349 cmd: "cat $(in) > $(out)",
350}
351
Nikita Ioffef49350e2024-11-01 16:11:48 +0000352filegroup {
353 name: "microdroid_16k_bootconfig_x86_64_gen",
354 srcs: ["bootconfig.x86_64_16k"],
355}
356
Jiyong Park3eb11f72021-02-23 12:53:30 +0900357prebuilt_etc {
358 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900359 src: "fstab.microdroid",
360 filename: "fstab.microdroid",
Jiyong Park5f939f92024-05-01 16:18:14 +0900361 no_full_install: true,
Jiyong Park153d3552021-02-04 08:54:31 +0900362}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900363
Jooyung Han64214832022-04-21 14:30:04 +0900364// python -c "import hashlib; print(hashlib.sha256(b'bootloader').hexdigest())"
365bootloader_salt = "3b4a12881d11f33cff968a24d7c53723a8232cde9a8d91e29fdbd6a95ae6adf0"
366
Jooyung Hand35952e2021-11-08 17:53:47 +0900367filegroup {
368 name: "microdroid_sign_key",
Pierre-Clément Tosi2188d802024-05-24 10:56:26 +0100369 srcs: [":pvmfw_embedded_key"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900370}
371
Inseob Kim7e0ba432024-07-26 11:15:31 +0900372vbmeta {
Jiyong Park80d8da82021-03-15 23:30:11 +0900373 name: "microdroid_vbmeta",
374 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900375 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900376 partitions: [
Jiyong Park80d8da82021-03-15 23:30:11 +0900377 "microdroid",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900378 ] + select(release_flag("RELEASE_AVF_ENABLE_VENDOR_MODULES"), {
379 true: [],
380 default: ["microdroid_vendor"],
381 }),
Jiyong Park80d8da82021-03-15 23:30:11 +0900382}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900383
384prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900385 name: "microdroid.json",
386 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900387}
Jooyung Han017916b2021-04-20 03:57:19 +0900388
389prebuilt_etc {
Nikita Ioffef49350e2024-11-01 16:11:48 +0000390 name: "microdroid_16k.json",
391 src: "microdroid_16k.json",
392}
393
394prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900395 name: "microdroid_manifest",
396 src: "microdroid_manifest.xml",
397 filename: "manifest.xml",
398 relative_install_path: "vintf",
Jiyong Park5f939f92024-05-01 16:18:14 +0900399 no_full_install: true,
Inseob Kim8f095c92021-05-26 12:04:54 +0900400}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700401
402prebuilt_etc {
403 name: "microdroid_event-log-tags",
404 src: "microdroid_event-log-tags",
405 filename: "event-log-tags",
Jiyong Park5f939f92024-05-01 16:18:14 +0900406 no_full_install: true,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900407}
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000408
409filegroup {
Seungjae Yooe85831e2022-12-12 09:34:58 +0900410 name: "microdroid_bootconfig_debuggable_src",
411 srcs: ["bootconfig.debuggable"],
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000412}
413
414filegroup {
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000415 name: "microdroid_bootconfig_normal_src",
416 srcs: ["bootconfig.normal"],
417}
Shikha Panwared8ace42022-09-28 12:52:16 +0000418
Alice Wangc5c966d2023-01-04 10:44:07 +0000419// python -c "import hashlib; print(hashlib.sha256(b'initrd_normal').hexdigest())"
420initrd_normal_salt = "8041a07d54ac82290f6d90bac1fa8d7fdbc4db974d101d60faf294749d1ebaf8"
421
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900422avb_gen_vbmeta_image_defaults {
423 name: "microdroid_initrd_defaults",
Alice Wangc5c966d2023-01-04 10:44:07 +0000424 enabled: false,
425 arch: {
426 // Microdroid kernel is only available in these architectures.
427 arm64: {
428 enabled: true,
429 },
430 x86_64: {
431 enabled: true,
432 },
433 },
434}
435
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900436avb_gen_vbmeta_image_defaults {
437 name: "microdroid_initrd_normal_defaults",
438 defaults: ["microdroid_initrd_defaults"],
Inseob Kim77c7f712023-11-06 17:01:02 +0900439 partition_name: "initrd_normal",
440 salt: initrd_normal_salt,
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900441}
442
443avb_gen_vbmeta_image {
444 name: "microdroid_initrd_normal_hashdesc",
445 defaults: ["microdroid_initrd_normal_defaults"],
446 src: ":microdroid_initrd_normal",
Inseob Kim77c7f712023-11-06 17:01:02 +0900447}
448
Nikita Ioffef49350e2024-11-01 16:11:48 +0000449avb_gen_vbmeta_image {
450 name: "microdroid_16k_initrd_normal_hashdesc",
451 defaults: ["microdroid_initrd_normal_defaults"],
452 src: ":microdroid_16k_initrd_normal",
453}
454
Alice Wangc5c966d2023-01-04 10:44:07 +0000455// python -c "import hashlib; print(hashlib.sha256(b'initrd_debug').hexdigest())"
456initrd_debug_salt = "8ab9dc9cb7e6456700ff6ef18c6b4c3acc24c5fa5381b829563f8d7a415d869a"
457
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900458avb_gen_vbmeta_image_defaults {
459 name: "microdroid_initrd_debug_defaults",
460 defaults: ["microdroid_initrd_defaults"],
Alice Wangc41ebfb2023-01-11 09:06:32 +0000461 partition_name: "initrd_debug",
Alice Wangc5c966d2023-01-04 10:44:07 +0000462 salt: initrd_debug_salt,
Alice Wangc5c966d2023-01-04 10:44:07 +0000463}
464
Inseob Kim77c7f712023-11-06 17:01:02 +0900465avb_gen_vbmeta_image {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900466 name: "microdroid_initrd_debug_hashdesc",
467 defaults: ["microdroid_initrd_debug_defaults"],
468 src: ":microdroid_initrd_debuggable",
Inseob Kim77c7f712023-11-06 17:01:02 +0900469}
470
Nikita Ioffef49350e2024-11-01 16:11:48 +0000471avb_gen_vbmeta_image {
472 name: "microdroid_16k_initrd_debug_hashdesc",
473 defaults: ["microdroid_initrd_debug_defaults"],
474 src: ":microdroid_16k_initrd_debuggable",
475}
476
Shikha Panwar2a788662023-09-11 14:04:24 +0000477soong_config_module_type {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900478 name: "flag_aware_avb_add_hash_footer_defaults",
479 module_type: "avb_add_hash_footer_defaults",
Shikha Panwar2a788662023-09-11 14:04:24 +0000480 config_namespace: "ANDROID",
481 bool_variables: [
482 "release_avf_enable_llpvm_changes",
483 ],
484 properties: [
485 "rollback_index",
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000486 "props",
Shikha Panwar2a788662023-09-11 14:04:24 +0000487 ],
488}
489
Nikolina Ilicda207762024-12-04 13:55:46 +0000490avb_add_hash_footer_defaults {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900491 name: "microdroid_kernel_signed_defaults",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100492 src: ":empty_file",
Alice Wang8aa3cb12023-01-11 09:04:04 +0000493 partition_name: "boot",
Shikha Panwared8ace42022-09-28 12:52:16 +0000494 private_key: ":microdroid_sign_key",
495 salt: bootloader_salt,
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000496 enabled: false,
497 arch: {
498 arm64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000499 enabled: true,
500 },
501 x86_64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000502 enabled: true,
503 },
504 },
Nikolina Ilicda207762024-12-04 13:55:46 +0000505}
506
507MICRODROID_GKI_ROLLBACK_INDEX = 1
508
509flag_aware_avb_add_hash_footer_defaults {
510 name: "microdroid_kernel_cap_defaults",
Shikha Panwar2a788662023-09-11 14:04:24 +0000511 // Below are properties that are conditionally set depending on value of build flags.
512 soong_config_variables: {
513 release_avf_enable_llpvm_changes: {
Nikolina Ilicda207762024-12-04 13:55:46 +0000514 rollback_index: MICRODROID_GKI_ROLLBACK_INDEX,
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000515 props: [
516 {
517 name: "com.android.virt.cap",
518 value: "secretkeeper_protection",
519 },
520 ],
Shikha Panwar2a788662023-09-11 14:04:24 +0000521 },
522 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000523}
524
Nikolina Ilicda207762024-12-04 13:55:46 +0000525flag_aware_avb_add_hash_footer_defaults {
526 name: "microdroid_kernel_cap_with_uefi_defaults",
527 // Below are properties that are conditionally set depending on value of build flags.
528 soong_config_variables: {
529 release_avf_enable_llpvm_changes: {
530 rollback_index: MICRODROID_GKI_ROLLBACK_INDEX,
531 props: [
532 {
533 name: "com.android.virt.cap",
534 value: "secretkeeper_protection|supports_uefi_boot",
535 },
536 ],
537 conditions_default: {
538 props: [
539 {
540 name: "com.android.virt.cap",
541 value: "supports_uefi_boot",
542 },
543 ],
544 },
545 },
546 },
547}
548
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900549avb_add_hash_footer {
550 name: "microdroid_kernel_signed",
Nikolina Ilicda207762024-12-04 13:55:46 +0000551 defaults: [
552 "microdroid_kernel_signed_defaults",
553 "microdroid_kernel_cap_defaults",
554 ],
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900555 filename: "microdroid_kernel",
Inseob Kim77c7f712023-11-06 17:01:02 +0900556 arch: {
557 arm64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000558 src: ":microdroid_kernel_prebuilt-arm64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900559 },
560 x86_64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000561 src: ":microdroid_kernel_prebuilt-x86_64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900562 },
563 },
564 include_descriptors_from_images: [
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900565 ":microdroid_initrd_normal_hashdesc",
566 ":microdroid_initrd_debug_hashdesc",
Inseob Kim77c7f712023-11-06 17:01:02 +0900567 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900568}
569
Shikha Panwared8ace42022-09-28 12:52:16 +0000570prebuilt_etc {
571 name: "microdroid_kernel",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100572 src: ":empty_file",
Shikha Panwared8ace42022-09-28 12:52:16 +0000573 relative_install_path: "fs",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000574 arch: {
575 arm64: {
576 src: ":microdroid_kernel_signed",
577 },
578 x86_64: {
579 src: ":microdroid_kernel_signed",
580 },
581 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000582}
Inseob Kim77c7f712023-11-06 17:01:02 +0900583
Nikita Ioffef49350e2024-11-01 16:11:48 +0000584avb_add_hash_footer {
585 name: "microdroid_kernel_16k_signed",
Nikolina Ilicda207762024-12-04 13:55:46 +0000586 defaults: [
587 "microdroid_kernel_signed_defaults",
588 "microdroid_kernel_cap_defaults",
589 ],
Nikita Ioffef49350e2024-11-01 16:11:48 +0000590 filename: "microdroid_kernel_16k",
591 arch: {
592 arm64: {
593 src: ":microdroid_kernel_16k_prebuilt-arm64",
594 },
595 // There is no 16k x86_64 kernel. Instead the 16k emulation is triggered by adding
596 // `page_shift=14` to the kernel cmdline or bootconfig.
597 x86_64: {
598 src: ":microdroid_kernel_prebuilt-x86_64",
599 },
600 },
Pierre-Clément Tosi9fbbaf32024-11-26 14:00:01 +0000601 props: [
602 {
603 name: "com.android.virt.page_size",
604 value: "16",
605 },
606 ],
Nikita Ioffef49350e2024-11-01 16:11:48 +0000607 include_descriptors_from_images: [
608 ":microdroid_16k_initrd_normal_hashdesc",
609 ":microdroid_16k_initrd_debug_hashdesc",
610 ],
611}
612
613prebuilt_etc {
614 name: "microdroid_kernel_16k",
615 src: ":empty_file",
616 relative_install_path: "fs",
617 arch: {
618 arm64: {
619 src: ":microdroid_kernel_16k_signed",
620 },
621 x86_64: {
622 src: ":microdroid_kernel_16k_signed",
623 },
624 },
625}
626
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900627///////////////////////////////////////
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000628// GKI-android15-6.6
629///////////////////////////////////////
630prebuilt_etc {
631 name: "microdroid_gki-android15-6.6.json",
632 src: "microdroid_gki-android15-6.6.json",
633}
634
Nikolina Ilicda207762024-12-04 13:55:46 +0000635avb_add_hash_footer_defaults {
636 name: "microdroid_gki_kernel_signed_defaults",
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000637 defaults: ["microdroid_kernel_signed_defaults"],
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000638 arch: {
639 arm64: {
640 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-arm64",
641 },
642 x86_64: {
643 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-x86_64",
644 },
645 },
646 include_descriptors_from_images: [
647 ":microdroid_gki-android15-6.6_initrd_normal_hashdesc",
648 ":microdroid_gki-android15-6.6_initrd_debug_hashdesc",
649 ],
650}
651
Nikolina Ilicda207762024-12-04 13:55:46 +0000652avb_add_hash_footer {
653 name: "microdroid_gki-android15-6.6_kernel_signed",
654 defaults: [
655 "microdroid_gki_kernel_signed_defaults",
656 "microdroid_kernel_cap_defaults",
657 ],
658 filename: "microdroid_gki-android15-6.6_kernel_signed",
659}
660
661avb_add_hash_footer {
662 name: "microdroid_gki-android15-6.6_kernel_signed_supports_uefi_boot",
663 defaults: [
664 "microdroid_gki_kernel_signed_defaults",
665 "microdroid_kernel_cap_with_uefi_defaults",
666 ],
667 filename: "microdroid_gki-android15-6.6_kernel_signed_supports_uefi_boot",
668}
669
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000670// HACK: use cc_genrule for arch-specific properties
671cc_genrule {
672 name: "microdroid_gki-android15-6.6_kernel_signed-lz4",
673 out: ["microdroid_gki-android15-6.6_kernel_signed-lz4"],
674 srcs: [":empty_file"],
675 arch: {
676 arm64: {
677 srcs: [":microdroid_gki-android15-6.6_kernel_signed"],
678 exclude_srcs: [":empty_file"],
679 },
680 },
681 tools: ["lz4"],
682 cmd: "$(location lz4) -9 $(in) $(out)",
683}
684
685prebuilt_etc {
686 name: "microdroid_gki-android15-6.6_kernel",
687 filename: "microdroid_gki-android15-6.6_kernel",
688 src: ":empty_file",
689 relative_install_path: "fs",
690 arch: {
691 arm64: {
692 src: ":microdroid_gki-android15-6.6_kernel_signed",
693 },
694 x86_64: {
695 src: ":microdroid_gki-android15-6.6_kernel_signed",
696 },
697 },
698}
699
700avb_gen_vbmeta_image {
701 name: "microdroid_gki-android15-6.6_initrd_normal_hashdesc",
702 defaults: ["microdroid_initrd_normal_defaults"],
703 src: ":microdroid_gki-android15-6.6_initrd_normal",
704}
705
706avb_gen_vbmeta_image {
707 name: "microdroid_gki-android15-6.6_initrd_debug_hashdesc",
708 defaults: ["microdroid_initrd_debug_defaults"],
709 src: ":microdroid_gki-android15-6.6_initrd_debuggable",
710}
711
Alice Wang89cae4f2024-02-22 14:40:00 +0000712python_binary_host {
713 name: "extract_microdroid_kernel_hashes",
714 srcs: ["extract_microdroid_kernel_hashes.py"],
715}
716
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900717// HACK: use cc_genrule for arch-specific properties
718cc_genrule {
Alice Wang89cae4f2024-02-22 14:40:00 +0000719 name: "microdroid_kernel_hashes_rs",
Cole Faust2b944092024-10-23 16:37:21 -0700720 compile_multilib: "first",
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900721 srcs: [":microdroid_kernel"],
722 arch: {
723 arm64: {
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000724 srcs: [
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000725 ":microdroid_gki-android15-6.6_kernel_signed",
726 ],
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900727 },
728 x86_64: {
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000729 srcs: [
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000730 ":microdroid_gki-android15-6.6_kernel_signed",
731 ],
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900732 },
733 },
Alice Wang89cae4f2024-02-22 14:40:00 +0000734 out: ["lib.rs"],
735 tools: [
736 "extract_microdroid_kernel_hashes",
737 "avbtool",
738 ],
739 cmd: "$(location extract_microdroid_kernel_hashes) --avbtool $(location avbtool) " +
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900740 "--kernel $(in) > $(out)",
Alice Wang89cae4f2024-02-22 14:40:00 +0000741}
742
743rust_library_rlib {
744 name: "libmicrodroid_kernel_hashes",
Cole Faust2b944092024-10-23 16:37:21 -0700745 compile_multilib: "first",
Alice Wang89cae4f2024-02-22 14:40:00 +0000746 srcs: [":microdroid_kernel_hashes_rs"],
747 crate_name: "microdroid_kernel_hashes",
748 prefer_rlib: true,
749 no_stdlibs: true,
750 stdlibs: [
751 "libcompiler_builtins.rust_sysroot",
752 "libcore.rust_sysroot",
753 ],
754}