Janis Danisevskis | 43c8971 | 2020-08-03 23:42:42 +0000 | [diff] [blame] | 1 | // 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 Badour | 4c7858c | 2021-02-12 15:40:29 -0800 | [diff] [blame] | 15 | package { |
Vikram Gaur | 743f178 | 2024-09-06 05:45:08 +0000 | [diff] [blame^] | 16 | default_team: "trendy_team_android_hardware_backed_security", |
Bob Badour | 4c7858c | 2021-02-12 15:40:29 -0800 | [diff] [blame] | 17 | // See: http://go/android-license-faq |
| 18 | // A large-scale-change added 'default_applicable_licenses' to import |
| 19 | // all of the 'license_kinds' from "system_security_license" |
| 20 | // to get the below license kinds: |
| 21 | // SPDX-license-identifier-Apache-2.0 |
| 22 | default_applicable_licenses: ["system_security_license"], |
| 23 | } |
| 24 | |
Paul Crowley | 7c57bf1 | 2021-02-02 16:26:57 -0800 | [diff] [blame] | 25 | rust_defaults { |
| 26 | name: "libkeystore2_defaults", |
Janis Danisevskis | 43c8971 | 2020-08-03 23:42:42 +0000 | [diff] [blame] | 27 | crate_name: "keystore2", |
| 28 | srcs: ["src/lib.rs"], |
David Drysdale | bdb232d | 2021-11-22 14:41:18 +0000 | [diff] [blame] | 29 | defaults: [ |
| 30 | "keymint_use_latest_hal_aidl_rust", |
Tri Vo | 735f9cb | 2022-09-06 14:30:45 -0700 | [diff] [blame] | 31 | "keystore2_use_latest_aidl_rust", |
Markus Vill | fdf4317 | 2024-01-31 15:57:04 +0100 | [diff] [blame] | 32 | "structured_log_rust_defaults", |
David Drysdale | bdb232d | 2021-11-22 14:41:18 +0000 | [diff] [blame] | 33 | ], |
Alice Wang | 81dbef7 | 2024-07-31 15:13:14 +0000 | [diff] [blame] | 34 | cfgs: select(release_flag("RELEASE_AVF_ENABLE_EARLY_VM"), { |
| 35 | true: ["early_vm"], |
| 36 | default: [], |
| 37 | }), |
Janis Danisevskis | 7d77a76 | 2020-07-20 13:03:31 -0700 | [diff] [blame] | 38 | rustlibs: [ |
Shaquille Johnson | df83fb7 | 2023-03-24 12:26:52 +0000 | [diff] [blame] | 39 | "android.hardware.security.rkp-V3-rust", |
Jeongik Cha | 9f632c6 | 2021-01-23 09:33:35 +0900 | [diff] [blame] | 40 | "android.hardware.security.secureclock-V1-rust", |
Janis Danisevskis | 84a83e4 | 2021-03-21 21:46:54 -0700 | [diff] [blame] | 41 | "android.hardware.security.sharedsecret-V1-rust", |
Bram Bonné | 5d6c510 | 2021-02-24 15:09:18 +0100 | [diff] [blame] | 42 | "android.os.permissions_aidl-rust", |
Janis Danisevskis | 7a1cf38 | 2020-11-20 11:22:14 -0800 | [diff] [blame] | 43 | "android.security.apc-rust", |
Janis Danisevskis | 9f10a6a | 2021-01-18 16:45:21 +0000 | [diff] [blame] | 44 | "android.security.authorization-rust", |
Joel Galenson | de386b4 | 2020-09-30 10:53:05 -0700 | [diff] [blame] | 45 | "android.security.compat-rust", |
Janis Danisevskis | 34a0cf2 | 2021-03-08 09:19:03 -0800 | [diff] [blame] | 46 | "android.security.maintenance-rust", |
Hasini Gunasinghe | 15891e6 | 2021-06-10 16:23:27 +0000 | [diff] [blame] | 47 | "android.security.metrics-rust", |
Tri Vo | e8f0444 | 2022-12-21 08:53:56 -0800 | [diff] [blame] | 48 | "android.security.rkp_aidl-rust", |
James Willcox | d215da8 | 2023-10-03 21:31:31 +0000 | [diff] [blame] | 49 | "libaconfig_android_hardware_biometrics_rust", |
Eric Biggers | 698922b | 2023-11-02 21:19:42 +0000 | [diff] [blame] | 50 | "libandroid_security_flags_rust", |
Janis Danisevskis | 7d77a76 | 2020-07-20 13:03:31 -0700 | [diff] [blame] | 51 | "libanyhow", |
Janis Danisevskis | e24f347 | 2020-08-12 17:58:49 -0700 | [diff] [blame] | 52 | "libbinder_rs", |
Janis Danisevskis | 212c68b | 2021-01-14 22:29:28 -0800 | [diff] [blame] | 53 | "libkeystore2_aaid-rust", |
Janis Danisevskis | 7a1cf38 | 2020-11-20 11:22:14 -0800 | [diff] [blame] | 54 | "libkeystore2_apc_compat-rust", |
Janis Danisevskis | b42fc18 | 2020-12-15 08:41:27 -0800 | [diff] [blame] | 55 | "libkeystore2_crypto_rust", |
Shaquille Johnson | 7f5a815 | 2023-09-27 18:46:27 +0100 | [diff] [blame] | 56 | "libkeystore2_flags_rust", |
Luca Stefani | 481b5d6 | 2024-01-17 11:42:06 +0100 | [diff] [blame] | 57 | "libkeystore2_hal_names_rust", |
Joel Galenson | de386b4 | 2020-09-30 10:53:05 -0700 | [diff] [blame] | 58 | "libkeystore2_km_compat", |
Janis Danisevskis | ce99543 | 2020-07-21 12:22:34 -0700 | [diff] [blame] | 59 | "libkeystore2_selinux", |
Hasini Gunasinghe | 557b103 | 2020-11-10 01:35:30 +0000 | [diff] [blame] | 60 | "liblibc", |
Janis Danisevskis | 7d77a76 | 2020-07-20 13:03:31 -0700 | [diff] [blame] | 61 | "liblog_rust", |
Alice Wang | e66c331 | 2023-11-07 12:41:42 +0000 | [diff] [blame] | 62 | "libmessage_macro", |
Vikram Gaur | 743f178 | 2024-09-06 05:45:08 +0000 | [diff] [blame^] | 63 | "libpostprocessor_client", |
Joel Galenson | 0891bc1 | 2020-07-20 10:37:03 -0700 | [diff] [blame] | 64 | "librand", |
Alice Wang | 01c16b6 | 2023-11-07 14:27:49 +0000 | [diff] [blame] | 65 | "librkpd_client", |
Joel Galenson | 7ead3a2 | 2021-07-29 15:27:34 -0700 | [diff] [blame] | 66 | "librustutils", |
Max Bires | 48fc2e5 | 2021-11-17 10:13:04 -0800 | [diff] [blame] | 67 | "libserde", |
| 68 | "libserde_cbor", |
Janis Danisevskis | 7d77a76 | 2020-07-20 13:03:31 -0700 | [diff] [blame] | 69 | "libthiserror", |
Tri Vo | 437d014 | 2023-01-18 16:43:49 -0800 | [diff] [blame] | 70 | "libtokio", |
Alice Wang | 83c6aef | 2023-11-03 17:17:34 +0000 | [diff] [blame] | 71 | "libwatchdog_rs", |
Janis Danisevskis | 7d77a76 | 2020-07-20 13:03:31 -0700 | [diff] [blame] | 72 | ], |
Joel Galenson | ba41ca3 | 2020-12-28 14:14:07 -0800 | [diff] [blame] | 73 | shared_libs: [ |
| 74 | "libcutils", |
| 75 | ], |
Janis Danisevskis | 3d5a214 | 2021-05-05 07:31:24 -0700 | [diff] [blame] | 76 | features: [ |
| 77 | "watchdog", |
| 78 | ], |
Janis Danisevskis | 43c8971 | 2020-08-03 23:42:42 +0000 | [diff] [blame] | 79 | } |
| 80 | |
Janis Danisevskis | 2a8330a | 2021-01-20 15:34:26 -0800 | [diff] [blame] | 81 | rust_library { |
Paul Crowley | 7c57bf1 | 2021-02-02 16:26:57 -0800 | [diff] [blame] | 82 | name: "libkeystore2", |
| 83 | defaults: ["libkeystore2_defaults"], |
Jiyong Park | 975906d | 2021-09-30 14:58:39 +0900 | [diff] [blame] | 84 | rustlibs: [ |
| 85 | "liblibsqlite3_sys", |
| 86 | "librusqlite", |
| 87 | ], |
| 88 | } |
| 89 | |
| 90 | rust_library { |
Rajesh Nyamagoud | 69a8505 | 2022-02-17 16:47:55 +0000 | [diff] [blame] | 91 | name: "libkeystore2_with_test_utils", |
| 92 | defaults: ["libkeystore2_defaults"], |
| 93 | features: [ |
| 94 | "keystore2_blob_test_utils", |
| 95 | ], |
| 96 | rustlibs: [ |
Luca Stefani | 481b5d6 | 2024-01-17 11:42:06 +0100 | [diff] [blame] | 97 | "libkeystore2_test_utils", |
Rajesh Nyamagoud | 69a8505 | 2022-02-17 16:47:55 +0000 | [diff] [blame] | 98 | "liblibsqlite3_sys", |
| 99 | "librusqlite", |
Rajesh Nyamagoud | 69a8505 | 2022-02-17 16:47:55 +0000 | [diff] [blame] | 100 | ], |
| 101 | } |
| 102 | |
Janis Danisevskis | a578d39 | 2021-09-20 15:44:06 -0700 | [diff] [blame] | 103 | rust_test { |
Janis Danisevskis | 43c8971 | 2020-08-03 23:42:42 +0000 | [diff] [blame] | 104 | name: "keystore2_test", |
Joel Galenson | 26f4d01 | 2020-07-17 14:57:21 -0700 | [diff] [blame] | 105 | crate_name: "keystore2", |
Joel Galenson | 3f78dd8 | 2021-01-20 16:21:30 -0800 | [diff] [blame] | 106 | test_suites: ["general-tests"], |
| 107 | auto_gen_config: true, |
Janis Danisevskis | 66784c4 | 2021-01-27 08:40:25 -0800 | [diff] [blame] | 108 | compile_multilib: "first", |
Paul Crowley | 7c57bf1 | 2021-02-02 16:26:57 -0800 | [diff] [blame] | 109 | defaults: ["libkeystore2_defaults"], |
Janis Danisevskis | 7d77a76 | 2020-07-20 13:03:31 -0700 | [diff] [blame] | 110 | rustlibs: [ |
| 111 | "libandroid_logger", |
David Drysdale | c0ed986 | 2023-07-05 07:11:39 +0100 | [diff] [blame] | 112 | "libhex", |
Janis Danisevskis | 2a8330a | 2021-01-20 15:34:26 -0800 | [diff] [blame] | 113 | "libkeystore2_test_utils", |
Luca Stefani | 481b5d6 | 2024-01-17 11:42:06 +0100 | [diff] [blame] | 114 | "libkeystore2_with_test_utils", |
Jiyong Park | 975906d | 2021-09-30 14:58:39 +0900 | [diff] [blame] | 115 | "liblibsqlite3_sys", |
Janis Danisevskis | 5cb52dc | 2021-04-07 16:31:18 -0700 | [diff] [blame] | 116 | "libnix", |
Jiyong Park | 975906d | 2021-09-30 14:58:39 +0900 | [diff] [blame] | 117 | "librusqlite", |
David Drysdale | da89743 | 2024-06-24 15:57:35 +0100 | [diff] [blame] | 118 | "libtempfile", |
Janis Danisevskis | 7d77a76 | 2020-07-20 13:03:31 -0700 | [diff] [blame] | 119 | ], |
Janis Danisevskis | 3d5a214 | 2021-05-05 07:31:24 -0700 | [diff] [blame] | 120 | // The test should always include watchdog. |
| 121 | features: [ |
Rajesh Nyamagoud | 69a8505 | 2022-02-17 16:47:55 +0000 | [diff] [blame] | 122 | "keystore2_blob_test_utils", |
Luca Stefani | 481b5d6 | 2024-01-17 11:42:06 +0100 | [diff] [blame] | 123 | "watchdog", |
Janis Danisevskis | 3d5a214 | 2021-05-05 07:31:24 -0700 | [diff] [blame] | 124 | ], |
Tri Vo | 30268da | 2023-01-24 15:35:45 -0800 | [diff] [blame] | 125 | require_root: true, |
Janis Danisevskis | 43c8971 | 2020-08-03 23:42:42 +0000 | [diff] [blame] | 126 | } |
Janis Danisevskis | 652f381 | 2020-08-04 00:01:12 +0000 | [diff] [blame] | 127 | |
Kiyoung Kim | 32034c7 | 2024-10-11 17:08:57 +0900 | [diff] [blame] | 128 | vintf_fragment { |
| 129 | name: "android.system.keystore2-service.xml", |
| 130 | src: "android.system.keystore2-service.xml", |
| 131 | } |
| 132 | |
Jiyong Park | 975906d | 2021-09-30 14:58:39 +0900 | [diff] [blame] | 133 | rust_defaults { |
| 134 | name: "keystore2_defaults", |
Janis Danisevskis | 1af9126 | 2020-08-10 14:58:08 -0700 | [diff] [blame] | 135 | srcs: ["src/keystore2_main.rs"], |
| 136 | rustlibs: [ |
| 137 | "libandroid_logger", |
| 138 | "libbinder_rs", |
Janis Danisevskis | 1af9126 | 2020-08-10 14:58:08 -0700 | [diff] [blame] | 139 | "liblog_rust", |
| 140 | ], |
| 141 | init_rc: ["keystore2.rc"], |
Stephen Crane | 56936e8 | 2021-03-10 17:48:26 -0800 | [diff] [blame] | 142 | |
Matthew Maurer | 3ca82bc | 2021-04-29 13:08:40 -0700 | [diff] [blame] | 143 | // In S, keystore2 is the only process using dynamically linked Rust from |
| 144 | // /system. As a result, the usual savings from sharing libraries don't |
| 145 | // apply. |
| 146 | // Remove `prefer_rlib: true` once we have several processes, once a space |
| 147 | // calculation shows net RAM savings, or once we have automatic variant |
| 148 | // selection available in the build system. |
| 149 | prefer_rlib: true, |
| 150 | |
Kiyoung Kim | 32034c7 | 2024-10-11 17:08:57 +0900 | [diff] [blame] | 151 | vintf_fragment_modules: ["android.system.keystore2-service.xml"], |
Janis Danisevskis | 2cb4f09 | 2021-05-17 13:25:07 -0700 | [diff] [blame] | 152 | |
| 153 | required: ["keystore_cli_v2"], |
Janis Danisevskis | 1af9126 | 2020-08-10 14:58:08 -0700 | [diff] [blame] | 154 | } |
Jiyong Park | 975906d | 2021-09-30 14:58:39 +0900 | [diff] [blame] | 155 | |
| 156 | rust_binary { |
| 157 | name: "keystore2", |
| 158 | defaults: ["keystore2_defaults"], |
| 159 | rustlibs: [ |
| 160 | "libkeystore2", |
| 161 | "liblegacykeystore-rust", |
| 162 | "librusqlite", |
| 163 | ], |
Yi Kong | 3270141 | 2022-01-22 02:53:12 +0800 | [diff] [blame] | 164 | afdo: true, |
Jiyong Park | 975906d | 2021-09-30 14:58:39 +0900 | [diff] [blame] | 165 | } |
Shaquille Johnson | 6a75199 | 2023-09-27 17:08:01 +0100 | [diff] [blame] | 166 | |
| 167 | // Keystore Flag definitions |
| 168 | aconfig_declarations { |
| 169 | name: "keystore2_flags", |
| 170 | package: "android.security.keystore2", |
Oriol Prieto Gasco | 85d84ff | 2024-02-03 02:39:40 +0000 | [diff] [blame] | 171 | container: "system", |
Shaquille Johnson | 6a75199 | 2023-09-27 17:08:01 +0100 | [diff] [blame] | 172 | srcs: ["aconfig/flags.aconfig"], |
| 173 | } |
| 174 | |
Shaquille Johnson | a3f1049 | 2024-06-20 09:53:36 +0000 | [diff] [blame] | 175 | java_aconfig_library { |
| 176 | name: "keystore2_flags_java", |
| 177 | aconfig_declarations: "keystore2_flags", |
| 178 | } |
| 179 | |
Victor Hsieh | b01202d | 2024-10-17 12:05:32 -0700 | [diff] [blame] | 180 | java_aconfig_library { |
| 181 | name: "keystore2_flags_java-host", |
| 182 | aconfig_declarations: "keystore2_flags", |
| 183 | host_supported: true, |
| 184 | } |
| 185 | |
Shaquille Johnson | 6a75199 | 2023-09-27 17:08:01 +0100 | [diff] [blame] | 186 | rust_aconfig_library { |
| 187 | name: "libkeystore2_flags_rust", |
| 188 | crate_name: "keystore2_flags", |
| 189 | aconfig_declarations: "keystore2_flags", |
| 190 | } |
James Willcox | d215da8 | 2023-10-03 21:31:31 +0000 | [diff] [blame] | 191 | |
| 192 | rust_aconfig_library { |
| 193 | name: "libaconfig_android_hardware_biometrics_rust", |
| 194 | crate_name: "aconfig_android_hardware_biometrics_rust", |
| 195 | aconfig_declarations: "android.hardware.biometrics.flags-aconfig", |
| 196 | } |