blob: 7c45cc56299768813370a78e5d9bcf392b8757a0 [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,
Alice Wangbe8330c2023-10-19 08:55:07 +0000102 prebuilts: [
103 "rialto_bin",
104 ],
Jiyong Park69b39372021-01-05 23:14:46 +0900105 },
106 x86_64: {
107 binaries: [
Jiyong Park2199f202020-12-07 15:58:47 +0900108 "crosvm",
David Brazdil1f530702022-10-03 12:18:10 +0100109 "virtmgr",
Andrew Walbrandfc953d2021-06-10 13:59:56 +0000110 "virtualizationservice",
Jiyong Park2199f202020-12-07 15:58:47 +0900111 ],
Victor Hsieh384bf6a2021-11-11 13:28:09 -0800112 filesystems: microdroid_filesystem_images,
Jiyong Park2199f202020-12-07 15:58:47 +0900113 },
114 },
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900115 binaries: [
Victor Hsieh573c6492021-03-11 14:19:18 -0800116 "fd_server",
Andrew Walbranea9fa482021-03-04 16:11:12 +0000117 "vm",
Jiyong Park8d1eb7e2021-02-16 13:23:00 +0900118 ],
Inseob Kim72f06a32021-04-12 14:48:42 +0900119 prebuilts: [
Nikita Ioffeab1754c2022-10-13 20:28:54 +0100120 "features_com.android.virt.xml",
Seungjae Yooe85831e2022-12-12 09:34:58 +0900121 "microdroid_initrd_debuggable",
Shikha Panwarf46f96b2022-08-22 14:11:14 +0000122 "microdroid_initrd_normal",
Jiyong Parke9b74d02021-06-21 14:39:12 +0900123 "microdroid.json",
Shikha Panwared8ace42022-09-28 12:52:16 +0000124 "microdroid_kernel",
Inseob Kim72f06a32021-04-12 14:48:42 +0900125 ],
Jiyong Park17e3ed42022-08-29 17:27:00 +0900126 host_required: [
127 "vm_shell",
128 ],
Nikita Ioffeb0b67562022-11-22 15:48:06 +0000129 apps: [
130 "EmptyPayloadApp",
131 ],
Inseob Kim77c7f712023-11-06 17:01:02 +0900132 soong_config_variables: {
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000133 release_avf_enable_device_assignment: {
134 prebuilts: [
135 "com.android.virt.vfio_handler.rc",
136 ],
137 arch: {
138 arm64: {
139 binaries: ["vfio_handler"],
140 },
141 x86_64: {
142 binaries: ["vfio_handler"],
143 },
144 },
145 },
Inseob Kim77c7f712023-11-06 17:01:02 +0900146 release_avf_enable_vendor_modules: {
147 prebuilts: [
Inseob Kim0276f612023-12-07 17:25:18 +0900148 "microdroid_gki-android14-6.1_initrd_debuggable",
149 "microdroid_gki-android14-6.1_initrd_normal",
150 "microdroid_gki-android14-6.1_kernel",
151 "microdroid_gki-android14-6.1.json",
Inseob Kim77c7f712023-11-06 17:01:02 +0900152 ],
153 },
Alice Wangb5b90322023-11-14 07:38:18 +0000154 release_avf_enable_remote_attestation: {
155 prebuilts: ["com.android.virt.init_attestation_enabled.rc"],
156 vintf_fragments: [
157 "virtualizationservice.xml",
158 ],
159 conditions_default: {
160 prebuilts: ["com.android.virt.init.rc"],
161 },
162 },
Inseob Kim77c7f712023-11-06 17:01:02 +0900163 },
Jiyong Parkda119cb2020-12-07 15:58:23 +0900164}
165
Nikita Ioffe50e2ebe2022-10-24 17:16:25 +0100166apex_defaults {
167 name: "com.android.virt_avf_disabled",
168
169 defaults: ["com.android.virt_common"],
170}
171
Jiyong Parkda119cb2020-12-07 15:58:23 +0900172apex_key {
173 name: "com.android.virt.key",
174 public_key: "com.android.virt.avbpubkey",
175 private_key: "com.android.virt.pem",
176}
177
178android_app_certificate {
179 name: "com.android.virt.certificate",
180 certificate: "com.android.virt",
181}
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100182
183prebuilt_etc {
184 name: "com.android.virt.init.rc",
Andrew Walbranf6bf6862021-05-21 12:41:13 +0000185 src: "virtualizationservice.rc",
Alice Wangb5b90322023-11-14 07:38:18 +0000186 filename: "virtualizationservice.rc",
187 installable: false,
188}
189
190prebuilt_etc {
191 name: "com.android.virt.init_attestation_enabled.rc",
192 src: "virtualizationservice_attestation_enabled.rc",
193 filename: "virtualizationservice.rc",
Alan Stokes3ef78d92021-09-08 11:51:06 +0100194 installable: false,
Jeff Vander Stoep63ab2382021-03-25 22:18:53 +0100195}
Jooyung Han504105f2021-10-26 15:54:50 +0900196
Nikita Ioffe94a8a182023-11-16 16:37:48 +0000197prebuilt_etc {
198 name: "com.android.virt.vfio_handler.rc",
199 src: "vfio_handler.rc",
200 filename: "vfio_handler.rc",
201 installable: false,
202}
203
Jooyung Han504105f2021-10-26 15:54:50 +0900204// Virt apex needs a custom signer for its payload
205python_binary_host {
206 name: "sign_virt_apex",
207 srcs: [
208 "sign_virt_apex.py",
209 ],
210 version: {
Jooyung Han504105f2021-10-26 15:54:50 +0900211 py3: {
Jooyung Han504105f2021-10-26 15:54:50 +0900212 embedded_launcher: true,
213 },
214 },
Jooyung Han05063d12021-10-27 01:50:51 +0900215 required: [
Shikha Panwara7605cf2023-01-12 09:29:39 +0000216 // sign_virt_apex should be runnable from outside the source tree,
217 // therefore, any required tool should be listed in build/make/core/Makefile as well.
Jooyung Han05063d12021-10-27 01:50:51 +0900218 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000219 "initrd_bootconfig",
Jooyung Han05063d12021-10-27 01:50:51 +0900220 "lpmake",
221 "lpunpack",
222 "simg2img",
223 ],
Jooyung Han504105f2021-10-26 15:54:50 +0900224}
Jooyung Hand35952e2021-11-08 17:53:47 +0900225
Jooyung Han02dceed2021-11-08 17:50:22 +0900226sh_test_host {
227 name: "sign_virt_apex_test",
228 src: "sign_virt_apex_test.sh",
229 test_config: "sign_virt_apex_test.xml",
230 data_bins: [
231 // deapexer
232 "deapexer",
233 "debugfs_static",
Dennis Shen28c79442022-11-08 14:26:13 +0000234 "fsck.erofs",
Jooyung Han02dceed2021-11-08 17:50:22 +0900235
236 // sign_virt_apex
237 "avbtool",
238 "img2simg",
Shikha Panwara7605cf2023-01-12 09:29:39 +0000239 "initrd_bootconfig",
Jooyung Han02dceed2021-11-08 17:50:22 +0900240 "lpmake",
241 "lpunpack",
242 "sign_virt_apex",
243 "simg2img",
244 ],
245 data_libs: [
246 "libbase",
247 "libc++",
248 "libcrypto_utils",
249 "libcrypto",
250 "libext4_utils",
251 "liblog",
252 "liblp",
253 "libsparse",
254 "libz",
255 ],
256 data: [
257 ":com.android.virt",
Jooyung Han6afd6672022-02-22 05:22:23 +0900258 ":test.com.android.virt.pem",
Jooyung Han02dceed2021-11-08 17:50:22 +0900259 ],
260 test_suites: ["general-tests"],
261}
262
Jooyung Han6afd6672022-02-22 05:22:23 +0900263filegroup {
264 name: "test.com.android.virt.pem",
265 srcs: ["test.com.android.virt.pem"],
266}
267
Jooyung Han1c3d2fa2022-02-24 02:35:59 +0900268filegroup {
269 name: "test2.com.android.virt.pem",
270 srcs: ["test2.com.android.virt.pem"],
271}
272
Jooyung Hand35952e2021-11-08 17:53:47 +0900273// custom tool to replace bytes in a file
274python_binary_host {
275 name: "replace_bytes",
276 srcs: [
277 "replace_bytes.py",
278 ],
279 version: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900280 py3: {
Jooyung Hand35952e2021-11-08 17:53:47 +0900281 embedded_launcher: true,
282 },
283 },
284}
Nikita Ioffef28eec22022-10-18 23:17:34 +0100285
286// Encapsulate the contributions made by the com.android.virt to the bootclasspath.
287bootclasspath_fragment {
288 name: "com.android.virt-bootclasspath-fragment",
289 contents: ["framework-virtualization"],
290 apex_available: ["com.android.virt"],
291
292 // The bootclasspath_fragments that provide APIs on which this depends.
293 fragments: [
294 {
295 apex: "com.android.art",
296 module: "art-bootclasspath-fragment",
297 },
298 ],
299
300 // Additional stubs libraries that this fragment's contents use which are
301 // not provided by another bootclasspath_fragment.
302 additional_stubs: [
303 "android-non-updatable",
304 ],
305
306 hidden_api: {
307
308 // This module does not contain any split packages.
309 split_packages: [],
310
311 // The following packages and all their subpackages currently only
312 // contain classes from this bootclasspath_fragment. Listing a package
313 // here won't prevent other bootclasspath modules from adding classes in
314 // any of those packages but it will prevent them from adding those
315 // classes into an API surface, e.g. public, system, etc.. Doing so will
316 // result in a build failure due to inconsistent flags.
317 package_prefixes: [
318 "android.system.virtualmachine",
319 "android.system.virtualizationservice",
320 // android.sysprop.*, renamed by jarjar
321 "com.android.system.virtualmachine.sysprop",
322 ],
323 },
324}