blob: 6d39e12c003a0c9dc10f7e8752a7529870f509c6 [file] [log] [blame]
Ilya Matyukhina9a3c852020-08-18 03:09:41 -07001/*
2 * Copyright (C) 2020 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#include "Fingerprint.h"
18#include "Session.h"
19
Jeff Pudef5b042023-05-25 14:28:16 -040020#include <android-base/properties.h>
Jeff Pu52653182022-10-12 16:27:23 -040021#include <fingerprint.sysprop.h>
22
23#include <android-base/file.h>
Joe Bolingerde94aa02021-12-09 17:00:32 -080024#include <android-base/logging.h>
Jeff Pu52653182022-10-12 16:27:23 -040025#include <android-base/stringprintf.h>
Joe Bolingerde94aa02021-12-09 17:00:32 -080026
27using namespace ::android::fingerprint::virt;
28
Ilya Matyukhina9a3c852020-08-18 03:09:41 -070029namespace aidl::android::hardware::biometrics::fingerprint {
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080030namespace {
Ilya Matyukhin48ff8962021-02-22 13:13:13 -080031constexpr size_t MAX_WORKER_QUEUE_SIZE = 5;
Jeff Pu63f33c72022-07-28 16:06:23 -040032constexpr int SENSOR_ID = 5;
Kevin Chyn0ec2e0c2021-03-26 18:07:24 -070033constexpr common::SensorStrength SENSOR_STRENGTH = common::SensorStrength::STRONG;
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080034constexpr int MAX_ENROLLMENTS_PER_USER = 5;
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080035constexpr bool SUPPORTS_NAVIGATION_GESTURES = true;
Haining Chen48618552021-03-14 17:30:09 -070036constexpr char HW_COMPONENT_ID[] = "fingerprintSensor";
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080037constexpr char HW_VERSION[] = "vendor/model/revision";
Haining Chen48618552021-03-14 17:30:09 -070038constexpr char FW_VERSION[] = "1.01";
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080039constexpr char SERIAL_NUMBER[] = "00000001";
Haining Chen48618552021-03-14 17:30:09 -070040constexpr char SW_COMPONENT_ID[] = "matchingAlgorithm";
41constexpr char SW_VERSION[] = "vendor/version/revision";
Kevin Chyn7d3fdf52020-09-15 13:01:40 -070042
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080043} // namespace
Kevin Chync306b762020-09-17 12:40:09 -070044
Jeff Pu63f33c72022-07-28 16:06:23 -040045Fingerprint::Fingerprint() : mWorker(MAX_WORKER_QUEUE_SIZE) {
Jeff Pu6ccd9562024-02-21 10:46:35 -050046 std::string sensorTypeProp = Fingerprint::cfg().get<std::string>("type");
Jeff Pu63f33c72022-07-28 16:06:23 -040047 if (sensorTypeProp == "" || sensorTypeProp == "default" || sensorTypeProp == "rear") {
48 mSensorType = FingerprintSensorType::REAR;
49 mEngine = std::make_unique<FakeFingerprintEngineRear>();
50 } else if (sensorTypeProp == "udfps") {
51 mSensorType = FingerprintSensorType::UNDER_DISPLAY_OPTICAL;
52 mEngine = std::make_unique<FakeFingerprintEngineUdfps>();
Jeff Pu0b8ea042024-12-19 21:11:16 +000053 } else if (sensorTypeProp == "udfps-us") {
54 mSensorType = FingerprintSensorType::UNDER_DISPLAY_ULTRASONIC;
55 mEngine = std::make_unique<FakeFingerprintEngineUdfps>();
Jeff Pu63f33c72022-07-28 16:06:23 -040056 } else if (sensorTypeProp == "side") {
57 mSensorType = FingerprintSensorType::POWER_BUTTON;
58 mEngine = std::make_unique<FakeFingerprintEngineSide>();
59 } else {
60 mSensorType = FingerprintSensorType::UNKNOWN;
61 mEngine = std::make_unique<FakeFingerprintEngineRear>();
62 UNIMPLEMENTED(FATAL) << "unrecognized or unimplemented fingerprint behavior: "
63 << sensorTypeProp;
64 }
65 LOG(INFO) << "sensorTypeProp:" << sensorTypeProp;
Jeff Pudef5b042023-05-25 14:28:16 -040066 LOG(INFO) << "ro.product.name=" << ::android::base::GetProperty("ro.product.name", "UNKNOWN");
Jeff Pu63f33c72022-07-28 16:06:23 -040067}
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080068
69ndk::ScopedAStatus Fingerprint::getSensorProps(std::vector<SensorProps>* out) {
Haining Chen48618552021-03-14 17:30:09 -070070 std::vector<common::ComponentInfo> componentInfo = {
71 {HW_COMPONENT_ID, HW_VERSION, FW_VERSION, SERIAL_NUMBER, "" /* softwareVersion */},
72 {SW_COMPONENT_ID, "" /* hardwareVersion */, "" /* firmwareVersion */,
73 "" /* serialNumber */, SW_VERSION}};
Jeff Pu6ccd9562024-02-21 10:46:35 -050074 auto sensorId = Fingerprint::cfg().get<std::int32_t>("sensor_id");
75 auto sensorStrength = Fingerprint::cfg().get<std::int32_t>("sensor_strength");
76 auto maxEnrollments = Fingerprint::cfg().get<std::int32_t>("max_enrollments");
Jeff Pu4facadf2025-01-02 21:24:35 +000077 auto navigationGesture = Fingerprint::cfg().get<bool>("navigation_gesture");
Jeff Pu6ccd9562024-02-21 10:46:35 -050078 auto detectInteraction = Fingerprint::cfg().get<bool>("detect_interaction");
79 auto displayTouch = Fingerprint::cfg().get<bool>("display_touch");
80 auto controlIllumination = Fingerprint::cfg().get<bool>("control_illumination");
Jeff Pu343ca942022-09-14 15:56:30 -040081
82 common::CommonProps commonProps = {sensorId, (common::SensorStrength)sensorStrength,
83 maxEnrollments, componentInfo};
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080084
Jeff Pu4facadf2025-01-02 21:24:35 +000085 std::vector<SensorLocation> sensorLocation;
86 mEngine->getSensorLocation(sensorLocation);
87 LOG(INFO) << "sensor type:" << ::android::internal::ToString(mSensorType);
88 for (auto location : sensorLocation) {
89 LOG(INFO) << "sensor location: " << location.toString();
90 }
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080091
Jeff Pu4facadf2025-01-02 21:24:35 +000092 *out = {{commonProps, mSensorType, sensorLocation, navigationGesture, detectInteraction,
93 displayTouch, controlIllumination, std::nullopt}};
Ilya Matyukhina9a3c852020-08-18 03:09:41 -070094 return ndk::ScopedAStatus::ok();
95}
96
Ilya Matyukhin48ff8962021-02-22 13:13:13 -080097ndk::ScopedAStatus Fingerprint::createSession(int32_t sensorId, int32_t userId,
Ilya Matyukhina9a3c852020-08-18 03:09:41 -070098 const std::shared_ptr<ISessionCallback>& cb,
Ilya Matyukhin124e70a2021-02-12 13:00:15 -080099 std::shared_ptr<ISession>* out) {
Ilya Matyukhinc605e0b2021-02-25 16:04:34 -0800100 CHECK(mSession == nullptr || mSession->isClosed()) << "Open session already exists!";
Ilya Matyukhin48ff8962021-02-22 13:13:13 -0800101
Ilya Matyukhinc605e0b2021-02-25 16:04:34 -0800102 mSession = SharedRefBase::make<Session>(sensorId, userId, cb, mEngine.get(), &mWorker);
103 *out = mSession;
Jeff Pu63f33c72022-07-28 16:06:23 -0400104
Jeff Pu87e9f2b2023-05-03 17:59:21 +0000105 mSession->linkToDeath(cb->asBinder().get());
106
Jeff Pudef5b042023-05-25 14:28:16 -0400107 LOG(INFO) << __func__ << ": sensorId:" << sensorId << " userId:" << userId;
Ilya Matyukhina9a3c852020-08-18 03:09:41 -0700108 return ndk::ScopedAStatus::ok();
109}
Ilya Matyukhin71005c52021-02-17 12:44:14 -0800110
Jeff Pu52653182022-10-12 16:27:23 -0400111binder_status_t Fingerprint::dump(int fd, const char** /*args*/, uint32_t numArgs) {
112 if (fd < 0) {
Jeff Pudef5b042023-05-25 14:28:16 -0400113 LOG(ERROR) << __func__ << "fd invalid: " << fd;
Jeff Pu52653182022-10-12 16:27:23 -0400114 return STATUS_BAD_VALUE;
115 } else {
Jeff Pudef5b042023-05-25 14:28:16 -0400116 LOG(INFO) << __func__ << " fd:" << fd << "numArgs:" << numArgs;
Jeff Pu52653182022-10-12 16:27:23 -0400117 }
118
119 dprintf(fd, "----- FingerprintVirtualHal::dump -----\n");
120 std::vector<SensorProps> sps(1);
121 getSensorProps(&sps);
122 for (auto& sp : sps) {
123 ::android::base::WriteStringToFd(sp.toString(), fd);
124 }
125 ::android::base::WriteStringToFd(mEngine->toString(), fd);
126
Jeff Pueda68e42024-04-10 15:47:59 -0400127 ::android::base::WriteStringToFd(Fingerprint::cfg().toString(), fd);
128
Jeff Pu52653182022-10-12 16:27:23 -0400129 fsync(fd);
130 return STATUS_OK;
131}
132
133binder_status_t Fingerprint::handleShellCommand(int in, int out, int err, const char** args,
134 uint32_t numArgs) {
Jeff Pudef5b042023-05-25 14:28:16 -0400135 LOG(INFO) << __func__ << " in:" << in << " out:" << out << " err:" << err
Jeff Pu52653182022-10-12 16:27:23 -0400136 << " numArgs:" << numArgs;
137
138 if (numArgs == 0) {
Jeff Pudef5b042023-05-25 14:28:16 -0400139 LOG(INFO) << __func__ << ": available commands";
Jeff Pu52653182022-10-12 16:27:23 -0400140 onHelp(out);
141 return STATUS_OK;
142 }
143
144 for (auto&& str : std::vector<std::string_view>(args, args + numArgs)) {
145 std::string option = str.data();
146 if (option.find("clearconfig") != std::string::npos ||
147 option.find("resetconfig") != std::string::npos) {
148 resetConfigToDefault();
149 }
150 if (option.find("help") != std::string::npos) {
151 onHelp(out);
152 }
153 }
154
155 return STATUS_OK;
156}
157
158void Fingerprint::onHelp(int fd) {
159 dprintf(fd, "Virtual HAL commands:\n");
160 dprintf(fd, " help: print this help\n");
161 dprintf(fd, " resetconfig: reset all configuration to default\n");
162 dprintf(fd, "\n");
163 fsync(fd);
164}
165
166void Fingerprint::resetConfigToDefault() {
Jeff Pudef5b042023-05-25 14:28:16 -0400167 LOG(INFO) << __func__ << ": reset virtual HAL configuration to default";
Jeff Pu6ccd9562024-02-21 10:46:35 -0500168 Fingerprint::cfg().init();
169#ifdef FPS_DEBUGGABLE
170 clearConfigSysprop();
171#endif
172}
173
174void Fingerprint::clearConfigSysprop() {
Jeff Pudf81c962024-03-06 10:58:17 -0500175 LOG(INFO) << __func__ << ": clear all sysprop configuration";
Jeff Pu52653182022-10-12 16:27:23 -0400176#define RESET_CONFIG_O(__NAME__) \
177 if (FingerprintHalProperties::__NAME__()) FingerprintHalProperties::__NAME__(std::nullopt)
178#define RESET_CONFIG_V(__NAME__) \
179 if (!FingerprintHalProperties::__NAME__().empty()) \
180 FingerprintHalProperties::__NAME__({std::nullopt})
181
182 RESET_CONFIG_O(type);
183 RESET_CONFIG_V(enrollments);
184 RESET_CONFIG_O(enrollment_hit);
185 RESET_CONFIG_O(authenticator_id);
186 RESET_CONFIG_O(challenge);
187 RESET_CONFIG_O(lockout);
188 RESET_CONFIG_O(operation_authenticate_fails);
189 RESET_CONFIG_O(operation_detect_interaction_error);
190 RESET_CONFIG_O(operation_enroll_error);
191 RESET_CONFIG_V(operation_authenticate_latency);
192 RESET_CONFIG_V(operation_detect_interaction_latency);
193 RESET_CONFIG_V(operation_enroll_latency);
194 RESET_CONFIG_O(operation_authenticate_duration);
195 RESET_CONFIG_O(operation_authenticate_error);
196 RESET_CONFIG_O(sensor_location);
197 RESET_CONFIG_O(operation_authenticate_acquired);
198 RESET_CONFIG_O(operation_detect_interaction_duration);
199 RESET_CONFIG_O(operation_detect_interaction_acquired);
200 RESET_CONFIG_O(sensor_id);
201 RESET_CONFIG_O(sensor_strength);
202 RESET_CONFIG_O(max_enrollments);
Jeff Pu4facadf2025-01-02 21:24:35 +0000203 RESET_CONFIG_O(navigation_gesture);
Jeff Pu52653182022-10-12 16:27:23 -0400204 RESET_CONFIG_O(detect_interaction);
205 RESET_CONFIG_O(display_touch);
206 RESET_CONFIG_O(control_illumination);
207 RESET_CONFIG_O(lockout_enable);
208 RESET_CONFIG_O(lockout_timed_threshold);
209 RESET_CONFIG_O(lockout_timed_duration);
210 RESET_CONFIG_O(lockout_permanent_threshold);
211}
212
Jeff Pudf81c962024-03-06 10:58:17 -0500213const char* Fingerprint::type2String(FingerprintSensorType type) {
214 switch (type) {
215 case FingerprintSensorType::REAR:
216 return "rear";
217 case FingerprintSensorType::POWER_BUTTON:
218 return "side";
219 case FingerprintSensorType::UNDER_DISPLAY_OPTICAL:
220 return "udfps";
221 case FingerprintSensorType::UNDER_DISPLAY_ULTRASONIC:
Jeff Pu0b8ea042024-12-19 21:11:16 +0000222 return "udfps-us";
Jeff Pudf81c962024-03-06 10:58:17 -0500223 default:
224 return "unknown";
225 }
226}
227
Ilya Matyukhina9a3c852020-08-18 03:09:41 -0700228} // namespace aidl::android::hardware::biometrics::fingerprint