xref: /aosp_15_r20/system/keymaster/ng/AndroidKeymaster41Device.cpp (revision 789431f29546679ab5188a97751fb38e3018d44d)
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