blob: 3b7933417c7ea7f4ec4c7564ab1715d63be5a7c3 [file] [log] [blame]
Janis Danisevskis43c89712020-08-03 23:42:42 +00001// Copyright 2020, The Android Open Source Project
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Bob Badour4c7858c2021-02-12 15:40:29 -080015package {
16 // See: http://go/android-license-faq
17 // A large-scale-change added 'default_applicable_licenses' to import
18 // all of the 'license_kinds' from "system_security_license"
19 // to get the below license kinds:
20 // SPDX-license-identifier-Apache-2.0
21 default_applicable_licenses: ["system_security_license"],
22}
23
Paul Crowley7c57bf12021-02-02 16:26:57 -080024rust_defaults {
25 name: "libkeystore2_defaults",
Janis Danisevskis43c89712020-08-03 23:42:42 +000026 crate_name: "keystore2",
27 srcs: ["src/lib.rs"],
Janis Danisevskis7d77a762020-07-20 13:03:31 -070028
29 rustlibs: [
Jeongik Cha9f632c62021-01-23 09:33:35 +090030 "android.hardware.security.keymint-V1-rust",
31 "android.hardware.security.secureclock-V1-rust",
Janis Danisevskis84a83e42021-03-21 21:46:54 -070032 "android.hardware.security.sharedsecret-V1-rust",
Bram Bonné5d6c5102021-02-24 15:09:18 +010033 "android.os.permissions_aidl-rust",
Janis Danisevskis7a1cf382020-11-20 11:22:14 -080034 "android.security.apc-rust",
Janis Danisevskis9f10a6a2021-01-18 16:45:21 +000035 "android.security.authorization-rust",
Joel Galensonde386b42020-09-30 10:53:05 -070036 "android.security.compat-rust",
Janis Danisevskis34a0cf22021-03-08 09:19:03 -080037 "android.security.maintenance-rust",
Hasini Gunasinghe15891e62021-06-10 16:23:27 +000038 "android.security.metrics-rust",
Max Bires148c08e2020-10-13 13:41:41 -070039 "android.security.remoteprovisioning-rust",
Jeongik Cha9f632c62021-01-23 09:33:35 +090040 "android.system.keystore2-V1-rust",
Janis Danisevskis7d77a762020-07-20 13:03:31 -070041 "libanyhow",
Janis Danisevskise24f3472020-08-12 17:58:49 -070042 "libbinder_rs",
Janis Danisevskis212c68b2021-01-14 22:29:28 -080043 "libkeystore2_aaid-rust",
Janis Danisevskis7a1cf382020-11-20 11:22:14 -080044 "libkeystore2_apc_compat-rust",
Janis Danisevskisb42fc182020-12-15 08:41:27 -080045 "libkeystore2_crypto_rust",
Joel Galensonde386b42020-09-30 10:53:05 -070046 "libkeystore2_km_compat",
Janis Danisevskisce995432020-07-21 12:22:34 -070047 "libkeystore2_selinux",
Janis Danisevskisef14e1a2021-02-23 23:16:55 -080048 "libkeystore2_vintf_rust",
Janis Danisevskis4ad056f2020-08-05 19:46:46 +000049 "liblazy_static",
Hasini Gunasinghe557b1032020-11-10 01:35:30 +000050 "liblibc",
Pavel Grafov94243c22021-04-21 18:03:11 +010051 "liblog_event_list",
Janis Danisevskis7d77a762020-07-20 13:03:31 -070052 "liblog_rust",
Joel Galenson0891bc12020-07-20 10:37:03 -070053 "librand",
Joel Galenson7ead3a22021-07-29 15:27:34 -070054 "librustutils",
Max Bires48fc2e52021-11-17 10:13:04 -080055 "libserde",
56 "libserde_cbor",
Janis Danisevskis7d77a762020-07-20 13:03:31 -070057 "libthiserror",
58 ],
Joel Galensonba41ca32020-12-28 14:14:07 -080059 shared_libs: [
60 "libcutils",
61 ],
Janis Danisevskis3d5a2142021-05-05 07:31:24 -070062 features: [
63 "watchdog",
64 ],
Janis Danisevskis43c89712020-08-03 23:42:42 +000065}
66
Janis Danisevskis2a8330a2021-01-20 15:34:26 -080067rust_library {
Paul Crowley7c57bf12021-02-02 16:26:57 -080068 name: "libkeystore2",
69 defaults: ["libkeystore2_defaults"],
Jiyong Park975906d2021-09-30 14:58:39 +090070 rustlibs: [
71 "liblibsqlite3_sys",
72 "librusqlite",
73 ],
74}
75
76rust_library {
77 name: "libkeystore2_noicu",
78 defaults: ["libkeystore2_defaults"],
79 rustlibs: [
80 "liblibsqlite3_sys_noicu",
81 "librusqlite_noicu",
82 ],
Paul Crowley7c57bf12021-02-02 16:26:57 -080083}
84
85rust_library {
Janis Danisevskis2a8330a2021-01-20 15:34:26 -080086 name: "libkeystore2_test_utils",
87 crate_name: "keystore2_test_utils",
88 srcs: ["test_utils/lib.rs"],
89 rustlibs: [
Janis Danisevskisa578d392021-09-20 15:44:06 -070090 "libkeystore2_selinux",
Janis Danisevskis2a8330a2021-01-20 15:34:26 -080091 "liblog_rust",
Janis Danisevskisa578d392021-09-20 15:44:06 -070092 "libnix",
Janis Danisevskis2a8330a2021-01-20 15:34:26 -080093 "librand",
Janis Danisevskisa578d392021-09-20 15:44:06 -070094 "libserde",
95 "libserde_cbor",
96 ],
97}
98
99rust_test {
100 name: "keystore2_test_utils_test",
101 srcs: ["test_utils/lib.rs"],
102 test_suites: ["general-tests"],
Joel Galenson1edfbea2021-10-26 13:41:07 -0700103 require_root: true,
104 auto_gen_config: true,
Janis Danisevskisa578d392021-09-20 15:44:06 -0700105 compile_multilib: "first",
106 rustlibs: [
107 "libkeystore2_selinux",
108 "liblog_rust",
109 "libnix",
110 "librand",
111 "libserde",
112 "libserde_cbor",
Matthew Maurer3ca82bc2021-04-29 13:08:40 -0700113 ],
Janis Danisevskis2a8330a2021-01-20 15:34:26 -0800114}
115
Janis Danisevskis43c89712020-08-03 23:42:42 +0000116rust_test {
117 name: "keystore2_test",
Joel Galenson26f4d012020-07-17 14:57:21 -0700118 crate_name: "keystore2",
Joel Galenson3f78dd82021-01-20 16:21:30 -0800119 test_suites: ["general-tests"],
120 auto_gen_config: true,
Janis Danisevskis66784c42021-01-27 08:40:25 -0800121 compile_multilib: "first",
Paul Crowley7c57bf12021-02-02 16:26:57 -0800122 defaults: ["libkeystore2_defaults"],
Janis Danisevskis7d77a762020-07-20 13:03:31 -0700123 rustlibs: [
124 "libandroid_logger",
Janis Danisevskis2a8330a2021-01-20 15:34:26 -0800125 "libkeystore2_test_utils",
Jiyong Park975906d2021-09-30 14:58:39 +0900126 "liblibsqlite3_sys",
Janis Danisevskis5cb52dc2021-04-07 16:31:18 -0700127 "libnix",
Jiyong Park975906d2021-09-30 14:58:39 +0900128 "librusqlite",
Janis Danisevskis7d77a762020-07-20 13:03:31 -0700129 ],
Janis Danisevskis3d5a2142021-05-05 07:31:24 -0700130 // The test should always include watchdog.
131 features: [
132 "watchdog",
133 ],
Janis Danisevskis43c89712020-08-03 23:42:42 +0000134}
Janis Danisevskis652f3812020-08-04 00:01:12 +0000135
Jiyong Park975906d2021-09-30 14:58:39 +0900136rust_defaults {
137 name: "keystore2_defaults",
Janis Danisevskis1af91262020-08-10 14:58:08 -0700138 srcs: ["src/keystore2_main.rs"],
139 rustlibs: [
140 "libandroid_logger",
141 "libbinder_rs",
Janis Danisevskis1af91262020-08-10 14:58:08 -0700142 "liblog_rust",
143 ],
144 init_rc: ["keystore2.rc"],
Stephen Crane56936e82021-03-10 17:48:26 -0800145
Matthew Maurer3ca82bc2021-04-29 13:08:40 -0700146 // In S, keystore2 is the only process using dynamically linked Rust from
147 // /system. As a result, the usual savings from sharing libraries don't
148 // apply.
149 // Remove `prefer_rlib: true` once we have several processes, once a space
150 // calculation shows net RAM savings, or once we have automatic variant
151 // selection available in the build system.
152 prefer_rlib: true,
153
154 // TODO(b/187412695)
155 // This is a hack to work around the build system not installing
156 // dynamic dependencies of rlibs to the device. This section should
157 // be removed once that works correctly.
158 shared_libs: [
159 "android.hardware.confirmationui@1.0",
Jiyong Park0d61dd62021-07-27 12:20:26 +0900160 "android.hardware.security.sharedsecret-V1-ndk",
161 "android.security.compat-ndk",
Matthew Maurer3ca82bc2021-04-29 13:08:40 -0700162 "libc",
163 "libdl_android",
164 "libdl",
Matthew Maurer3ca82bc2021-04-29 13:08:40 -0700165 "libkeymint",
166 "libkeystore2_aaid",
167 "libkeystore2_apc_compat",
168 "libkeystore2_crypto",
Matthew Maurer3ca82bc2021-04-29 13:08:40 -0700169 "libkm_compat_service",
170 "libkm_compat",
171 "libm",
172 "libstatspull",
173 "libstatssocket",
174 ],
175
Stephen Crane56936e82021-03-10 17:48:26 -0800176 vintf_fragments: ["android.system.keystore2-service.xml"],
Janis Danisevskis2cb4f092021-05-17 13:25:07 -0700177
178 required: ["keystore_cli_v2"],
Janis Danisevskis1af91262020-08-10 14:58:08 -0700179}
Jiyong Park975906d2021-09-30 14:58:39 +0900180
181rust_binary {
182 name: "keystore2",
183 defaults: ["keystore2_defaults"],
184 rustlibs: [
185 "libkeystore2",
186 "liblegacykeystore-rust",
187 "librusqlite",
188 ],
189}
190
191// Variant of keystore2 for use in microdroid. It doesn't depend on the ICU-enabled sqlite.
192// This can be used also in Android, but we choose not to because it will bring two
193// variants of sqlite to the system causing more RAM usage and CPU cycles when loading.
194rust_binary {
195 name: "keystore2_microdroid",
196 stem: "keystore2",
197 defaults: ["keystore2_defaults"],
198 rustlibs: [
199 "libkeystore2_noicu",
200 "liblegacykeystore-rust_noicu",
201 "librusqlite_noicu",
202 ],
203 installable: false, // don't install this to Android
204}