blob: fac001747446a7e198d1060af5a07fe544b060a9 [file] [log] [blame]
Shawn Willden98b998b2018-01-20 11:48:53 -07001/*
2 ** Copyright 2018, 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 <keymasterV4_0/Keymaster.h>
18
19#include <android-base/logging.h>
20#include <android/hidl/manager/1.0/IServiceManager.h>
21#include <keymasterV4_0/Keymaster3.h>
22#include <keymasterV4_0/Keymaster4.h>
23
24namespace android {
25namespace hardware {
26namespace keymaster {
27namespace V4_0 {
28namespace support {
29
30using ::android::sp;
31using ::android::hidl::manager::V1_0::IServiceManager;
32
33template <typename Wrapper>
34std::vector<std::unique_ptr<Keymaster>> enumerateDevices(
35 const sp<IServiceManager>& serviceManager) {
36 std::vector<std::unique_ptr<Keymaster>> result;
37
38 bool foundDefault = false;
39 auto& descriptor = Wrapper::WrappedIKeymasterDevice::descriptor;
40 serviceManager->listByInterface(descriptor, [&](const hidl_vec<hidl_string>& names) {
41 for (auto& name : names) {
42 if (name == "default") foundDefault = true;
nagendra modadugu9c36c912018-03-30 17:07:55 -070043 auto device = Wrapper::WrappedIKeymasterDevice::getService(name);
Shawn Willden98b998b2018-01-20 11:48:53 -070044 CHECK(device) << "Failed to get service for " << descriptor << " with interface name "
45 << name;
46 result.push_back(std::unique_ptr<Keymaster>(new Wrapper(device, name)));
47 }
48 });
49
50 if (!foundDefault) {
51 // "default" wasn't provided by listByInterface. Maybe there's a passthrough
52 // implementation.
53 auto device = Wrapper::WrappedIKeymasterDevice::getService("default");
54 if (device) result.push_back(std::unique_ptr<Keymaster>(new Wrapper(device, "default")));
55 }
56
57 return result;
58}
59
60std::vector<std::unique_ptr<Keymaster>> Keymaster::enumerateAvailableDevices() {
61 auto serviceManager = IServiceManager::getService();
62 CHECK(serviceManager) << "Could not retrieve ServiceManager";
63
64 auto km4s = enumerateDevices<Keymaster4>(serviceManager);
65 auto km3s = enumerateDevices<Keymaster3>(serviceManager);
66
67 auto result = std::move(km4s);
68 result.insert(result.end(), std::make_move_iterator(km3s.begin()),
69 std::make_move_iterator(km3s.end()));
70
71 std::sort(result.begin(), result.end(),
72 [](auto& a, auto& b) { return a->halVersion() > b->halVersion(); });
73
74 size_t i = 1;
75 LOG(INFO) << "List of Keymaster HALs found:";
76 for (auto& hal : result) {
77 auto& version = hal->halVersion();
78 LOG(INFO) << "Keymaster HAL #" << i << ": " << version.keymasterName << " from "
79 << version.authorName << " SecurityLevel: " << toString(version.securityLevel)
80 << " HAL : " << hal->descriptor() << " instance " << hal->instanceName();
81 }
82
83 return result;
84}
85
86} // namespace support
87} // namespace V4_0
88} // namespace keymaster
89} // namespace hardware
90}; // namespace android