1*789431f2SAndroid Build Coastguard Worker /* 2*789431f2SAndroid Build Coastguard Worker * Copyright 2020, The Android Open Source Project 3*789431f2SAndroid Build Coastguard Worker * 4*789431f2SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*789431f2SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*789431f2SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*789431f2SAndroid Build Coastguard Worker * 8*789431f2SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*789431f2SAndroid Build Coastguard Worker * 10*789431f2SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*789431f2SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*789431f2SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*789431f2SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*789431f2SAndroid Build Coastguard Worker * limitations under the License. 15*789431f2SAndroid Build Coastguard Worker */ 16*789431f2SAndroid Build Coastguard Worker 17*789431f2SAndroid Build Coastguard Worker #define LOG_TAG "android.hardware.security.secureclock-impl" 18*789431f2SAndroid Build Coastguard Worker #include <log/log.h> 19*789431f2SAndroid Build Coastguard Worker 20*789431f2SAndroid Build Coastguard Worker #include "AndroidSecureClock.h" 21*789431f2SAndroid Build Coastguard Worker 22*789431f2SAndroid Build Coastguard Worker #include <aidl/android/hardware/security/keymint/ErrorCode.h> 23*789431f2SAndroid Build Coastguard Worker 24*789431f2SAndroid Build Coastguard Worker #include "KeyMintUtils.h" 25*789431f2SAndroid Build Coastguard Worker #include <keymaster/android_keymaster.h> 26*789431f2SAndroid Build Coastguard Worker #include <keymaster/keymaster_configuration.h> 27*789431f2SAndroid Build Coastguard Worker 28*789431f2SAndroid Build Coastguard Worker namespace aidl::android::hardware::security::secureclock { 29*789431f2SAndroid Build Coastguard Worker 30*789431f2SAndroid Build Coastguard Worker using keymaster::GenerateTimestampTokenRequest; 31*789431f2SAndroid Build Coastguard Worker using keymaster::GenerateTimestampTokenResponse; 32*789431f2SAndroid Build Coastguard Worker using keymint::km_utils::kmBlob2vector; 33*789431f2SAndroid Build Coastguard Worker using keymint::km_utils::kmError2ScopedAStatus; 34*789431f2SAndroid Build Coastguard Worker AndroidSecureClock(const std::shared_ptr<keymint::AndroidKeyMintDevice> & keymint)35*789431f2SAndroid Build Coastguard WorkerAndroidSecureClock::AndroidSecureClock( 36*789431f2SAndroid Build Coastguard Worker const std::shared_ptr<keymint::AndroidKeyMintDevice>& keymint) 37*789431f2SAndroid Build Coastguard Worker : impl_(keymint->getKeymasterImpl()) {} 38*789431f2SAndroid Build Coastguard Worker ~AndroidSecureClock()39*789431f2SAndroid Build Coastguard WorkerAndroidSecureClock::~AndroidSecureClock() {} 40*789431f2SAndroid Build Coastguard Worker generateTimeStamp(int64_t challenge,TimeStampToken * token)41*789431f2SAndroid Build Coastguard WorkerScopedAStatus AndroidSecureClock::generateTimeStamp(int64_t challenge, TimeStampToken* token) { 42*789431f2SAndroid Build Coastguard Worker GenerateTimestampTokenRequest request(impl_->message_version()); 43*789431f2SAndroid Build Coastguard Worker request.challenge = challenge; 44*789431f2SAndroid Build Coastguard Worker GenerateTimestampTokenResponse response(request.message_version); 45*789431f2SAndroid Build Coastguard Worker impl_->GenerateTimestampToken(request, &response); 46*789431f2SAndroid Build Coastguard Worker if (response.error != KM_ERROR_OK) { 47*789431f2SAndroid Build Coastguard Worker return kmError2ScopedAStatus(response.error); 48*789431f2SAndroid Build Coastguard Worker } 49*789431f2SAndroid Build Coastguard Worker token->challenge = response.token.challenge; 50*789431f2SAndroid Build Coastguard Worker token->timestamp.milliSeconds = static_cast<int64_t>(response.token.timestamp); 51*789431f2SAndroid Build Coastguard Worker token->mac = kmBlob2vector(response.token.mac); 52*789431f2SAndroid Build Coastguard Worker return ScopedAStatus::ok(); 53*789431f2SAndroid Build Coastguard Worker } 54*789431f2SAndroid Build Coastguard Worker 55*789431f2SAndroid Build Coastguard Worker } // namespace aidl::android::hardware::security::secureclock 56