blob: 00defbee25ca00600a032a22c36f70fb192cc3f4 [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
Cole Faust5fb8d862024-08-23 16:10:00 -070010soong_config_module_type {
11 name: "virt_apex",
12 module_type: "apex",
13 config_namespace: "ANDROID",
14 bool_variables: [
15 "avf_enabled",
16 ],
17 properties: [
18 "defaults",
19 ],
20}
21
22virt_apex {
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010023 name: "com.android.virt",
Cole Faust5fb8d862024-08-23 16:10:00 -070024 soong_config_variables: {
25 avf_enabled: {
26 defaults: ["com.android.virt_avf_enabled"],
27 conditions_default: {
28 defaults: ["com.android.virt_avf_disabled"],
29 },
30 },
31 },
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010032}
33
Inseob Kimc2a710d2024-07-23 16:14:14 +090034apex_defaults {
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010035 name: "com.android.virt_common",
Jiyong Parkda119cb2020-12-07 15:58:23 +090036 // TODO(jiyong): make it updatable
Mathew Inwood9af36dd2021-02-16 14:43:40 +000037 updatable: false,
Nikita Ioffec0b09612023-01-27 01:49:39 +000038 future_updatable: false,
Jiyong Parkb6c45e72021-06-22 20:24:56 +090039 platform_apis: true,
Jiyong Parkda119cb2020-12-07 15:58:23 +090040
41 manifest: "manifest.json",
42
43 key: "com.android.virt.key",
44 certificate: ":com.android.virt.certificate",
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010045
46 apps: [
47 "android.system.virtualmachine.res",
Jiyong Park27f460c2024-11-01 10:39:25 +090048 ],
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010049
50 file_contexts: ":com.android.virt-file_contexts",
Nikita Ioffef28eec22022-10-18 23:17:34 +010051
52 bootclasspath_fragments: [
53 "com.android.virt-bootclasspath-fragment",
54 ],
Nikita Ioffeb78c6202022-11-18 17:01:36 +000055 jni_libs: [
David Brazdil79588392022-10-20 17:04:46 +010056 "libvirtualizationservice_jni",
Nikita Ioffeb78c6202022-11-18 17:01:36 +000057 "libvirtualmachine_jni",
58 ],
Jooyung Han3b980eb2023-11-03 14:48:00 +090059 // TODO(b/295593640) Unfortunately these are added to the apex even though they are unused.
60 // Once the build system is fixed, remove this.
61 unwanted_transitive_deps: [
Jooyung Han3b980eb2023-11-03 14:48:00 +090062 "libsso",
63 "libutils",
64 ],
Inseob Kimc2a710d2024-07-23 16:14:14 +090065
66 systemserverclasspath_fragments: select(release_flag("RELEASE_AVF_ENABLE_LLPVM_CHANGES"), {
67 true: ["com.android.virt-systemserver-fragment"],
68 default: [],
69 }),
70
71 canned_fs_config: select(release_flag("RELEASE_AVF_ENABLE_VIRT_CPUFREQ"), {
72 true: "canned_fs_config_sys_nice",
73 default: "canned_fs_config",
74 }),
Inseob Kim77c7f712023-11-06 17:01:02 +090075}
76
Kiyoung Kim0e359fb2024-10-11 17:06:20 +090077vintf_fragment {
78 name: "virtualizationservice.xml",
79 src: "virtualizationservice.xml",
80}
81
Inseob Kimc2a710d2024-07-23 16:14:14 +090082apex_defaults {
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010083 name: "com.android.virt_avf_enabled",
84
85 defaults: ["com.android.virt_common"],
86
Jooyung Han05063d12021-10-27 01:50:51 +090087 custom_sign_tool: "sign_virt_apex",
Jiyong Parkda119cb2020-12-07 15:58:23 +090088
Andrew Walbrandfc953d2021-06-10 13:59:56 +000089 // crosvm and virtualizationservice are only enabled for 64-bit targets on device
Jiyong Park2199f202020-12-07 15:58:47 +090090 arch: {
91 arm64: {
92 binaries: [
Jiyong Park69b39372021-01-05 23:14:46 +090093 "crosvm",
David Brazdil1f530702022-10-03 12:18:10 +010094 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +000095 "virtualizationservice",
Inseob Kimc2a710d2024-07-23 16:14:14 +090096 ] + select(release_flag("RELEASE_AVF_ENABLE_DEVICE_ASSIGNMENT"), {
97 true: ["vfio_handler"],
98 default: [],
99 }) + select(release_flag("RELEASE_AVF_ENABLE_NETWORK"), {
100 true: ["vmnic"],
101 default: [],
Inseob Kim7c7d4522024-08-01 23:46:39 +0900102 }) + select(release_flag("RELEASE_AVF_ENABLE_EARLY_VM"), {
103 true: ["early_virtmgr"],
104 default: [],
Inseob Kimc2a710d2024-07-23 16:14:14 +0900105 }),
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800106 filesystems: microdroid_filesystem_images,
Alice Wangbe8330c2023-10-19 08:55:07 +0000107 prebuilts: [
108 "rialto_bin",
maciek swiechbc533882024-09-11 19:27:59 +0000109 "android_bootloader_crosvm_aarch64",
Alice Wangbe8330c2023-10-19 08:55:07 +0000110 ],
Inseob Kimf3536de2024-11-22 14:00:57 +0900111 native_shared_libs: ["libavf"],
Jiyong Park69b39372021-01-05 23:14:46 +0900112 },
113 x86_64: {
114 binaries: [
Jiyong Park2199f202020-12-07 15:58:47 +0900115 "crosvm",
David Brazdil1f530702022-10-03 12:18:10 +0100116 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +0000117 "virtualizationservice",
Inseob Kimc2a710d2024-07-23 16:14:14 +0900118 ] + select(release_flag("RELEASE_AVF_ENABLE_DEVICE_ASSIGNMENT"), {
119 true: ["vfio_handler"],
120 default: [],
121 }) + select(release_flag("RELEASE_AVF_ENABLE_NETWORK"), {
122 true: ["vmnic"],
123 default: [],
Inseob Kim7c7d4522024-08-01 23:46:39 +0900124 }) + select(release_flag("RELEASE_AVF_ENABLE_EARLY_VM"), {
125 true: ["early_virtmgr"],
126 default: [],
Inseob Kimc2a710d2024-07-23 16:14:14 +0900127 }),
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800128 filesystems: microdroid_filesystem_images,
maciek swiechbc533882024-09-11 19:27:59 +0000129 prebuilts: [
130 "android_bootloader_crosvm_x86_64",
131 ],
Inseob Kimf3536de2024-11-22 14:00:57 +0900132 native_shared_libs: ["libavf"],
Jiyong Park2199f202020-12-07 15:58:47 +0900133 },
134 },
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900135 binaries: [
Victor Hsieh573c6492021-03-11 14:19:18 -0800136 "fd_server",
Andrew Walbranea9fa482021-03-04 16:11:12 +0000137 "vm",
Inseob Kim7c7d4522024-08-01 23:46:39 +0900138 ],
Inseob Kim72f06a32021-04-12 14:48:42 +0900139 prebuilts: [
Seungjae Yooe85831e2022-12-12 09:34:58 +0900140 "microdroid_initrd_debuggable",
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000141 "microdroid_initrd_normal",
Jiyong Parke9b74d02021-06-21 14:39:12 +0900142 "microdroid.json",
Shikha Panwared8ace42022-09-28 12:52:16 +0000143 "microdroid_kernel",
Alan Stokes1d2d4152024-02-21 10:49:55 +0000144 "com.android.virt.init.rc",
Inseob Kimc2a710d2024-07-23 16:14:14 +0900145 ] + select(soong_config_variable("ANDROID", "avf_microdroid_guest_gki_version"), {
146 "android15_66": [
147 "microdroid_gki-android15-6.6_initrd_debuggable",
148 "microdroid_gki-android15-6.6_initrd_normal",
149 "microdroid_gki-android15-6.6_kernel",
150 "microdroid_gki-android15-6.6.json",
151 ],
Nikita Ioffe6d65f242024-09-25 21:27:12 +0000152 // Internal option used by pkvm team while developing new features.
153 // Should not be used on production kernels.
154 "pkvm_experimental": [
155 "microdroid_gki-pkvm_experimental_initrd_debuggable",
156 "microdroid_gki-pkvm_experimental_initrd_normal",
157 "microdroid_gki-pkvm_experimental_kernel",
158 "microdroid_gki-pkvm_experimental.json",
159 ],
Inseob Kimc2a710d2024-07-23 16:14:14 +0900160 default: [],
161 }) + select(release_flag("RELEASE_AVF_ENABLE_DEVICE_ASSIGNMENT"), {
162 true: ["com.android.virt.vfio_handler.rc"],
163 default: [],
164 }) + select(release_flag("RELEASE_AVF_ENABLE_NETWORK"), {
165 true: ["com.android.virt.vmnic.rc"],
166 default: [],
Nikita Ioffef49350e2024-11-01 16:11:48 +0000167 }) + select(soong_config_variable("ANDROID", "target_boots_16k"), {
168 true: [
169 "microdroid_16k_initrd_debuggable",
170 "microdroid_16k_initrd_normal",
171 "microdroid_kernel_16k",
172 "microdroid_16k.json",
173 ],
174 default: [],
Inseob Kimc2a710d2024-07-23 16:14:14 +0900175 }),
Jiyong Park17e3ed42022-08-29 17:27:00 +0900176 host_required: [
177 "vm_shell",
178 ],
Nikita Ioffeb0b67562022-11-22 15:48:06 +0000179 apps: [
180 "EmptyPayloadApp",
Jiyong Park27f460c2024-11-01 10:39:25 +0900181 ] + select(release_flag("RELEASE_AVF_SUPPORT_CUSTOM_VM_WITH_PARAVIRTUALIZED_DEVICES"), {
182 true: [
183 "VmTerminalApp",
184 ],
185 default: [],
186 }),
Inseob Kimc2a710d2024-07-23 16:14:14 +0900187 androidManifest: select(release_flag("RELEASE_AVF_ENABLE_LLPVM_CHANGES"), {
188 true: "AndroidManifest.xml",
189 default: unset,
190 }),
Kiyoung Kim0e359fb2024-10-11 17:06:20 +0900191 vintf_fragment_modules: select(soong_config_variable("ANDROID", "avf_remote_attestation_enabled"), {
Inseob Kimc2a710d2024-07-23 16:14:14 +0900192 "true": ["virtualizationservice.xml"],
193 default: unset,
194 }),
Jiyong Parkda119cb2020-12-07 15:58:23 +0900195}
196
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +0100197apex_defaults {
198 name: "com.android.virt_avf_disabled",
199
200 defaults: ["com.android.virt_common"],
201}
202
Jiyong Parkda119cb2020-12-07 15:58:23 +0900203apex_key {
204 name: "com.android.virt.key",
205 public_key: "com.android.virt.avbpubkey",
206 private_key: "com.android.virt.pem",
207}
208
209android_app_certificate {
210 name: "com.android.virt.certificate",
211 certificate: "com.android.virt",
212}
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100213
Inseob Kimc2a710d2024-07-23 16:14:14 +0900214genrule {
Alan Stokes1d2d4152024-02-21 10:49:55 +0000215 name: "virtualizationservice_rc_combined",
Inseob Kimc2a710d2024-07-23 16:14:14 +0900216 srcs: [
217 "virtualizationservice.rc.base",
218 ] + select(release_flag("RELEASE_AVF_ENABLE_LLPVM_CHANGES"), {
219 true: ["virtualizationservice.rc.llpvm"],
220 default: [],
221 }) + select(soong_config_variable("ANDROID", "avf_remote_attestation_enabled"), {
222 "true": ["virtualizationservice.rc.ra"],
223 default: [],
224 }),
Alan Stokes1d2d4152024-02-21 10:49:55 +0000225 out: ["virtualizationservice.rc"],
226 cmd: "cat $(in) > $(out)",
Alice Wangb5b90322023-11-14 07:38:18 +0000227}
228
229prebuilt_etc {
Alan Stokes1d2d4152024-02-21 10:49:55 +0000230 name: "com.android.virt.init.rc",
231 src: ":virtualizationservice_rc_combined",
Alice Wangb5b90322023-11-14 07:38:18 +0000232 filename: "virtualizationservice.rc",
Seungjae Yoo13af0b62024-05-20 14:15:13 +0900233 no_full_install: true,
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100234}
Jooyung Han504105f2021-10-26 15:54:50 +0900235
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000236prebuilt_etc {
237 name: "com.android.virt.vfio_handler.rc",
238 src: "vfio_handler.rc",
239 filename: "vfio_handler.rc",
Seungjae Yoo13af0b62024-05-20 14:15:13 +0900240 no_full_install: true,
241}
242
243prebuilt_etc {
244 name: "com.android.virt.vmnic.rc",
245 src: "vmnic.rc",
246 filename: "vmnic.rc",
247 no_full_install: true,
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000248}
249
Jooyung Han504105f2021-10-26 15:54:50 +0900250// Virt apex needs a custom signer for its payload
251python_binary_host {
252 name: "sign_virt_apex",
253 srcs: [
254 "sign_virt_apex.py",
255 ],
256 version: {
Jooyung Han504105f2021-10-26 15:54:50 +0900257 py3: {
Jooyung Han504105f2021-10-26 15:54:50 +0900258 embedded_launcher: true,
259 },
260 },
Jooyung Han05063d12021-10-27 01:50:51 +0900261 required: [
Shikha Panwara7605cf2023-01-12 09:29:39 +0000262 // sign_virt_apex should be runnable from outside the source tree,
263 // therefore, any required tool should be listed in build/make/core/Makefile as well.
Jooyung Han05063d12021-10-27 01:50:51 +0900264 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000265 "initrd_bootconfig",
Jooyung Han05063d12021-10-27 01:50:51 +0900266 "lpmake",
267 "lpunpack",
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900268 "lz4",
Jooyung Han05063d12021-10-27 01:50:51 +0900269 "simg2img",
270 ],
Jooyung Han504105f2021-10-26 15:54:50 +0900271}
Jooyung Hand35952e2021-11-08 17:53:47 +0900272
Jooyung Han02dceed2021-11-08 17:50:22 +0900273sh_test_host {
274 name: "sign_virt_apex_test",
275 src: "sign_virt_apex_test.sh",
276 test_config: "sign_virt_apex_test.xml",
277 data_bins: [
278 // deapexer
279 "deapexer",
280 "debugfs_static",
Dennis Shen28c79442022-11-08 14:26:13 +0000281 "fsck.erofs",
Jooyung Han02dceed2021-11-08 17:50:22 +0900282
283 // sign_virt_apex
284 "avbtool",
285 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000286 "initrd_bootconfig",
Jooyung Han02dceed2021-11-08 17:50:22 +0900287 "lpmake",
288 "lpunpack",
Inseob Kim2e2f48a2024-02-21 22:56:08 +0900289 "lz4",
Jooyung Han02dceed2021-11-08 17:50:22 +0900290 "sign_virt_apex",
291 "simg2img",
292 ],
293 data_libs: [
294 "libbase",
295 "libc++",
296 "libcrypto_utils",
297 "libcrypto",
298 "libext4_utils",
299 "liblog",
300 "liblp",
301 "libsparse",
302 "libz",
303 ],
304 data: [
Jooyung Han6afd6672022-02-22 05:22:23 +0900305 ":test.com.android.virt.pem",
Jooyung Han02dceed2021-11-08 17:50:22 +0900306 ],
Cole Faust316e6422024-10-22 16:31:03 -0700307 device_common_data: [
308 ":com.android.virt",
309 ],
Jooyung Han02dceed2021-11-08 17:50:22 +0900310 test_suites: ["general-tests"],
311}
312
Jooyung Han6afd6672022-02-22 05:22:23 +0900313filegroup {
314 name: "test.com.android.virt.pem",
315 srcs: ["test.com.android.virt.pem"],
316}
317
Jooyung Han1c3d2fa2022-02-24 02:35:59 +0900318filegroup {
319 name: "test2.com.android.virt.pem",
320 srcs: ["test2.com.android.virt.pem"],
321}
322
Jooyung Hand35952e2021-11-08 17:53:47 +0900323// custom tool to replace bytes in a file
324python_binary_host {
325 name: "replace_bytes",
326 srcs: [
327 "replace_bytes.py",
328 ],
329 version: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900330 py3: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900331 embedded_launcher: true,
332 },
333 },
334}
Nikita Ioffef28eec22022-10-18 23:17:34 +0100335
336// Encapsulate the contributions made by the com.android.virt to the bootclasspath.
337bootclasspath_fragment {
338 name: "com.android.virt-bootclasspath-fragment",
339 contents: ["framework-virtualization"],
340 apex_available: ["com.android.virt"],
341
342 // The bootclasspath_fragments that provide APIs on which this depends.
343 fragments: [
344 {
345 apex: "com.android.art",
346 module: "art-bootclasspath-fragment",
347 },
348 ],
349
350 // Additional stubs libraries that this fragment's contents use which are
351 // not provided by another bootclasspath_fragment.
352 additional_stubs: [
353 "android-non-updatable",
354 ],
355
356 hidden_api: {
357
358 // This module does not contain any split packages.
359 split_packages: [],
360
361 // The following packages and all their subpackages currently only
362 // contain classes from this bootclasspath_fragment. Listing a package
363 // here won't prevent other bootclasspath modules from adding classes in
364 // any of those packages but it will prevent them from adding those
365 // classes into an API surface, e.g. public, system, etc.. Doing so will
366 // result in a build failure due to inconsistent flags.
367 package_prefixes: [
368 "android.system.virtualmachine",
369 "android.system.virtualizationservice",
370 // android.sysprop.*, renamed by jarjar
371 "com.android.system.virtualmachine.sysprop",
372 ],
373 },
374}
Nikita Ioffead4c7192024-02-02 13:07:00 +0000375
Inseob Kimc2a710d2024-07-23 16:14:14 +0900376systemserverclasspath_fragment {
Nikita Ioffead4c7192024-02-02 13:07:00 +0000377 name: "com.android.virt-systemserver-fragment",
378 contents: [
379 "service-virtualization",
380 ],
381 apex_available: ["com.android.virt"],
Inseob Kimc2a710d2024-07-23 16:14:14 +0900382 enabled: select(release_flag("RELEASE_AVF_ENABLE_LLPVM_CHANGES"), {
383 true: true,
384 default: false,
385 }),
Nikita Ioffead4c7192024-02-02 13:07:00 +0000386}