1*789431f2SAndroid Build Coastguard Worker /*
2*789431f2SAndroid Build Coastguard Worker **
3*789431f2SAndroid Build Coastguard Worker ** Copyright 2019, The Android Open Source Project
4*789431f2SAndroid Build Coastguard Worker **
5*789431f2SAndroid Build Coastguard Worker ** Licensed under the Apache License, Version 2.0 (the "License");
6*789431f2SAndroid Build Coastguard Worker ** you may not use this file except in compliance with the License.
7*789431f2SAndroid Build Coastguard Worker ** You may obtain a copy of the License at
8*789431f2SAndroid Build Coastguard Worker **
9*789431f2SAndroid Build Coastguard Worker ** http://www.apache.org/licenses/LICENSE-2.0
10*789431f2SAndroid Build Coastguard Worker **
11*789431f2SAndroid Build Coastguard Worker ** Unless required by applicable law or agreed to in writing, software
12*789431f2SAndroid Build Coastguard Worker ** distributed under the License is distributed on an "AS IS" BASIS,
13*789431f2SAndroid Build Coastguard Worker ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*789431f2SAndroid Build Coastguard Worker ** See the License for the specific language governing permissions and
15*789431f2SAndroid Build Coastguard Worker ** limitations under the License.
16*789431f2SAndroid Build Coastguard Worker */
17*789431f2SAndroid Build Coastguard Worker
18*789431f2SAndroid Build Coastguard Worker #define LOG_TAG "[email protected] ref impl"
19*789431f2SAndroid Build Coastguard Worker #include <log/log.h>
20*789431f2SAndroid Build Coastguard Worker
21*789431f2SAndroid Build Coastguard Worker #include "include/AndroidKeymaster41Device.h"
22*789431f2SAndroid Build Coastguard Worker
23*789431f2SAndroid Build Coastguard Worker #include <keymaster/android_keymaster.h>
24*789431f2SAndroid Build Coastguard Worker
25*789431f2SAndroid Build Coastguard Worker namespace keymaster::V4_1 {
26*789431f2SAndroid Build Coastguard Worker
27*789431f2SAndroid Build Coastguard Worker using V4_0::ng::hidlKeyParams2Km;
28*789431f2SAndroid Build Coastguard Worker
29*789431f2SAndroid Build Coastguard Worker namespace {
30*789431f2SAndroid Build Coastguard Worker
legacy_enum_conversion(const keymaster_error_t value)31*789431f2SAndroid Build Coastguard Worker inline V41ErrorCode legacy_enum_conversion(const keymaster_error_t value) {
32*789431f2SAndroid Build Coastguard Worker return static_cast<V41ErrorCode>(value);
33*789431f2SAndroid Build Coastguard Worker }
34*789431f2SAndroid Build Coastguard Worker
35*789431f2SAndroid Build Coastguard Worker } // namespace
36*789431f2SAndroid Build Coastguard Worker
CreateKeymasterDevice(SecurityLevel securityLevel)37*789431f2SAndroid Build Coastguard Worker IKeymasterDevice* CreateKeymasterDevice(SecurityLevel securityLevel) {
38*789431f2SAndroid Build Coastguard Worker return new (std::nothrow) AndroidKeymaster41Device(securityLevel);
39*789431f2SAndroid Build Coastguard Worker }
40*789431f2SAndroid Build Coastguard Worker
41*789431f2SAndroid Build Coastguard Worker Return<V41ErrorCode>
deviceLocked(bool passwordOnly,const VerificationToken & verificationToken)42*789431f2SAndroid Build Coastguard Worker AndroidKeymaster41Device::deviceLocked(bool passwordOnly,
43*789431f2SAndroid Build Coastguard Worker const VerificationToken& verificationToken) {
44*789431f2SAndroid Build Coastguard Worker keymaster::VerificationToken serializableToken;
45*789431f2SAndroid Build Coastguard Worker serializableToken.challenge = verificationToken.challenge;
46*789431f2SAndroid Build Coastguard Worker serializableToken.timestamp = verificationToken.timestamp;
47*789431f2SAndroid Build Coastguard Worker serializableToken.parameters_verified.Reinitialize(
48*789431f2SAndroid Build Coastguard Worker hidlKeyParams2Km(verificationToken.parametersVerified));
49*789431f2SAndroid Build Coastguard Worker serializableToken.security_level =
50*789431f2SAndroid Build Coastguard Worker static_cast<keymaster_security_level_t>(verificationToken.securityLevel);
51*789431f2SAndroid Build Coastguard Worker serializableToken.mac =
52*789431f2SAndroid Build Coastguard Worker KeymasterBlob(verificationToken.mac.data(), verificationToken.mac.size());
53*789431f2SAndroid Build Coastguard Worker return legacy_enum_conversion(
54*789431f2SAndroid Build Coastguard Worker impl_
55*789431f2SAndroid Build Coastguard Worker ->DeviceLocked(DeviceLockedRequest(impl_->message_version(), passwordOnly,
56*789431f2SAndroid Build Coastguard Worker std::move(serializableToken)))
57*789431f2SAndroid Build Coastguard Worker .error);
58*789431f2SAndroid Build Coastguard Worker }
59*789431f2SAndroid Build Coastguard Worker
earlyBootEnded()60*789431f2SAndroid Build Coastguard Worker Return<V41ErrorCode> AndroidKeymaster41Device::earlyBootEnded() {
61*789431f2SAndroid Build Coastguard Worker return legacy_enum_conversion(impl_->EarlyBootEnded().error);
62*789431f2SAndroid Build Coastguard Worker }
63*789431f2SAndroid Build Coastguard Worker
64*789431f2SAndroid Build Coastguard Worker } // namespace keymaster::V4_1
65