| /* |
| * Copyright (C) 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. |
| */ |
| |
| |
| #define LOG_TAG "libvintf" |
| |
| #include "RuntimeInfo.h" |
| |
| #include "CompatibilityMatrix.h" |
| #include "parse_string.h" |
| |
| namespace android { |
| namespace vintf { |
| |
| const std::string &RuntimeInfo::osName() const { |
| return mOsName; |
| } |
| |
| const std::string &RuntimeInfo::nodeName() const { |
| return mNodeName; |
| } |
| |
| const std::string &RuntimeInfo::osRelease() const { |
| return mOsRelease; |
| } |
| |
| const std::string &RuntimeInfo::osVersion() const { |
| return mOsVersion; |
| } |
| |
| const std::string &RuntimeInfo::hardwareId() const { |
| return mHardwareId; |
| } |
| |
| size_t RuntimeInfo::kernelSepolicyVersion() const { |
| return mKernelSepolicyVersion; |
| } |
| |
| bool RuntimeInfo::checkCompatibility(const CompatibilityMatrix &mat, |
| std::string *error) const { |
| if (mat.mType != SchemaType::FRAMEWORK) { |
| if (error != nullptr) { |
| *error = "Should not check runtime info against " + to_string(mat.mType) |
| + " compatibility matrix."; |
| } |
| return false; |
| } |
| if (kernelSepolicyVersion() != mat.framework.mSepolicy.kernelSepolicyVersion()) { |
| if (error != nullptr) { |
| *error = "kernelSepolicyVersion = " + to_string(kernelSepolicyVersion()) |
| + " but required " + to_string(mat.framework.mSepolicy.kernelSepolicyVersion()); |
| } |
| return false; |
| } |
| |
| // TODO(b/35217573): check sepolicy version against mat.mSepolicy.sepolicyVersion() here. |
| |
| const MatrixKernel *matrixKernel = mat.findKernel(this->mKernelVersion); |
| if (matrixKernel == nullptr) { |
| if (error != nullptr) { |
| *error = "Cannot find suitable kernel entry for " + to_string(mKernelVersion); |
| } |
| return false; |
| } |
| for (const KernelConfig &matrixConfig : matrixKernel->configs()) { |
| const std::string &key = matrixConfig.first; |
| auto it = this->mKernelConfigs.find(key); |
| if (it == this->mKernelConfigs.end()) { |
| // special case: <value type="tristate">n</value> matches if the config doesn't exist. |
| if (matrixConfig.second == KernelConfigTypedValue::gMissingConfig) { |
| continue; |
| } |
| if (error != nullptr) { |
| *error = "Missing config " + key; |
| } |
| return false; |
| } |
| const std::string &kernelValue = it->second; |
| if (!matrixConfig.second.matchValue(kernelValue)) { |
| if (error != nullptr) { |
| *error = "For config " + key + ", value = " + kernelValue |
| + " but required " + to_string(matrixConfig.second); |
| } |
| return false; |
| } |
| } |
| return true; |
| } |
| |
| } // namespace vintf |
| } // namespace android |