/* ** Copyright 2017, The Android Open Source Project ** ** Licensed under the Apache License, Version 2.0 (the "License"); ** you may not use this file except in compliance with the License. ** You may obtain a copy of the License at ** ** http://www.apache.org/licenses/LICENSE-2.0 ** ** Unless required by applicable law or agreed to in writing, software ** distributed under the License is distributed on an "AS IS" BASIS, ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ** See the License for the specific language governing permissions and ** limitations under the License. */ #pragma once #include #include "Keymaster.h" namespace android::hardware::keymaster::V4_1::support { using IKeymaster3Device = ::android::hardware::keymaster::V3_0::IKeymasterDevice; using ::android::sp; using ::android::hardware::hidl_string; using ::android::hardware::hidl_vec; using ::android::hardware::Return; using ::android::hardware::Void; using ::android::hardware::details::return_status; class Keymaster3 : public Keymaster { public: // This definition is used for device enumeration. using WrappedIKeymasterDevice = IKeymaster3Device; Keymaster3(sp km3_dev, const hidl_string& instanceName) : Keymaster(IKeymaster3Device::descriptor, instanceName), km3_dev_(km3_dev), haveVersion_(false) {} const VersionResult& halVersion() const override { const_cast(this)->getVersionIfNeeded(); return version_; } Return getHardwareInfo(getHardwareInfo_cb _hidl_cb); Return getHmacSharingParameters(getHmacSharingParameters_cb _hidl_cb) override { _hidl_cb(V4_0::ErrorCode::UNIMPLEMENTED, {}); return Void(); } Return computeSharedHmac(const hidl_vec&, computeSharedHmac_cb _hidl_cb) override { _hidl_cb(V4_0::ErrorCode::UNIMPLEMENTED, {}); return Void(); } Return verifyAuthorization(uint64_t, const hidl_vec&, const HardwareAuthToken&, verifyAuthorization_cb _hidl_cb) override { _hidl_cb(V4_0::ErrorCode::UNIMPLEMENTED, {}); return Void(); } Return addRngEntropy(const hidl_vec& data) override; Return generateKey(const hidl_vec& keyParams, generateKey_cb _hidl_cb) override; Return getKeyCharacteristics(const hidl_vec& keyBlob, const hidl_vec& clientId, const hidl_vec& appData, getKeyCharacteristics_cb _hidl_cb) override; Return importKey(const hidl_vec& params, KeyFormat keyFormat, const hidl_vec& keyData, importKey_cb _hidl_cb) override; Return importWrappedKey(const hidl_vec& /* wrappedKeyData */, const hidl_vec& /* wrappingKeyBlob */, const hidl_vec& /* maskingKey */, const hidl_vec& /* unwrappingParams */, uint64_t /* passwordSid */, uint64_t /* biometricSid */, importWrappedKey_cb _hidl_cb) { _hidl_cb(V4_0::ErrorCode::UNIMPLEMENTED, {}, {}); return Void(); } Return exportKey(KeyFormat exportFormat, const hidl_vec& keyBlob, const hidl_vec& clientId, const hidl_vec& appData, exportKey_cb _hidl_cb) override; Return attestKey(const hidl_vec& keyToAttest, const hidl_vec& attestParams, attestKey_cb _hidl_cb) override; Return upgradeKey(const hidl_vec& keyBlobToUpgrade, const hidl_vec& upgradeParams, upgradeKey_cb _hidl_cb) override; Return deleteKey(const hidl_vec& keyBlob) override; Return deleteAllKeys() override; Return destroyAttestationIds() override; Return begin(KeyPurpose purpose, const hidl_vec& key, const hidl_vec& inParams, const HardwareAuthToken& authToken, begin_cb _hidl_cb) override; Return update(uint64_t operationHandle, const hidl_vec& inParams, const hidl_vec& input, const HardwareAuthToken& authToken, const VerificationToken& verificationToken, update_cb _hidl_cb) override; Return finish(uint64_t operationHandle, const hidl_vec& inParams, const hidl_vec& input, const hidl_vec& signature, const HardwareAuthToken& authToken, const VerificationToken& verificationToken, finish_cb _hidl_cb) override; Return abort(uint64_t operationHandle) override; /********************************** * V4_1::IKeymasterDevice methods * *********************************/ Return deviceLocked(bool /* passwordOnly */, const VerificationToken& /* verificationToken */) override { return ErrorCode::UNIMPLEMENTED; } Return earlyBootEnded() override { return ErrorCode::UNIMPLEMENTED; } private: void getVersionIfNeeded(); sp km3_dev_; bool haveVersion_; VersionResult version_; bool supportsSymmetricCryptography_; bool supportsAttestation_; bool supportsAllDigests_; }; } // namespace android::hardware::keymaster::V4_1::support