| /* |
| * Copyright (C) 2017 The Android Open Source Project |
| * |
| * SPDX-License-Identifier: Apache-2.0 |
| */ |
| |
| #define LOG_TAG "android.hardware.biometrics.fingerprint@2.1-service.RM6785" |
| |
| #include <android-base/logging.h> |
| #include <hidl/HidlTransportSupport.h> |
| |
| #include "BiometricsFingerprint.h" |
| |
| using android::hardware::biometrics::fingerprint::V2_1::IBiometricsFingerprint; |
| using android::hardware::biometrics::fingerprint::V2_1::implementation::BiometricsFingerprint; |
| using android::hardware::configureRpcThreadpool; |
| using android::hardware::joinRpcThreadpool; |
| using android::OK; |
| using android::sp; |
| using android::status_t; |
| |
| int main() { |
| sp<BiometricsFingerprint> biometricsFingerprint; |
| status_t status; |
| |
| LOG(INFO) << "Fingerprint HAL Adapter service is starting."; |
| |
| biometricsFingerprint = new BiometricsFingerprint(); |
| if (biometricsFingerprint == nullptr) { |
| LOG(ERROR) << "Can not create an instance of Fingerprint HAL Adapter BiometricsFingerprint Iface, exiting."; |
| goto shutdown; |
| } |
| |
| configureRpcThreadpool(1, true /*callerWillJoin*/); |
| |
| status = biometricsFingerprint->registerAsService(); |
| if (status != OK) { |
| LOG(ERROR) << "Could not register service for Fingerprint HAL Adapter BiometricsFingerprint Iface (" |
| << status << ")"; |
| goto shutdown; |
| } |
| |
| LOG(INFO) << "Fingerprint HAL Adapter service is ready."; |
| joinRpcThreadpool(); |
| // Should not pass this line |
| |
| shutdown: |
| // In normal operation, we don't expect the thread pool to shutdown |
| LOG(ERROR) << "Fingerprint HAL Adapter service is shutting down."; |
| return 1; |
| } |