1 /*
2  * Copyright 2021, 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 #define LOG_TAG "android.hardware.identity-service"
18 
19 #include <android-base/logging.h>
20 #include <android/binder_manager.h>
21 #include <android/binder_process.h>
22 
23 #include "IdentityCredentialStore.h"
24 
25 #include "RemoteSecureHardwareProxy.h"
26 
27 using ::android::sp;
28 using ::android::base::InitLogging;
29 using ::android::base::StderrLogger;
30 
31 using ::aidl::android::hardware::identity::IdentityCredentialStore;
32 using ::android::hardware::identity::RemoteSecureHardwareProxyFactory;
33 using ::android::hardware::identity::SecureHardwareProxyFactory;
34 
main(int,char * argv[])35 int main(int /*argc*/, char* argv[]) {
36   InitLogging(argv, StderrLogger);
37 
38   sp<SecureHardwareProxyFactory> hwProxyFactory =
39       new RemoteSecureHardwareProxyFactory();
40 
41   ABinderProcess_setThreadPoolMaxThreadCount(0);
42   std::shared_ptr<IdentityCredentialStore> store =
43       ndk::SharedRefBase::make<IdentityCredentialStore>(hwProxyFactory);
44 
45   const std::string instance =
46       std::string(IdentityCredentialStore::descriptor) + "/default";
47   binder_status_t status =
48       AServiceManager_addService(store->asBinder().get(), instance.c_str());
49   CHECK_EQ(status, STATUS_OK);
50 
51   ABinderProcess_joinThreadPool();
52   return EXIT_FAILURE;  // should not reach
53 }
54