blob: b3f40317914b9bd0c79ac40cf60d7a5b5d3e24ee [file] [log] [blame]
Yifan Hongccf967b2017-01-18 11:04:19 -08001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17
18#define LOG_TAG "libvintf"
19
Yifan Honga7201e72017-02-17 10:09:59 -080020#include "RuntimeInfo.h"
Yifan Hongccf967b2017-01-18 11:04:19 -080021
Yifan Hongc66ad1e2017-02-08 20:19:45 -080022#include "CompatibilityMatrix.h"
23#include "parse_string.h"
24
Yifan Hongccf967b2017-01-18 11:04:19 -080025namespace android {
26namespace vintf {
27
Yifan Honga7201e72017-02-17 10:09:59 -080028const std::string &RuntimeInfo::osName() const {
Yifan Hongccf967b2017-01-18 11:04:19 -080029 return mOsName;
30}
31
Yifan Honga7201e72017-02-17 10:09:59 -080032const std::string &RuntimeInfo::nodeName() const {
Yifan Hongccf967b2017-01-18 11:04:19 -080033 return mNodeName;
34}
35
Yifan Honga7201e72017-02-17 10:09:59 -080036const std::string &RuntimeInfo::osRelease() const {
Yifan Hongccf967b2017-01-18 11:04:19 -080037 return mOsRelease;
38}
39
Yifan Honga7201e72017-02-17 10:09:59 -080040const std::string &RuntimeInfo::osVersion() const {
Yifan Hongccf967b2017-01-18 11:04:19 -080041 return mOsVersion;
42}
43
Yifan Honga7201e72017-02-17 10:09:59 -080044const std::string &RuntimeInfo::hardwareId() const {
Yifan Hongccf967b2017-01-18 11:04:19 -080045 return mHardwareId;
46}
47
Yifan Hongfa2b18b2017-04-12 19:40:00 -070048const std::vector<std::string> &RuntimeInfo::sepolicyFilePaths() const {
49 return mSepolicyFilePaths;
50}
51
Yifan Honga7201e72017-02-17 10:09:59 -080052size_t RuntimeInfo::kernelSepolicyVersion() const {
Yifan Hongccf967b2017-01-18 11:04:19 -080053 return mKernelSepolicyVersion;
54}
55
Yifan Hong242eabf2017-04-20 14:06:26 -070056const std::string &RuntimeInfo::cpuInfo() const {
57 return mCpuInfo;
58}
59
Yifan Honga7201e72017-02-17 10:09:59 -080060bool RuntimeInfo::checkCompatibility(const CompatibilityMatrix &mat,
Yifan Hongc66ad1e2017-02-08 20:19:45 -080061 std::string *error) const {
Yifan Hong7c7d7062017-04-04 16:26:51 -070062 if (mat.mType != SchemaType::FRAMEWORK) {
63 if (error != nullptr) {
64 *error = "Should not check runtime info against " + to_string(mat.mType)
65 + " compatibility matrix.";
66 }
67 return false;
68 }
69 if (kernelSepolicyVersion() != mat.framework.mSepolicy.kernelSepolicyVersion()) {
Yifan Hongc66ad1e2017-02-08 20:19:45 -080070 if (error != nullptr) {
71 *error = "kernelSepolicyVersion = " + to_string(kernelSepolicyVersion())
Yifan Hong7c7d7062017-04-04 16:26:51 -070072 + " but required " + to_string(mat.framework.mSepolicy.kernelSepolicyVersion());
Yifan Hongc66ad1e2017-02-08 20:19:45 -080073 }
74 return false;
75 }
76
Yifan Hongf3029302017-04-12 17:23:49 -070077 // mat.mSepolicy.sepolicyVersion() is checked against static HalManifest.device.mSepolicyVersion
Yifan Hongc66ad1e2017-02-08 20:19:45 -080078
79 const MatrixKernel *matrixKernel = mat.findKernel(this->mKernelVersion);
80 if (matrixKernel == nullptr) {
81 if (error != nullptr) {
82 *error = "Cannot find suitable kernel entry for " + to_string(mKernelVersion);
83 }
84 return false;
85 }
86 for (const KernelConfig &matrixConfig : matrixKernel->configs()) {
87 const std::string &key = matrixConfig.first;
Yifan Hongf1af7522017-02-16 18:00:55 -080088 auto it = this->mKernelConfigs.find(key);
89 if (it == this->mKernelConfigs.end()) {
Yifan Hongc66ad1e2017-02-08 20:19:45 -080090 // special case: <value type="tristate">n</value> matches if the config doesn't exist.
91 if (matrixConfig.second == KernelConfigTypedValue::gMissingConfig) {
92 continue;
93 }
94 if (error != nullptr) {
95 *error = "Missing config " + key;
96 }
97 return false;
98 }
99 const std::string &kernelValue = it->second;
100 if (!matrixConfig.second.matchValue(kernelValue)) {
101 if (error != nullptr) {
102 *error = "For config " + key + ", value = " + kernelValue
103 + " but required " + to_string(matrixConfig.second);
104 }
105 return false;
106 }
107 }
Yifan Hongf3029302017-04-12 17:23:49 -0700108
109 const Version &matAvb = mat.framework.mAvbMetaVersion;
110 if (mAvbBootVersion.majorVer != matAvb.majorVer ||
111 mAvbBootVersion.minorVer < matAvb.minorVer ||
112 mAvbInitVersion.majorVer != matAvb.majorVer ||
113 mAvbInitVersion.minorVer < matAvb.minorVer) {
114 return false;
115 }
116
Yifan Hongc66ad1e2017-02-08 20:19:45 -0800117 return true;
118}
119
Yifan Hongccf967b2017-01-18 11:04:19 -0800120} // namespace vintf
121} // namespace android