blob: f2badfa30d7687e8d9eefc0dd72a6fcfa8590ec5 [file] [log] [blame]
Bob Badour2efc4762021-02-03 18:36:27 -08001package {
2 default_applicable_licenses: ["Android-Apache-2.0"],
3}
4
Victor Hsieh384bf6a2021-11-11 13:28:09 -08005microdroid_filesystem_images = [
Andrew Sculld6267ae2022-06-13 13:47:59 +00006 "microdroid_super",
Victor Hsieh384bf6a2021-11-11 13:28:09 -08007 "microdroid_vbmeta",
Victor Hsieh384bf6a2021-11-11 13:28:09 -08008]
9
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010010soong_config_module_type {
11 name: "virt_apex",
12 module_type: "apex",
13 config_namespace: "ANDROID",
Nikita Ioffeadb33932023-06-07 14:33:56 +010014 bool_variables: [
15 "avf_enabled",
Nikita Ioffeadb33932023-06-07 14:33:56 +010016 ],
17 properties: [
18 "defaults",
19 "prebuilts",
20 ],
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010021}
Jiyong Parkda119cb2020-12-07 15:58:23 +090022
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010023virt_apex {
24 name: "com.android.virt",
25 soong_config_variables: {
26 avf_enabled: {
27 defaults: ["com.android.virt_avf_enabled"],
28 conditions_default: {
29 defaults: ["com.android.virt_avf_disabled"],
30 },
31 },
32 },
33}
34
Nikita Ioffead4c7192024-02-02 13:07:00 +000035soong_config_module_type {
36 name: "avf_flag_aware_apex_defaults",
37 module_type: "apex_defaults",
38 config_namespace: "ANDROID",
39 bool_variables: [
40 "release_avf_enable_device_assignment",
41 "release_avf_enable_llpvm_changes",
42 "release_avf_enable_remote_attestation",
43 "release_avf_enable_vendor_modules",
David Dai351b9cf2024-02-14 18:42:09 -080044 "release_avf_enable_virt_cpufreq",
Nikita Ioffead4c7192024-02-02 13:07:00 +000045 ],
46 properties: [
47 "androidManifest",
48 "arch",
David Dai351b9cf2024-02-14 18:42:09 -080049 "canned_fs_config",
Nikita Ioffead4c7192024-02-02 13:07:00 +000050 "prebuilts",
51 "systemserverclasspath_fragments",
52 "vintf_fragments",
53 ],
54}
55
56avf_flag_aware_apex_defaults {
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010057 name: "com.android.virt_common",
Jiyong Parkda119cb2020-12-07 15:58:23 +090058 // TODO(jiyong): make it updatable
Mathew Inwood9af36dd2021-02-16 14:43:40 +000059 updatable: false,
Nikita Ioffec0b09612023-01-27 01:49:39 +000060 future_updatable: false,
Jiyong Parkb6c45e72021-06-22 20:24:56 +090061 platform_apis: true,
Jiyong Parkda119cb2020-12-07 15:58:23 +090062
63 manifest: "manifest.json",
64
65 key: "com.android.virt.key",
66 certificate: ":com.android.virt.certificate",
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010067
68 apps: [
69 "android.system.virtualmachine.res",
70 ],
71
72 file_contexts: ":com.android.virt-file_contexts",
Nikita Ioffef28eec22022-10-18 23:17:34 +010073
74 bootclasspath_fragments: [
75 "com.android.virt-bootclasspath-fragment",
76 ],
Nikita Ioffeb78c6202022-11-18 17:01:36 +000077 jni_libs: [
David Brazdil79588392022-10-20 17:04:46 +010078 "libvirtualizationservice_jni",
Nikita Ioffeb78c6202022-11-18 17:01:36 +000079 "libvirtualmachine_jni",
80 ],
Jooyung Han3b980eb2023-11-03 14:48:00 +090081 // TODO(b/295593640) Unfortunately these are added to the apex even though they are unused.
82 // Once the build system is fixed, remove this.
83 unwanted_transitive_deps: [
84 "libdrm",
85 "libsso",
86 "libutils",
87 ],
Nikita Ioffead4c7192024-02-02 13:07:00 +000088 soong_config_variables: {
89 release_avf_enable_llpvm_changes: {
90 systemserverclasspath_fragments: [
91 "com.android.virt-systemserver-fragment",
92 ],
93 },
David Dai351b9cf2024-02-14 18:42:09 -080094 release_avf_enable_virt_cpufreq: {
95 canned_fs_config: "canned_fs_config_sys_nice",
96 conditions_default: {
97 canned_fs_config: "canned_fs_config",
98 },
99 },
Nikita Ioffead4c7192024-02-02 13:07:00 +0000100 },
Inseob Kim77c7f712023-11-06 17:01:02 +0900101}
102
103avf_flag_aware_apex_defaults {
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +0100104 name: "com.android.virt_avf_enabled",
105
106 defaults: ["com.android.virt_common"],
107
Jooyung Han05063d12021-10-27 01:50:51 +0900108 custom_sign_tool: "sign_virt_apex",
Jiyong Parkda119cb2020-12-07 15:58:23 +0900109
Andrew Walbrandfc953d2021-06-10 13:59:56 +0000110 // crosvm and virtualizationservice are only enabled for 64-bit targets on device
Jiyong Park2199f202020-12-07 15:58:47 +0900111 arch: {
112 arm64: {
113 binaries: [
Jiyong Park69b39372021-01-05 23:14:46 +0900114 "crosvm",
David Brazdil1f530702022-10-03 12:18:10 +0100115 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +0000116 "virtualizationservice",
Jiyong Park69b39372021-01-05 23:14:46 +0900117 ],
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800118 filesystems: microdroid_filesystem_images,
Alice Wangbe8330c2023-10-19 08:55:07 +0000119 prebuilts: [
120 "rialto_bin",
121 ],
Jiyong Park69b39372021-01-05 23:14:46 +0900122 },
123 x86_64: {
124 binaries: [
Jiyong Park2199f202020-12-07 15:58:47 +0900125 "crosvm",
David Brazdil1f530702022-10-03 12:18:10 +0100126 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +0000127 "virtualizationservice",
Jiyong Park2199f202020-12-07 15:58:47 +0900128 ],
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800129 filesystems: microdroid_filesystem_images,
Jiyong Park2199f202020-12-07 15:58:47 +0900130 },
131 },
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900132 binaries: [
Victor Hsieh573c6492021-03-11 14:19:18 -0800133 "fd_server",
Andrew Walbranea9fa482021-03-04 16:11:12 +0000134 "vm",
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900135 ],
Inseob Kim72f06a32021-04-12 14:48:42 +0900136 prebuilts: [
Nikita Ioffeab1754c2022-10-13 20:28:54 +0100137 "features_com.android.virt.xml",
Seungjae Yooe85831e2022-12-12 09:34:58 +0900138 "microdroid_initrd_debuggable",
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000139 "microdroid_initrd_normal",
Jiyong Parke9b74d02021-06-21 14:39:12 +0900140 "microdroid.json",
Shikha Panwared8ace42022-09-28 12:52:16 +0000141 "microdroid_kernel",
Alan Stokes1d2d4152024-02-21 10:49:55 +0000142 "com.android.virt.init.rc",
Inseob Kim72f06a32021-04-12 14:48:42 +0900143 ],
Jiyong Park17e3ed42022-08-29 17:27:00 +0900144 host_required: [
145 "vm_shell",
146 ],
Nikita Ioffeb0b67562022-11-22 15:48:06 +0000147 apps: [
148 "EmptyPayloadApp",
149 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900150 soong_config_variables: {
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000151 release_avf_enable_device_assignment: {
152 prebuilts: [
153 "com.android.virt.vfio_handler.rc",
154 ],
155 arch: {
156 arm64: {
157 binaries: ["vfio_handler"],
158 },
159 x86_64: {
160 binaries: ["vfio_handler"],
161 },
162 },
163 },
Nikita Ioffead4c7192024-02-02 13:07:00 +0000164 release_avf_enable_llpvm_changes: {
165 androidManifest: "AndroidManifest.xml",
166 },
Inseob Kim77c7f712023-11-06 17:01:02 +0900167 release_avf_enable_vendor_modules: {
168 prebuilts: [
Inseob Kim0276f612023-12-07 17:25:18 +0900169 "microdroid_gki-android14-6.1_initrd_debuggable",
170 "microdroid_gki-android14-6.1_initrd_normal",
171 "microdroid_gki-android14-6.1_kernel",
172 "microdroid_gki-android14-6.1.json",
Inseob Kim77c7f712023-11-06 17:01:02 +0900173 ],
174 },
Alice Wangb5b90322023-11-14 07:38:18 +0000175 release_avf_enable_remote_attestation: {
Alice Wangb5b90322023-11-14 07:38:18 +0000176 vintf_fragments: [
177 "virtualizationservice.xml",
178 ],
Alice Wangb5b90322023-11-14 07:38:18 +0000179 },
Inseob Kim77c7f712023-11-06 17:01:02 +0900180 },
Jiyong Parkda119cb2020-12-07 15:58:23 +0900181}
182
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +0100183apex_defaults {
184 name: "com.android.virt_avf_disabled",
185
186 defaults: ["com.android.virt_common"],
187}
188
Jiyong Parkda119cb2020-12-07 15:58:23 +0900189apex_key {
190 name: "com.android.virt.key",
191 public_key: "com.android.virt.avbpubkey",
192 private_key: "com.android.virt.pem",
193}
194
195android_app_certificate {
196 name: "com.android.virt.certificate",
197 certificate: "com.android.virt",
198}
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100199
Alan Stokes1d2d4152024-02-21 10:49:55 +0000200soong_config_module_type {
201 name: "avf_flag_aware_genrule",
202 module_type: "genrule",
203 config_namespace: "ANDROID",
204 bool_variables: [
205 "release_avf_enable_llpvm_changes",
206 "release_avf_enable_remote_attestation",
207 ],
208 properties: ["srcs"],
209}
210
211avf_flag_aware_genrule {
212 name: "virtualizationservice_rc_combined",
213 srcs: ["virtualizationservice.rc.base"],
214 soong_config_variables: {
215 release_avf_enable_llpvm_changes: {
216 srcs: ["virtualizationservice.rc.llpvm"],
217 },
218 release_avf_enable_remote_attestation: {
219 srcs: ["virtualizationservice.rc.ra"],
220 },
221 },
222 out: ["virtualizationservice.rc"],
223 cmd: "cat $(in) > $(out)",
Alice Wangb5b90322023-11-14 07:38:18 +0000224}
225
226prebuilt_etc {
Alan Stokes1d2d4152024-02-21 10:49:55 +0000227 name: "com.android.virt.init.rc",
228 src: ":virtualizationservice_rc_combined",
Alice Wangb5b90322023-11-14 07:38:18 +0000229 filename: "virtualizationservice.rc",
Alan Stokes3ef78d92021-09-08 11:51:06 +0100230 installable: false,
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100231}
Jooyung Han504105f2021-10-26 15:54:50 +0900232
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000233prebuilt_etc {
234 name: "com.android.virt.vfio_handler.rc",
235 src: "vfio_handler.rc",
236 filename: "vfio_handler.rc",
237 installable: false,
238}
239
Jooyung Han504105f2021-10-26 15:54:50 +0900240// Virt apex needs a custom signer for its payload
241python_binary_host {
242 name: "sign_virt_apex",
243 srcs: [
244 "sign_virt_apex.py",
245 ],
246 version: {
Jooyung Han504105f2021-10-26 15:54:50 +0900247 py3: {
Jooyung Han504105f2021-10-26 15:54:50 +0900248 embedded_launcher: true,
249 },
250 },
Jooyung Han05063d12021-10-27 01:50:51 +0900251 required: [
Shikha Panwara7605cf2023-01-12 09:29:39 +0000252 // sign_virt_apex should be runnable from outside the source tree,
253 // therefore, any required tool should be listed in build/make/core/Makefile as well.
Jooyung Han05063d12021-10-27 01:50:51 +0900254 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000255 "initrd_bootconfig",
Jooyung Han05063d12021-10-27 01:50:51 +0900256 "lpmake",
257 "lpunpack",
258 "simg2img",
259 ],
Jooyung Han504105f2021-10-26 15:54:50 +0900260}
Jooyung Hand35952e2021-11-08 17:53:47 +0900261
Jooyung Han02dceed2021-11-08 17:50:22 +0900262sh_test_host {
263 name: "sign_virt_apex_test",
264 src: "sign_virt_apex_test.sh",
265 test_config: "sign_virt_apex_test.xml",
266 data_bins: [
267 // deapexer
268 "deapexer",
269 "debugfs_static",
Dennis Shen28c79442022-11-08 14:26:13 +0000270 "fsck.erofs",
Jooyung Han02dceed2021-11-08 17:50:22 +0900271
272 // sign_virt_apex
273 "avbtool",
274 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000275 "initrd_bootconfig",
Jooyung Han02dceed2021-11-08 17:50:22 +0900276 "lpmake",
277 "lpunpack",
278 "sign_virt_apex",
279 "simg2img",
280 ],
281 data_libs: [
282 "libbase",
283 "libc++",
284 "libcrypto_utils",
285 "libcrypto",
286 "libext4_utils",
287 "liblog",
288 "liblp",
289 "libsparse",
290 "libz",
291 ],
292 data: [
293 ":com.android.virt",
Jooyung Han6afd6672022-02-22 05:22:23 +0900294 ":test.com.android.virt.pem",
Jooyung Han02dceed2021-11-08 17:50:22 +0900295 ],
296 test_suites: ["general-tests"],
297}
298
Jooyung Han6afd6672022-02-22 05:22:23 +0900299filegroup {
300 name: "test.com.android.virt.pem",
301 srcs: ["test.com.android.virt.pem"],
302}
303
Jooyung Han1c3d2fa2022-02-24 02:35:59 +0900304filegroup {
305 name: "test2.com.android.virt.pem",
306 srcs: ["test2.com.android.virt.pem"],
307}
308
Jooyung Hand35952e2021-11-08 17:53:47 +0900309// custom tool to replace bytes in a file
310python_binary_host {
311 name: "replace_bytes",
312 srcs: [
313 "replace_bytes.py",
314 ],
315 version: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900316 py3: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900317 embedded_launcher: true,
318 },
319 },
320}
Nikita Ioffef28eec22022-10-18 23:17:34 +0100321
322// Encapsulate the contributions made by the com.android.virt to the bootclasspath.
323bootclasspath_fragment {
324 name: "com.android.virt-bootclasspath-fragment",
325 contents: ["framework-virtualization"],
326 apex_available: ["com.android.virt"],
327
328 // The bootclasspath_fragments that provide APIs on which this depends.
329 fragments: [
330 {
331 apex: "com.android.art",
332 module: "art-bootclasspath-fragment",
333 },
334 ],
335
336 // Additional stubs libraries that this fragment's contents use which are
337 // not provided by another bootclasspath_fragment.
338 additional_stubs: [
339 "android-non-updatable",
340 ],
341
342 hidden_api: {
343
344 // This module does not contain any split packages.
345 split_packages: [],
346
347 // The following packages and all their subpackages currently only
348 // contain classes from this bootclasspath_fragment. Listing a package
349 // here won't prevent other bootclasspath modules from adding classes in
350 // any of those packages but it will prevent them from adding those
351 // classes into an API surface, e.g. public, system, etc.. Doing so will
352 // result in a build failure due to inconsistent flags.
353 package_prefixes: [
354 "android.system.virtualmachine",
355 "android.system.virtualizationservice",
356 // android.sysprop.*, renamed by jarjar
357 "com.android.system.virtualmachine.sysprop",
358 ],
359 },
360}
Nikita Ioffead4c7192024-02-02 13:07:00 +0000361
362soong_config_module_type {
363 name: "avf_flag_aware_systemserverclasspath_fragment",
364 module_type: "systemserverclasspath_fragment",
365 config_namespace: "ANDROID",
366 bool_variables: [
367 "release_avf_enable_llpvm_changes",
368 ],
369 properties: [
370 "enabled",
371 ],
372}
373
374avf_flag_aware_systemserverclasspath_fragment {
375 name: "com.android.virt-systemserver-fragment",
376 contents: [
377 "service-virtualization",
378 ],
379 apex_available: ["com.android.virt"],
380 enabled: false,
381 soong_config_variables: {
382 release_avf_enable_llpvm_changes: {
383 enabled: true,
384 },
385 },
386}