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