blob: d5d81081227ce340472de3f0ac228d17689058e3 [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",
Jiyong Parkd4326f32021-03-15 23:25:46 +090053 partition_name: "system",
Jiyong Parkb552bb62021-01-25 19:12:47 +090054 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +010055 "init_second_stage.microdroid",
Inseob Kim23ce1582021-04-06 21:25:57 +090056 "microdroid_build_prop",
Jaewan Kimb24d1dc2023-02-13 15:34:56 +090057 "microdroid_init_debug_policy",
Jiyong Park40699612021-05-24 16:55:06 +090058 "microdroid_init_rc",
Jiyong Park4d228952021-10-18 18:28:57 +090059 "microdroid_ueventd_rc",
Jiyong Park40699612021-05-24 16:55:06 +090060 "microdroid_launcher",
Jooyung Han7ce2e532021-06-16 16:52:02 +090061
Jooyung Han837eef52021-05-15 11:33:48 +090062 "libbinder_ndk",
Inseob Kimdc2af862021-02-17 15:51:56 +090063 "libstdc++",
Jooyung Han017916b2021-04-20 03:57:19 +090064
65 // "com.android.adbd" requires these,
66 "libadbd_auth",
67 "libadbd_fs",
68
Jooyung Han730b7b82021-05-12 14:09:38 +090069 // "com.android.art" requires
70 "heapprofd_client_api",
Victor Hsieh527b81d2021-06-11 10:41:11 -070071 "libartpalette-system",
Jooyung Han730b7b82021-05-12 14:09:38 +090072
Jooyung Hanb6a52152022-12-12 11:20:23 +090073 "apexd.microdroid",
Inseob Kimdc2af862021-02-17 15:51:56 +090074 "debuggerd",
75 "linker",
Inseob Kimdc2af862021-02-17 15:51:56 +090076 "cgroups.json",
Inseob Kime60307a2022-04-14 03:48:38 +090077 "task_profiles.json",
Jooyung Han1c820732021-04-15 05:16:23 +090078 "public.libraries.android.txt",
Inseob Kimd8cf7622021-02-18 19:12:06 +090079
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070080 "microdroid_event-log-tags",
Inseob Kimff43be22021-06-07 16:56:56 +090081 "microdroid_file_contexts",
Oleg Matcovschi7b413a22022-03-18 01:51:58 -070082 "microdroid_manifest",
Inseob Kimff43be22021-06-07 16:56:56 +090083 "microdroid_property_contexts",
Shikha Panwar5cb5b992022-12-12 11:51:07 +000084 "mke2fs.microdroid",
Nikita Ioffe57b4dfc2023-06-14 20:29:37 +000085 "microdroid_fstab",
Jooyung Han8a17ef72021-08-04 15:39:54 +090086
Alice Wang2e57b082022-10-27 10:39:01 +000087 "libvm_payload", // used by payload to interact with microdroid manager
Jiyong Park61eebed2022-12-20 19:24:48 +090088
Jiyong Park5f7ae032022-12-22 10:24:39 +090089 "prng_seeder_microdroid",
Nikita Ioffe858fa052023-03-03 00:46:35 +000090
91 // Binaries required to capture traces in Microdroid.
92 "atrace",
93 "traced",
94 "traced_probes",
95 "perfetto",
Inseob Kim7e0ba432024-07-26 11:15:31 +090096 ] + select(release_flag("RELEASE_AVF_ENABLE_MULTI_TENANT_MICRODROID_VM"), {
97 true: [
98 "microdroid_etc_passwd",
99 "microdroid_etc_group",
100 ],
101 default: [],
102 }) + microdroid_shell_and_utilities,
Inseob Kimdc2af862021-02-17 15:51:56 +0900103 multilib: {
104 common: {
105 deps: [
Jooyung Han1c2d7582021-09-08 22:46:42 +0900106 // non-updatable & mandatory apexes
Inseob Kimdc2af862021-02-17 15:51:56 +0900107 "com.android.runtime",
Jooyung Han1c2d7582021-09-08 22:46:42 +0900108
Jiyong Park9117f012022-07-07 15:24:06 +0900109 "microdroid_crashdump_initrd",
Nikita Ioffe536bc552023-06-14 20:29:37 +0000110 "microdroid_precompiled_sepolicy",
Inseob Kimdc2af862021-02-17 15:51:56 +0900111 ],
112 },
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900113 lib64: {
114 deps: [
Jooyung Han7ce2e532021-06-16 16:52:02 +0900115 "apkdmverity",
Victor Hsieh2445e332021-06-04 16:44:53 -0700116 "authfs",
Victor Hsieh8bb67b62021-08-04 12:10:58 -0700117 "authfs_service",
Shikha Panwar566c9672022-11-15 14:39:58 +0000118 "encryptedstore",
Jiyong Park9e5ae632022-07-08 14:47:23 +0900119 "microdroid_kexec",
Jiyong Park21ce2c52021-08-28 02:32:17 +0900120 "microdroid_manager",
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900121 "zipfuse",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900122 ] + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
123 true: ["derive_microdroid_vendor_dice_node"],
124 default: [],
125 }),
Jiyong Parkcc5d26b2021-05-17 11:27:34 +0900126 },
Inseob Kimdc2af862021-02-17 15:51:56 +0900127 },
Colin Crossca0049b2023-03-22 16:03:19 -0700128 arch: {
129 // b/273792258: These could be in multilib.lib64 except that
130 // microdroid_crashdump_kernel doesn't exist for riscv64 yet
131 arm64: {
132 deps: [
133 "microdroid_crashdump_kernel",
134 ],
135 },
136 x86_64: {
137 deps: [
138 "microdroid_crashdump_kernel",
139 ],
140 },
141 },
Jiyong Park92199ce2021-04-16 21:35:58 +0900142 linker_config_src: "linker.config.json",
Inseob Kima313e562021-02-15 17:04:39 +0900143 base_dir: "system",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900144 dirs: microdroid_rootdirs + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
145 true: ["microdroid_resources"],
146 default: [],
147 }),
Inseob Kim5ffc0822021-02-09 21:23:36 +0900148 symlinks: microdroid_symlinks,
Inseob Kimff43be22021-06-07 16:56:56 +0900149 file_contexts: ":microdroid_file_contexts.gen",
Jooyung Han64214832022-04-21 14:30:04 +0900150 // For deterministic output, use fake_timestamp, hard-coded uuid
151 fake_timestamp: "1611569676",
152 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/system'))"
153 uuid: "5fe079c6-f01a-52be-87d3-d415231a72ad",
Jiyong Parkb552bb62021-01-25 19:12:47 +0900154}
Jiyong Park153d3552021-02-04 08:54:31 +0900155
Inseob Kimdc2af862021-02-17 15:51:56 +0900156prebuilt_etc {
157 name: "microdroid_init_rc",
158 filename: "init.rc",
159 src: "init.rc",
160 relative_install_path: "init/hw",
Jiyong Park5f939f92024-05-01 16:18:14 +0900161 no_full_install: true, // avoid collision with system partition's init.rc
Inseob Kimdc2af862021-02-17 15:51:56 +0900162}
163
Jiyong Park4d228952021-10-18 18:28:57 +0900164prebuilt_etc {
165 name: "microdroid_ueventd_rc",
166 filename: "ueventd.rc",
167 src: "ueventd.rc",
Jiyong Park5f939f92024-05-01 16:18:14 +0900168 no_full_install: true, // avoid collision with system partition's ueventd.rc
Jiyong Park4d228952021-10-18 18:28:57 +0900169}
170
Alan Stokes1294f942023-08-21 14:34:12 +0100171prebuilt_etc {
172 name: "microdroid_etc_passwd",
173 src: "microdroid_passwd",
174 filename: "passwd",
Jiyong Park5f939f92024-05-01 16:18:14 +0900175 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100176}
177
178prebuilt_etc {
179 name: "microdroid_etc_group",
180 src: "microdroid_group",
181 filename: "group",
Jiyong Park5f939f92024-05-01 16:18:14 +0900182 no_full_install: true,
Alan Stokes1294f942023-08-21 14:34:12 +0100183}
184
Inseob Kim23ce1582021-04-06 21:25:57 +0900185prebuilt_root {
186 name: "microdroid_build_prop",
187 filename: "build.prop",
188 src: "build.prop",
Jiyong Park68f560c2021-05-24 17:38:27 +0900189 arch: {
190 x86_64: {
191 src: ":microdroid_build_prop_gen_x86_64",
192 },
193 arm64: {
194 src: ":microdroid_build_prop_gen_arm64",
195 },
196 },
Jiyong Park5f939f92024-05-01 16:18:14 +0900197 no_full_install: true,
Inseob Kim23ce1582021-04-06 21:25:57 +0900198}
199
Cole Faust316e6422024-10-22 16:31:03 -0700200java_genrule {
Jiyong Park68f560c2021-05-24 17:38:27 +0900201 name: "microdroid_build_prop_gen_x86_64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900202 srcs: [
203 "build.prop",
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000204 ":system-build.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900205 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900206 out: ["build.prop.out"],
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000207 cmd: "(echo '# build properties from system/build.prop' && " +
208 "grep ro\\.build\\.version\\.codename= $(location :system-build.prop) && " +
209 "grep ro\\.build\\.version\\.release= $(location :system-build.prop) && " +
210 "grep ro\\.build\\.version\\.sdk= $(location :system-build.prop) && " +
211 "grep ro\\.build\\.version\\.security_patch= $(location :system-build.prop) && " +
212 "grep ro\\.build\\.version\\.known_codenames= $(location :system-build.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900213 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900214 "echo ro.product.cpu.abilist=x86_64 && " +
215 "echo ro.product.cpu.abi=x86_64) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900216}
217
Cole Faust316e6422024-10-22 16:31:03 -0700218java_genrule {
Jiyong Park68f560c2021-05-24 17:38:27 +0900219 name: "microdroid_build_prop_gen_arm64",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900220 srcs: [
221 "build.prop",
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000222 ":system-build.prop",
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900223 ],
Jiyong Park68f560c2021-05-24 17:38:27 +0900224 out: ["build.prop.out"],
Inseob Kim08ef7ff2024-07-31 02:00:41 +0000225 cmd: "(echo '# build properties from system/build.prop' && " +
226 "grep ro\\.build\\.version\\.codename= $(location :system-build.prop) && " +
227 "grep ro\\.build\\.version\\.release= $(location :system-build.prop) && " +
228 "grep ro\\.build\\.version\\.sdk= $(location :system-build.prop) && " +
229 "grep ro\\.build\\.version\\.security_patch= $(location :system-build.prop) && " +
230 "grep ro\\.build\\.version\\.known_codenames= $(location :system-build.prop) && " +
Inseob Kim0ff6b6e2022-04-25 18:24:58 +0900231 "cat $(location build.prop) && " +
Jiyong Park7b160bf2022-10-23 15:37:14 +0900232 "echo ro.product.cpu.abilist=arm64-v8a && " +
233 "echo ro.product.cpu.abi=arm64-v8a) > $(out)",
Jiyong Park68f560c2021-05-24 17:38:27 +0900234}
235
Nikita Ioffee1112032023-11-13 15:09:39 +0000236// Need to keep microdroid_vendor for the release configurations that don't
237// have RELEASE_AVF_ENABLE_VENDOR_MODULES build flag enabled.
238android_filesystem {
239 name: "microdroid_vendor",
240 partition_name: "vendor",
241 use_avb: true,
242 avb_private_key: ":microdroid_sign_key",
243 avb_algorithm: "SHA256_RSA4096",
244 avb_hash_algorithm: "sha256",
245 file_contexts: ":microdroid_vendor_file_contexts.gen",
246 // For deterministic output, use fake_timestamp, hard-coded uuid
247 fake_timestamp: "1611569676",
248 // python -c "import uuid; print(uuid.uuid5(uuid.NAMESPACE_URL, 'www.android.com/avf/microdroid/vendor'))"
249 uuid: "156d40d7-8d8e-5c99-8913-ec82de549a70",
250}
251
252soong_config_module_type {
253 name: "flag_aware_microdroid_super_partition",
254 module_type: "logical_partition",
255 config_namespace: "ANDROID",
256 bool_variables: [
257 "release_avf_enable_vendor_modules",
258 ],
259 properties: [
260 "default_group",
261 ],
262}
263
264flag_aware_microdroid_super_partition {
Jiyong Parkc1500e82021-02-24 01:39:51 +0900265 name: "microdroid_super",
266 sparse: true,
Inseob Kimc95b6422021-03-31 16:31:27 +0900267 size: "auto",
Inseob Kimd1004752021-03-30 16:57:27 +0900268 default_group: [
Jiyong Parkc1500e82021-02-24 01:39:51 +0900269 {
Jiyong Park52ea0832021-09-01 12:10:18 +0900270 name: "system_a",
Inseob Kimd1004752021-03-30 16:57:27 +0900271 filesystem: ":microdroid",
272 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900273 ],
Nikita Ioffee1112032023-11-13 15:09:39 +0000274 soong_config_variables: {
275 release_avf_enable_vendor_modules: {
Nikita Ioffe2814dd32023-11-17 15:41:36 +0000276 conditions_default: {
277 default_group: [
278 {
279 name: "vendor_a",
280 filesystem: ":microdroid_vendor",
281 },
282 ],
283 },
Nikita Ioffee1112032023-11-13 15:09:39 +0000284 },
285 },
Jiyong Parkc1500e82021-02-24 01:39:51 +0900286}
287
Inseob Kim7e0ba432024-07-26 11:15:31 +0900288android_filesystem {
Jiyong Park09a2bda2022-06-13 16:44:45 +0900289 name: "microdroid_ramdisk",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900290 deps: [
Nikita Ioffe010b1ad2023-06-21 16:43:16 +0100291 "init_first_stage.microdroid",
Jiyong Parkc8b40032021-02-18 23:15:41 +0900292 ],
293 dirs: [
294 "dev",
295 "proc",
296 "sys",
297
Jiyong Parkc8b40032021-02-18 23:15:41 +0900298 "mnt",
299 "debug_ramdisk",
300 "second_stage_resources",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900301 ] + select(release_flag("RELEASE_AVF_ENABLE_DICE_CHANGES"), {
302 true: ["microdroid_resources"],
303 default: [],
304 }),
Jiyong Parkc8b40032021-02-18 23:15:41 +0900305 type: "compressed_cpio",
306}
307
Jiyong Parkb54646f2022-02-07 11:13:56 +0900308android_filesystem {
Nikita Ioffe2c3bc222024-03-26 20:51:00 +0000309 name: "microdroid_first_stage_ramdisk",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900310 deps: [
311 "microdroid_fstab",
312 ],
313 base_dir: "first_stage_ramdisk",
Jiyong Park153d3552021-02-04 08:54:31 +0900314 type: "compressed_cpio",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900315 symlinks: [
316 {
Inseob Kim67ab4362021-05-11 16:51:03 +0900317 target: "etc/fstab.microdroid",
Jiyong Park3eb11f72021-02-23 12:53:30 +0900318 name: "first_stage_ramdisk/fstab.microdroid",
319 },
320 {
321 target: "first_stage_ramdisk/lib",
322 name: "lib",
323 },
324 ],
325}
326
Jiyong Parkb810cfe2021-07-05 13:05:48 +0900327genrule {
328 name: "microdroid_bootconfig_arm64_gen",
329 srcs: [
330 "bootconfig.common",
331 "bootconfig.arm64",
332 ],
333 out: ["bootconfig"],
334 cmd: "cat $(in) > $(out)",
335}
336
337genrule {
338 name: "microdroid_bootconfig_x86_64_gen",
339 srcs: [
340 "bootconfig.common",
341 "bootconfig.x86_64",
342 ],
343 out: ["bootconfig"],
344 cmd: "cat $(in) > $(out)",
345}
346
Nikita Ioffef49350e2024-11-01 16:11:48 +0000347filegroup {
348 name: "microdroid_16k_bootconfig_x86_64_gen",
349 srcs: ["bootconfig.x86_64_16k"],
350}
351
Jiyong Park3eb11f72021-02-23 12:53:30 +0900352prebuilt_etc {
353 name: "microdroid_fstab",
Inseob Kim67ab4362021-05-11 16:51:03 +0900354 src: "fstab.microdroid",
355 filename: "fstab.microdroid",
Jiyong Park5f939f92024-05-01 16:18:14 +0900356 no_full_install: true,
Jiyong Park153d3552021-02-04 08:54:31 +0900357}
Jiyong Parkf677cfa2021-02-19 15:44:52 +0900358
Jooyung Han64214832022-04-21 14:30:04 +0900359// python -c "import hashlib; print(hashlib.sha256(b'bootloader').hexdigest())"
360bootloader_salt = "3b4a12881d11f33cff968a24d7c53723a8232cde9a8d91e29fdbd6a95ae6adf0"
361
Jooyung Hand35952e2021-11-08 17:53:47 +0900362filegroup {
363 name: "microdroid_sign_key",
Pierre-Clément Tosi2188d802024-05-24 10:56:26 +0100364 srcs: [":pvmfw_embedded_key"],
Jooyung Hand35952e2021-11-08 17:53:47 +0900365}
366
Inseob Kim7e0ba432024-07-26 11:15:31 +0900367vbmeta {
Jiyong Park80d8da82021-03-15 23:30:11 +0900368 name: "microdroid_vbmeta",
369 partition_name: "vbmeta",
Jooyung Hand35952e2021-11-08 17:53:47 +0900370 private_key: ":microdroid_sign_key",
Jiyong Park80d8da82021-03-15 23:30:11 +0900371 partitions: [
Jiyong Park80d8da82021-03-15 23:30:11 +0900372 "microdroid",
Inseob Kim7e0ba432024-07-26 11:15:31 +0900373 ] + select(release_flag("RELEASE_AVF_ENABLE_VENDOR_MODULES"), {
374 true: [],
375 default: ["microdroid_vendor"],
376 }),
Jiyong Park80d8da82021-03-15 23:30:11 +0900377}
Jooyung Han25a2acc2021-04-05 11:20:10 +0900378
379prebuilt_etc {
Jiyong Parke9b74d02021-06-21 14:39:12 +0900380 name: "microdroid.json",
381 src: "microdroid.json",
Jiyong Park78515012021-04-13 17:43:10 +0900382}
Jooyung Han017916b2021-04-20 03:57:19 +0900383
384prebuilt_etc {
Nikita Ioffef49350e2024-11-01 16:11:48 +0000385 name: "microdroid_16k.json",
386 src: "microdroid_16k.json",
387}
388
389prebuilt_etc {
Inseob Kim8f095c92021-05-26 12:04:54 +0900390 name: "microdroid_manifest",
391 src: "microdroid_manifest.xml",
392 filename: "manifest.xml",
393 relative_install_path: "vintf",
Jiyong Park5f939f92024-05-01 16:18:14 +0900394 no_full_install: true,
Inseob Kim8f095c92021-05-26 12:04:54 +0900395}
Oleg Matcovschi7b413a22022-03-18 01:51:58 -0700396
397prebuilt_etc {
398 name: "microdroid_event-log-tags",
399 src: "microdroid_event-log-tags",
400 filename: "event-log-tags",
Jiyong Park5f939f92024-05-01 16:18:14 +0900401 no_full_install: true,
Jooyung Hana704cbc2022-04-05 14:57:27 +0900402}
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000403
404filegroup {
Seungjae Yooe85831e2022-12-12 09:34:58 +0900405 name: "microdroid_bootconfig_debuggable_src",
406 srcs: ["bootconfig.debuggable"],
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000407}
408
409filegroup {
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000410 name: "microdroid_bootconfig_normal_src",
411 srcs: ["bootconfig.normal"],
412}
Shikha Panwared8ace42022-09-28 12:52:16 +0000413
Alice Wangc5c966d2023-01-04 10:44:07 +0000414// python -c "import hashlib; print(hashlib.sha256(b'initrd_normal').hexdigest())"
415initrd_normal_salt = "8041a07d54ac82290f6d90bac1fa8d7fdbc4db974d101d60faf294749d1ebaf8"
416
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900417avb_gen_vbmeta_image_defaults {
418 name: "microdroid_initrd_defaults",
Alice Wangc5c966d2023-01-04 10:44:07 +0000419 enabled: false,
420 arch: {
421 // Microdroid kernel is only available in these architectures.
422 arm64: {
423 enabled: true,
424 },
425 x86_64: {
426 enabled: true,
427 },
428 },
429}
430
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900431avb_gen_vbmeta_image_defaults {
432 name: "microdroid_initrd_normal_defaults",
433 defaults: ["microdroid_initrd_defaults"],
Inseob Kim77c7f712023-11-06 17:01:02 +0900434 partition_name: "initrd_normal",
435 salt: initrd_normal_salt,
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900436}
437
438avb_gen_vbmeta_image {
439 name: "microdroid_initrd_normal_hashdesc",
440 defaults: ["microdroid_initrd_normal_defaults"],
441 src: ":microdroid_initrd_normal",
Inseob Kim77c7f712023-11-06 17:01:02 +0900442}
443
Nikita Ioffef49350e2024-11-01 16:11:48 +0000444avb_gen_vbmeta_image {
445 name: "microdroid_16k_initrd_normal_hashdesc",
446 defaults: ["microdroid_initrd_normal_defaults"],
447 src: ":microdroid_16k_initrd_normal",
448}
449
Alice Wangc5c966d2023-01-04 10:44:07 +0000450// python -c "import hashlib; print(hashlib.sha256(b'initrd_debug').hexdigest())"
451initrd_debug_salt = "8ab9dc9cb7e6456700ff6ef18c6b4c3acc24c5fa5381b829563f8d7a415d869a"
452
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900453avb_gen_vbmeta_image_defaults {
454 name: "microdroid_initrd_debug_defaults",
455 defaults: ["microdroid_initrd_defaults"],
Alice Wangc41ebfb2023-01-11 09:06:32 +0000456 partition_name: "initrd_debug",
Alice Wangc5c966d2023-01-04 10:44:07 +0000457 salt: initrd_debug_salt,
Alice Wangc5c966d2023-01-04 10:44:07 +0000458}
459
Inseob Kim77c7f712023-11-06 17:01:02 +0900460avb_gen_vbmeta_image {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900461 name: "microdroid_initrd_debug_hashdesc",
462 defaults: ["microdroid_initrd_debug_defaults"],
463 src: ":microdroid_initrd_debuggable",
Inseob Kim77c7f712023-11-06 17:01:02 +0900464}
465
Nikita Ioffef49350e2024-11-01 16:11:48 +0000466avb_gen_vbmeta_image {
467 name: "microdroid_16k_initrd_debug_hashdesc",
468 defaults: ["microdroid_initrd_debug_defaults"],
469 src: ":microdroid_16k_initrd_debuggable",
470}
471
Shikha Panwar2a788662023-09-11 14:04:24 +0000472soong_config_module_type {
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900473 name: "flag_aware_avb_add_hash_footer_defaults",
474 module_type: "avb_add_hash_footer_defaults",
Shikha Panwar2a788662023-09-11 14:04:24 +0000475 config_namespace: "ANDROID",
476 bool_variables: [
477 "release_avf_enable_llpvm_changes",
478 ],
479 properties: [
480 "rollback_index",
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000481 "props",
Shikha Panwar2a788662023-09-11 14:04:24 +0000482 ],
483}
484
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900485flag_aware_avb_add_hash_footer_defaults {
486 name: "microdroid_kernel_signed_defaults",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100487 src: ":empty_file",
Alice Wang8aa3cb12023-01-11 09:04:04 +0000488 partition_name: "boot",
Shikha Panwared8ace42022-09-28 12:52:16 +0000489 private_key: ":microdroid_sign_key",
490 salt: bootloader_salt,
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000491 enabled: false,
492 arch: {
493 arm64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000494 enabled: true,
495 },
496 x86_64: {
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000497 enabled: true,
498 },
499 },
Shikha Panwar2a788662023-09-11 14:04:24 +0000500 // Below are properties that are conditionally set depending on value of build flags.
501 soong_config_variables: {
502 release_avf_enable_llpvm_changes: {
503 rollback_index: 1,
Shikha Panwar4a0651d2023-09-28 13:06:13 +0000504 props: [
505 {
506 name: "com.android.virt.cap",
507 value: "secretkeeper_protection",
508 },
509 ],
Shikha Panwar2a788662023-09-11 14:04:24 +0000510 },
511 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000512}
513
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900514avb_add_hash_footer {
515 name: "microdroid_kernel_signed",
516 defaults: ["microdroid_kernel_signed_defaults"],
517 filename: "microdroid_kernel",
Inseob Kim77c7f712023-11-06 17:01:02 +0900518 arch: {
519 arm64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000520 src: ":microdroid_kernel_prebuilt-arm64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900521 },
522 x86_64: {
Nikita Ioffea2af1e42024-02-14 18:13:47 +0000523 src: ":microdroid_kernel_prebuilt-x86_64",
Inseob Kim77c7f712023-11-06 17:01:02 +0900524 },
525 },
526 include_descriptors_from_images: [
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900527 ":microdroid_initrd_normal_hashdesc",
528 ":microdroid_initrd_debug_hashdesc",
Inseob Kim77c7f712023-11-06 17:01:02 +0900529 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900530}
531
Shikha Panwared8ace42022-09-28 12:52:16 +0000532prebuilt_etc {
533 name: "microdroid_kernel",
Pierre-Clément Tosi9d8e7382023-04-14 18:55:08 +0100534 src: ":empty_file",
Shikha Panwared8ace42022-09-28 12:52:16 +0000535 relative_install_path: "fs",
Shikha Panwar17fc23a2022-09-28 13:12:06 +0000536 arch: {
537 arm64: {
538 src: ":microdroid_kernel_signed",
539 },
540 x86_64: {
541 src: ":microdroid_kernel_signed",
542 },
543 },
Shikha Panwared8ace42022-09-28 12:52:16 +0000544}
Inseob Kim77c7f712023-11-06 17:01:02 +0900545
Nikita Ioffef49350e2024-11-01 16:11:48 +0000546avb_add_hash_footer {
547 name: "microdroid_kernel_16k_signed",
548 defaults: ["microdroid_kernel_signed_defaults"],
549 filename: "microdroid_kernel_16k",
550 arch: {
551 arm64: {
552 src: ":microdroid_kernel_16k_prebuilt-arm64",
553 },
554 // There is no 16k x86_64 kernel. Instead the 16k emulation is triggered by adding
555 // `page_shift=14` to the kernel cmdline or bootconfig.
556 x86_64: {
557 src: ":microdroid_kernel_prebuilt-x86_64",
558 },
559 },
560 include_descriptors_from_images: [
561 ":microdroid_16k_initrd_normal_hashdesc",
562 ":microdroid_16k_initrd_debug_hashdesc",
563 ],
564}
565
566prebuilt_etc {
567 name: "microdroid_kernel_16k",
568 src: ":empty_file",
569 relative_install_path: "fs",
570 arch: {
571 arm64: {
572 src: ":microdroid_kernel_16k_signed",
573 },
574 x86_64: {
575 src: ":microdroid_kernel_16k_signed",
576 },
577 },
578}
579
Inseob Kim7a1fc8f2023-11-22 18:45:28 +0900580///////////////////////////////////////
Nikita Ioffee4c38ab2024-07-02 11:40:48 +0000581// GKI-android15-6.6
582///////////////////////////////////////
583prebuilt_etc {
584 name: "microdroid_gki-android15-6.6.json",
585 src: "microdroid_gki-android15-6.6.json",
586}
587
588avb_add_hash_footer {
589 name: "microdroid_gki-android15-6.6_kernel_signed",
590 defaults: ["microdroid_kernel_signed_defaults"],
591 filename: "microdroid_gki-android15-6.6_kernel_signed",
592 arch: {
593 arm64: {
594 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-arm64",
595 },
596 x86_64: {
597 src: ":microdroid_gki_kernel_prebuilts-android15-6.6-x86_64",
598 },
599 },
600 include_descriptors_from_images: [
601 ":microdroid_gki-android15-6.6_initrd_normal_hashdesc",
602 ":microdroid_gki-android15-6.6_initrd_debug_hashdesc",
603 ],
604}
605
606// HACK: use cc_genrule for arch-specific properties
607cc_genrule {
608 name: "microdroid_gki-android15-6.6_kernel_signed-lz4",
609 out: ["microdroid_gki-android15-6.6_kernel_signed-lz4"],
610 srcs: [":empty_file"],
611 arch: {
612 arm64: {
613 srcs: [":microdroid_gki-android15-6.6_kernel_signed"],
614 exclude_srcs: [":empty_file"],
615 },
616 },
617 tools: ["lz4"],
618 cmd: "$(location lz4) -9 $(in) $(out)",
619}
620
621prebuilt_etc {
622 name: "microdroid_gki-android15-6.6_kernel",
623 filename: "microdroid_gki-android15-6.6_kernel",
624 src: ":empty_file",
625 relative_install_path: "fs",
626 arch: {
627 arm64: {
628 src: ":microdroid_gki-android15-6.6_kernel_signed",
629 },
630 x86_64: {
631 src: ":microdroid_gki-android15-6.6_kernel_signed",
632 },
633 },
634}
635
636avb_gen_vbmeta_image {
637 name: "microdroid_gki-android15-6.6_initrd_normal_hashdesc",
638 defaults: ["microdroid_initrd_normal_defaults"],
639 src: ":microdroid_gki-android15-6.6_initrd_normal",
640}
641
642avb_gen_vbmeta_image {
643 name: "microdroid_gki-android15-6.6_initrd_debug_hashdesc",
644 defaults: ["microdroid_initrd_debug_defaults"],
645 src: ":microdroid_gki-android15-6.6_initrd_debuggable",
646}
647
Alice Wang89cae4f2024-02-22 14:40:00 +0000648python_binary_host {
649 name: "extract_microdroid_kernel_hashes",
650 srcs: ["extract_microdroid_kernel_hashes.py"],
651}
652
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900653// HACK: use cc_genrule for arch-specific properties
654cc_genrule {
Alice Wang89cae4f2024-02-22 14:40:00 +0000655 name: "microdroid_kernel_hashes_rs",
Cole Faust2b944092024-10-23 16:37:21 -0700656 compile_multilib: "first",
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",
Cole Faust2b944092024-10-23 16:37:21 -0700681 compile_multilib: "first",
Alice Wang89cae4f2024-02-22 14:40:00 +0000682 srcs: [":microdroid_kernel_hashes_rs"],
683 crate_name: "microdroid_kernel_hashes",
684 prefer_rlib: true,
685 no_stdlibs: true,
686 stdlibs: [
687 "libcompiler_builtins.rust_sysroot",
688 "libcore.rust_sysroot",
689 ],
690}