blob: b09cf58277edca37fc98fee937d57540a7315998 [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 ],
Jooyung Han3b980eb2023-11-03 14:48:00 +090061 // TODO(b/295593640) Unfortunately these are added to the apex even though they are unused.
62 // Once the build system is fixed, remove this.
63 unwanted_transitive_deps: [
64 "libdrm",
65 "libsso",
66 "libutils",
67 ],
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010068}
69
Inseob Kim77c7f712023-11-06 17:01:02 +090070soong_config_module_type {
71 name: "avf_flag_aware_apex_defaults",
72 module_type: "apex_defaults",
73 config_namespace: "ANDROID",
Nikita Ioffe94a8a182023-11-16 16:37:48 +000074 bool_variables: [
75 "release_avf_enable_device_assignment",
Alice Wangb5b90322023-11-14 07:38:18 +000076 "release_avf_enable_remote_attestation",
Nikita Ioffe94a8a182023-11-16 16:37:48 +000077 "release_avf_enable_vendor_modules",
78 ],
79 properties: [
80 "arch",
81 "prebuilts",
Alice Wangb5b90322023-11-14 07:38:18 +000082 "vintf_fragments",
Nikita Ioffe94a8a182023-11-16 16:37:48 +000083 ],
Inseob Kim77c7f712023-11-06 17:01:02 +090084}
85
86avf_flag_aware_apex_defaults {
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +010087 name: "com.android.virt_avf_enabled",
88
89 defaults: ["com.android.virt_common"],
90
Jooyung Han05063d12021-10-27 01:50:51 +090091 custom_sign_tool: "sign_virt_apex",
Jiyong Parkda119cb2020-12-07 15:58:23 +090092
Andrew Walbrandfc953d2021-06-10 13:59:56 +000093 // crosvm and virtualizationservice are only enabled for 64-bit targets on device
Jiyong Park2199f202020-12-07 15:58:47 +090094 arch: {
95 arm64: {
96 binaries: [
Jiyong Park69b39372021-01-05 23:14:46 +090097 "crosvm",
David Brazdil1f530702022-10-03 12:18:10 +010098 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +000099 "virtualizationservice",
Jiyong Park69b39372021-01-05 23:14:46 +0900100 ],
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800101 filesystems: microdroid_filesystem_images,
Jiyong Park69b39372021-01-05 23:14:46 +0900102 },
103 x86_64: {
104 binaries: [
Jiyong Park2199f202020-12-07 15:58:47 +0900105 "crosvm",
David Brazdil1f530702022-10-03 12:18:10 +0100106 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +0000107 "virtualizationservice",
Jiyong Park2199f202020-12-07 15:58:47 +0900108 ],
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800109 filesystems: microdroid_filesystem_images,
Jiyong Park2199f202020-12-07 15:58:47 +0900110 },
111 },
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900112 binaries: [
Victor Hsieh573c6492021-03-11 14:19:18 -0800113 "fd_server",
Andrew Walbranea9fa482021-03-04 16:11:12 +0000114 "vm",
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900115 ],
Inseob Kim72f06a32021-04-12 14:48:42 +0900116 prebuilts: [
Nikita Ioffeab1754c2022-10-13 20:28:54 +0100117 "features_com.android.virt.xml",
Seungjae Yooe85831e2022-12-12 09:34:58 +0900118 "microdroid_initrd_debuggable",
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000119 "microdroid_initrd_normal",
Jiyong Parke9b74d02021-06-21 14:39:12 +0900120 "microdroid.json",
Shikha Panwared8ace42022-09-28 12:52:16 +0000121 "microdroid_kernel",
Alice Wangc2fec932023-02-23 16:24:02 +0000122 "rialto_bin",
Inseob Kim72f06a32021-04-12 14:48:42 +0900123 ],
Jiyong Park17e3ed42022-08-29 17:27:00 +0900124 host_required: [
125 "vm_shell",
126 ],
Nikita Ioffeb0b67562022-11-22 15:48:06 +0000127 apps: [
128 "EmptyPayloadApp",
129 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900130 soong_config_variables: {
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000131 release_avf_enable_device_assignment: {
132 prebuilts: [
133 "com.android.virt.vfio_handler.rc",
134 ],
135 arch: {
136 arm64: {
137 binaries: ["vfio_handler"],
138 },
139 x86_64: {
140 binaries: ["vfio_handler"],
141 },
142 },
143 },
Inseob Kim77c7f712023-11-06 17:01:02 +0900144 release_avf_enable_vendor_modules: {
145 prebuilts: [
Inseob Kim0276f612023-12-07 17:25:18 +0900146 "microdroid_gki-android14-6.1_initrd_debuggable",
147 "microdroid_gki-android14-6.1_initrd_normal",
148 "microdroid_gki-android14-6.1_kernel",
149 "microdroid_gki-android14-6.1.json",
Inseob Kim77c7f712023-11-06 17:01:02 +0900150 ],
151 },
Alice Wangb5b90322023-11-14 07:38:18 +0000152 release_avf_enable_remote_attestation: {
153 prebuilts: ["com.android.virt.init_attestation_enabled.rc"],
154 vintf_fragments: [
155 "virtualizationservice.xml",
156 ],
157 conditions_default: {
158 prebuilts: ["com.android.virt.init.rc"],
159 },
160 },
Inseob Kim77c7f712023-11-06 17:01:02 +0900161 },
Jiyong Parkda119cb2020-12-07 15:58:23 +0900162}
163
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +0100164apex_defaults {
165 name: "com.android.virt_avf_disabled",
166
167 defaults: ["com.android.virt_common"],
168}
169
Jiyong Parkda119cb2020-12-07 15:58:23 +0900170apex_key {
171 name: "com.android.virt.key",
172 public_key: "com.android.virt.avbpubkey",
173 private_key: "com.android.virt.pem",
174}
175
176android_app_certificate {
177 name: "com.android.virt.certificate",
178 certificate: "com.android.virt",
179}
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100180
181prebuilt_etc {
182 name: "com.android.virt.init.rc",
Andrew Walbranf6bf6862021-05-21 12:41:13 +0000183 src: "virtualizationservice.rc",
Alice Wangb5b90322023-11-14 07:38:18 +0000184 filename: "virtualizationservice.rc",
185 installable: false,
186}
187
188prebuilt_etc {
189 name: "com.android.virt.init_attestation_enabled.rc",
190 src: "virtualizationservice_attestation_enabled.rc",
191 filename: "virtualizationservice.rc",
Alan Stokes3ef78d92021-09-08 11:51:06 +0100192 installable: false,
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100193}
Jooyung Han504105f2021-10-26 15:54:50 +0900194
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000195prebuilt_etc {
196 name: "com.android.virt.vfio_handler.rc",
197 src: "vfio_handler.rc",
198 filename: "vfio_handler.rc",
199 installable: false,
200}
201
Jooyung Han504105f2021-10-26 15:54:50 +0900202// Virt apex needs a custom signer for its payload
203python_binary_host {
204 name: "sign_virt_apex",
205 srcs: [
206 "sign_virt_apex.py",
207 ],
208 version: {
Jooyung Han504105f2021-10-26 15:54:50 +0900209 py3: {
Jooyung Han504105f2021-10-26 15:54:50 +0900210 embedded_launcher: true,
211 },
212 },
Jooyung Han05063d12021-10-27 01:50:51 +0900213 required: [
Shikha Panwara7605cf2023-01-12 09:29:39 +0000214 // sign_virt_apex should be runnable from outside the source tree,
215 // therefore, any required tool should be listed in build/make/core/Makefile as well.
Jooyung Han05063d12021-10-27 01:50:51 +0900216 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000217 "initrd_bootconfig",
Jooyung Han05063d12021-10-27 01:50:51 +0900218 "lpmake",
219 "lpunpack",
220 "simg2img",
221 ],
Jooyung Han504105f2021-10-26 15:54:50 +0900222}
Jooyung Hand35952e2021-11-08 17:53:47 +0900223
Jooyung Han02dceed2021-11-08 17:50:22 +0900224sh_test_host {
225 name: "sign_virt_apex_test",
226 src: "sign_virt_apex_test.sh",
227 test_config: "sign_virt_apex_test.xml",
228 data_bins: [
229 // deapexer
230 "deapexer",
231 "debugfs_static",
Dennis Shen28c79442022-11-08 14:26:13 +0000232 "fsck.erofs",
Jooyung Han02dceed2021-11-08 17:50:22 +0900233
234 // sign_virt_apex
235 "avbtool",
236 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000237 "initrd_bootconfig",
Jooyung Han02dceed2021-11-08 17:50:22 +0900238 "lpmake",
239 "lpunpack",
240 "sign_virt_apex",
241 "simg2img",
242 ],
243 data_libs: [
244 "libbase",
245 "libc++",
246 "libcrypto_utils",
247 "libcrypto",
248 "libext4_utils",
249 "liblog",
250 "liblp",
251 "libsparse",
252 "libz",
253 ],
254 data: [
255 ":com.android.virt",
Jooyung Han6afd6672022-02-22 05:22:23 +0900256 ":test.com.android.virt.pem",
Jooyung Han02dceed2021-11-08 17:50:22 +0900257 ],
258 test_suites: ["general-tests"],
259}
260
Jooyung Han6afd6672022-02-22 05:22:23 +0900261filegroup {
262 name: "test.com.android.virt.pem",
263 srcs: ["test.com.android.virt.pem"],
264}
265
Jooyung Han1c3d2fa2022-02-24 02:35:59 +0900266filegroup {
267 name: "test2.com.android.virt.pem",
268 srcs: ["test2.com.android.virt.pem"],
269}
270
Jooyung Hand35952e2021-11-08 17:53:47 +0900271// custom tool to replace bytes in a file
272python_binary_host {
273 name: "replace_bytes",
274 srcs: [
275 "replace_bytes.py",
276 ],
277 version: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900278 py3: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900279 embedded_launcher: true,
280 },
281 },
282}
Nikita Ioffef28eec22022-10-18 23:17:34 +0100283
284// Encapsulate the contributions made by the com.android.virt to the bootclasspath.
285bootclasspath_fragment {
286 name: "com.android.virt-bootclasspath-fragment",
287 contents: ["framework-virtualization"],
288 apex_available: ["com.android.virt"],
289
290 // The bootclasspath_fragments that provide APIs on which this depends.
291 fragments: [
292 {
293 apex: "com.android.art",
294 module: "art-bootclasspath-fragment",
295 },
296 ],
297
298 // Additional stubs libraries that this fragment's contents use which are
299 // not provided by another bootclasspath_fragment.
300 additional_stubs: [
301 "android-non-updatable",
302 ],
303
304 hidden_api: {
305
306 // This module does not contain any split packages.
307 split_packages: [],
308
309 // The following packages and all their subpackages currently only
310 // contain classes from this bootclasspath_fragment. Listing a package
311 // here won't prevent other bootclasspath modules from adding classes in
312 // any of those packages but it will prevent them from adding those
313 // classes into an API surface, e.g. public, system, etc.. Doing so will
314 // result in a build failure due to inconsistent flags.
315 package_prefixes: [
316 "android.system.virtualmachine",
317 "android.system.virtualizationservice",
318 // android.sysprop.*, renamed by jarjar
319 "com.android.system.virtualmachine.sysprop",
320 ],
321 },
322}