blob: 7983181fe62100f236a13da976de094bec99ade0 [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
35apex_defaults {
36 name: "com.android.virt_common",
Jiyong Parkda119cb2020-12-07 15:58:23 +090037 // TODO(jiyong): make it updatable
Mathew Inwood9af36dd2021-02-16 14:43:40 +000038 updatable: false,
Nikita Ioffec0b09612023-01-27 01:49:39 +000039 future_updatable: false,
Jiyong Parkb6c45e72021-06-22 20:24:56 +090040 platform_apis: true,
Jiyong Parkda119cb2020-12-07 15:58:23 +090041
42 manifest: "manifest.json",
43
44 key: "com.android.virt.key",
45 certificate: ":com.android.virt.certificate",
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010046
47 apps: [
48 "android.system.virtualmachine.res",
49 ],
50
51 file_contexts: ":com.android.virt-file_contexts",
52 canned_fs_config: "canned_fs_config",
Nikita Ioffef28eec22022-10-18 23:17:34 +010053
54 bootclasspath_fragments: [
55 "com.android.virt-bootclasspath-fragment",
56 ],
Nikita Ioffeb78c6202022-11-18 17:01:36 +000057 jni_libs: [
David Brazdil79588392022-10-20 17:04:46 +010058 "libvirtualizationservice_jni",
Nikita Ioffeb78c6202022-11-18 17:01:36 +000059 "libvirtualmachine_jni",
60 ],
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010061}
62
Alice Wangfcbf5ff2023-10-09 09:25:50 +000063soong_config_module_type {
64 name: "flag_aware_apex_defaults",
65 module_type: "apex_defaults",
66 config_namespace: "ANDROID",
67 bool_variables: [
68 "release_avf_enable_remote_attestation",
69 ],
70 properties: [
71 "prebuilts",
72 "vintf_fragments",
73 ],
74}
75
76flag_aware_apex_defaults {
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010077 name: "com.android.virt_avf_enabled",
78
79 defaults: ["com.android.virt_common"],
80
Jooyung Han05063d12021-10-27 01:50:51 +090081 custom_sign_tool: "sign_virt_apex",
Jiyong Parkda119cb2020-12-07 15:58:23 +090082
Andrew Walbrandfc953d2021-06-10 13:59:56 +000083 // crosvm and virtualizationservice are only enabled for 64-bit targets on device
Jiyong Park2199f202020-12-07 15:58:47 +090084 arch: {
85 arm64: {
86 binaries: [
Jiyong Park69b39372021-01-05 23:14:46 +090087 "crosvm",
Inseob Kimbdca0472023-07-28 19:20:56 +090088 "vfio_handler",
David Brazdil1f530702022-10-03 12:18:10 +010089 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +000090 "virtualizationservice",
Jiyong Park69b39372021-01-05 23:14:46 +090091 ],
Victor Hsieh384bf6a2021-11-11 13:28:09 -080092 filesystems: microdroid_filesystem_images,
Jiyong Park69b39372021-01-05 23:14:46 +090093 },
94 x86_64: {
95 binaries: [
Jiyong Park2199f202020-12-07 15:58:47 +090096 "crosvm",
Inseob Kimbdca0472023-07-28 19:20:56 +090097 "vfio_handler",
David Brazdil1f530702022-10-03 12:18:10 +010098 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +000099 "virtualizationservice",
Jiyong Park2199f202020-12-07 15:58:47 +0900100 ],
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800101 filesystems: microdroid_filesystem_images,
Jiyong Park2199f202020-12-07 15:58:47 +0900102 },
103 },
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900104 binaries: [
Victor Hsieh573c6492021-03-11 14:19:18 -0800105 "fd_server",
Andrew Walbranea9fa482021-03-04 16:11:12 +0000106 "vm",
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900107 ],
Alice Wangfcbf5ff2023-10-09 09:25:50 +0000108 soong_config_variables: {
109 release_avf_enable_remote_attestation: {
110 prebuilts: ["com.android.virt.init_attestation_enabled.rc"],
111 vintf_fragments: [
112 "virtualizationservice.xml",
113 ],
114 conditions_default: {
115 prebuilts: ["com.android.virt.init.rc"],
116 },
117 },
118 },
Inseob Kim72f06a32021-04-12 14:48:42 +0900119 prebuilts: [
Alice Wangfcbf5ff2023-10-09 09:25:50 +0000120 "com.android.virt.vfio_handler.rc",
Nikita Ioffeab1754c2022-10-13 20:28:54 +0100121 "features_com.android.virt.xml",
Seungjae Yooe85831e2022-12-12 09:34:58 +0900122 "microdroid_initrd_debuggable",
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000123 "microdroid_initrd_normal",
Jiyong Parke9b74d02021-06-21 14:39:12 +0900124 "microdroid.json",
Shikha Panwared8ace42022-09-28 12:52:16 +0000125 "microdroid_kernel",
Alice Wangc2fec932023-02-23 16:24:02 +0000126 "rialto_bin",
Inseob Kim72f06a32021-04-12 14:48:42 +0900127 ],
Jiyong Park17e3ed42022-08-29 17:27:00 +0900128 host_required: [
129 "vm_shell",
Jakob Vukalovic70ba6332023-07-11 10:52:22 +0100130 "prepare_device_vfio",
Jiyong Park17e3ed42022-08-29 17:27:00 +0900131 ],
Nikita Ioffeb0b67562022-11-22 15:48:06 +0000132 apps: [
133 "EmptyPayloadApp",
134 ],
Jiyong Parkda119cb2020-12-07 15:58:23 +0900135}
136
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +0100137apex_defaults {
138 name: "com.android.virt_avf_disabled",
139
140 defaults: ["com.android.virt_common"],
141}
142
Jiyong Parkda119cb2020-12-07 15:58:23 +0900143apex_key {
144 name: "com.android.virt.key",
145 public_key: "com.android.virt.avbpubkey",
146 private_key: "com.android.virt.pem",
147}
148
149android_app_certificate {
150 name: "com.android.virt.certificate",
151 certificate: "com.android.virt",
152}
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100153
154prebuilt_etc {
Alice Wangfcbf5ff2023-10-09 09:25:50 +0000155 name: "com.android.virt.vfio_handler.rc",
156 src: "vfio_handler.rc",
157 filename: "vfio_handler.rc",
158 installable: false,
159}
160
161prebuilt_etc {
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100162 name: "com.android.virt.init.rc",
Andrew Walbranf6bf6862021-05-21 12:41:13 +0000163 src: "virtualizationservice.rc",
Alice Wangfcbf5ff2023-10-09 09:25:50 +0000164 filename: "virtualizationservice.rc",
165 installable: false,
166}
167
168prebuilt_etc {
169 name: "com.android.virt.init_attestation_enabled.rc",
170 src: "virtualizationservice_attestation_enabled.rc",
171 filename: "virtualizationservice.rc",
Alan Stokes3ef78d92021-09-08 11:51:06 +0100172 installable: false,
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100173}
Jooyung Han504105f2021-10-26 15:54:50 +0900174
Jakob Vukalovic70ba6332023-07-11 10:52:22 +0100175sh_binary_host {
176 name: "prepare_device_vfio",
177 src: "prepare_device_vfio.sh",
178 filename: "prepare_device_vfio.sh",
179}
180
Jooyung Han504105f2021-10-26 15:54:50 +0900181// Virt apex needs a custom signer for its payload
182python_binary_host {
183 name: "sign_virt_apex",
184 srcs: [
185 "sign_virt_apex.py",
186 ],
187 version: {
Jooyung Han504105f2021-10-26 15:54:50 +0900188 py3: {
Jooyung Han504105f2021-10-26 15:54:50 +0900189 embedded_launcher: true,
190 },
191 },
Jooyung Han05063d12021-10-27 01:50:51 +0900192 required: [
Shikha Panwara7605cf2023-01-12 09:29:39 +0000193 // sign_virt_apex should be runnable from outside the source tree,
194 // therefore, any required tool should be listed in build/make/core/Makefile as well.
Jooyung Han05063d12021-10-27 01:50:51 +0900195 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000196 "initrd_bootconfig",
Jooyung Han05063d12021-10-27 01:50:51 +0900197 "lpmake",
198 "lpunpack",
199 "simg2img",
200 ],
Jooyung Han504105f2021-10-26 15:54:50 +0900201}
Jooyung Hand35952e2021-11-08 17:53:47 +0900202
Jooyung Han02dceed2021-11-08 17:50:22 +0900203sh_test_host {
204 name: "sign_virt_apex_test",
205 src: "sign_virt_apex_test.sh",
206 test_config: "sign_virt_apex_test.xml",
207 data_bins: [
208 // deapexer
209 "deapexer",
210 "debugfs_static",
Dennis Shen28c79442022-11-08 14:26:13 +0000211 "fsck.erofs",
Jooyung Han02dceed2021-11-08 17:50:22 +0900212
213 // sign_virt_apex
214 "avbtool",
215 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000216 "initrd_bootconfig",
Jooyung Han02dceed2021-11-08 17:50:22 +0900217 "lpmake",
218 "lpunpack",
219 "sign_virt_apex",
220 "simg2img",
221 ],
222 data_libs: [
223 "libbase",
224 "libc++",
225 "libcrypto_utils",
226 "libcrypto",
227 "libext4_utils",
228 "liblog",
229 "liblp",
230 "libsparse",
231 "libz",
232 ],
233 data: [
234 ":com.android.virt",
Jooyung Han6afd6672022-02-22 05:22:23 +0900235 ":test.com.android.virt.pem",
Jooyung Han02dceed2021-11-08 17:50:22 +0900236 ],
237 test_suites: ["general-tests"],
238}
239
Jooyung Han6afd6672022-02-22 05:22:23 +0900240filegroup {
241 name: "test.com.android.virt.pem",
242 srcs: ["test.com.android.virt.pem"],
243}
244
Jooyung Han1c3d2fa2022-02-24 02:35:59 +0900245filegroup {
246 name: "test2.com.android.virt.pem",
247 srcs: ["test2.com.android.virt.pem"],
248}
249
Jooyung Hand35952e2021-11-08 17:53:47 +0900250// custom tool to replace bytes in a file
251python_binary_host {
252 name: "replace_bytes",
253 srcs: [
254 "replace_bytes.py",
255 ],
256 version: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900257 py3: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900258 embedded_launcher: true,
259 },
260 },
261}
Nikita Ioffef28eec22022-10-18 23:17:34 +0100262
263// Encapsulate the contributions made by the com.android.virt to the bootclasspath.
264bootclasspath_fragment {
265 name: "com.android.virt-bootclasspath-fragment",
266 contents: ["framework-virtualization"],
267 apex_available: ["com.android.virt"],
268
269 // The bootclasspath_fragments that provide APIs on which this depends.
270 fragments: [
271 {
272 apex: "com.android.art",
273 module: "art-bootclasspath-fragment",
274 },
275 ],
276
277 // Additional stubs libraries that this fragment's contents use which are
278 // not provided by another bootclasspath_fragment.
279 additional_stubs: [
280 "android-non-updatable",
281 ],
282
283 hidden_api: {
284
285 // This module does not contain any split packages.
286 split_packages: [],
287
288 // The following packages and all their subpackages currently only
289 // contain classes from this bootclasspath_fragment. Listing a package
290 // here won't prevent other bootclasspath modules from adding classes in
291 // any of those packages but it will prevent them from adding those
292 // classes into an API surface, e.g. public, system, etc.. Doing so will
293 // result in a build failure due to inconsistent flags.
294 package_prefixes: [
295 "android.system.virtualmachine",
296 "android.system.virtualizationservice",
297 // android.sysprop.*, renamed by jarjar
298 "com.android.system.virtualmachine.sysprop",
299 ],
300 },
301}