blob: 3edfb533cafb2bf75d464f81cab6c5bebdfeb9c0 [file] [log] [blame]
/*
**
** 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.
*/
#include "Keymaster4.h"
#include <android-base/logging.h>
namespace keystore {
void Keymaster4::getVersionIfNeeded() {
if (haveVersion_) return;
auto rc = dev_->getHardwareInfo([&](SecurityLevel securityLevel, auto...) {
securityLevel_ = securityLevel;
haveVersion_ = true;
});
CHECK(rc.isOk()) << "Got error " << rc.description() << " trying to get hardware info";
}
Keymaster::VersionResult Keymaster4::halVersion() {
getVersionIfNeeded();
return {ErrorCode::OK, halMajorVersion(), securityLevel_, true};
}
} // namespace keystore