123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173 |
- /*
- * 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.
- */
- #ifndef ANDROID_VINTF_COMPATIBILITY_MATRIX_H
- #define ANDROID_VINTF_COMPATIBILITY_MATRIX_H
- #include <map>
- #include <memory>
- #include <string>
- #include <utils/Errors.h>
- #include "FileSystem.h"
- #include "HalGroup.h"
- #include "Level.h"
- #include "MapValueIterator.h"
- #include "MatrixHal.h"
- #include "MatrixInstance.h"
- #include "MatrixKernel.h"
- #include "Named.h"
- #include "SchemaType.h"
- #include "Sepolicy.h"
- #include "SystemSdk.h"
- #include "VendorNdk.h"
- #include "Vndk.h"
- #include "XmlFileGroup.h"
- namespace android {
- namespace vintf {
- // Compatibility matrix defines what hardware does the framework requires.
- struct CompatibilityMatrix : public HalGroup<MatrixHal>, public XmlFileGroup<MatrixXmlFile> {
- // Create a framework compatibility matrix.
- CompatibilityMatrix() : mType(SchemaType::FRAMEWORK) {}
- SchemaType type() const;
- Level level() const;
- Version getMinimumMetaVersion() const;
- // If the corresponding <xmlfile> with the given version exists, for the first match,
- // - Return the overridden <path> if it is present,
- // - otherwise the default value: /{system,vendor}/etc/<name>_V<major>_<minor-max>.<format>
- // Otherwise if the <xmlfile> entry does not exist, "" is returned.
- // For example, if the matrix says ["[email protected]" -> "foo.xml", "[email protected]" -> bar.xml]
- // getXmlSchemaPath("audio", 1.0) -> foo.xml
- // getXmlSchemaPath("audio", 1.5) -> foo.xml
- // getXmlSchemaPath("audio", 1.7) -> bar.xml
- // (Normally, version ranges do not overlap, and the only match is returned.)
- std::string getXmlSchemaPath(const std::string& xmlFileName, const Version& version) const;
- bool forEachInstanceOfVersion(
- const std::string& package, const Version& expectVersion,
- const std::function<bool(const MatrixInstance&)>& func) const override;
- std::string getVendorNdkVersion() const;
- private:
- // Add everything in inputMatrix to "this" as requirements.
- bool addAll(Named<CompatibilityMatrix>* inputMatrix, std::string* error);
- // Add all <kernel> from other to "this". Error if there is a conflict.
- bool addAllKernels(CompatibilityMatrix* other, std::string* error);
- // Add a <kernel> tag to "this". Error if there is a conflict.
- bool addKernel(MatrixKernel&& kernel, std::string* error);
- // Merge <sepolicy> with other's <sepolicy>. Error if there is a conflict.
- bool addSepolicy(CompatibilityMatrix* other, std::string* error);
- // Merge <avb><vbmeta-version> with other's <avb><vbmeta-version>. Error if there is a conflict.
- bool addAvbMetaVersion(CompatibilityMatrix* other, std::string* error);
- // Merge <vndk> with other's <vndk>. Error if there is a conflict.
- bool addVndk(CompatibilityMatrix* other, std::string* error);
- // Merge <vendor-ndk> with other's <vendor-ndk>. Error if there is a conflict.
- bool addVendorNdk(CompatibilityMatrix* other, std::string* error);
- // Merge <system-sdk> with other's <system-sdk>.
- bool addSystemSdk(CompatibilityMatrix* other, std::string* error);
- // Add everything in inputMatrix to "this" as optional.
- bool addAllAsOptional(Named<CompatibilityMatrix>* inputMatrix, std::string* error);
- // Add all HALs as optional HALs from "other". This function moves MatrixHal objects
- // from "other".
- // Require other->level() > this->level(), otherwise do nothing.
- bool addAllHalsAsOptional(CompatibilityMatrix* other, std::string* error);
- // Similar to addAllHalsAsOptional but on <xmlfile> entries.
- bool addAllXmlFilesAsOptional(CompatibilityMatrix* other, std::string* error);
- // Similar to addAllHalsAsOptional but on <kernel> entries.
- bool addAllKernelsAsOptional(CompatibilityMatrix* other, std::string* error);
- // Combine a set of framework compatibility matrices. For each CompatibilityMatrix in matrices
- // (in the order of level(), where UNSPECIFIED (empty) is treated as deviceLevel)
- // - If level() < deviceLevel, ignore
- // - If level() == UNSPECIFIED or level() == deviceLevel,
- // - Add as hard requirements. See combineSameFcmVersion
- // - If level() > deviceLevel,
- // - all <hal> versions and <xmlfile>s are added as optional.
- // - <kernel minlts="x.y.z"> is added only if x.y does not exist in a file
- // with lower level()
- // - <sepolicy>, <avb><vbmeta-version> is ignored
- // Return the combined matrix, nullptr if any error (e.g. conflict of information).
- static std::unique_ptr<CompatibilityMatrix> combine(
- Level deviceLevel, std::vector<Named<CompatibilityMatrix>>* matrices, std::string* error);
- // Combine a set of device compatibility matrices.
- static std::unique_ptr<CompatibilityMatrix> combineDeviceMatrices(
- std::vector<Named<CompatibilityMatrix>>* matrices, std::string* error);
- status_t fetchAllInformation(const FileSystem* fileSystem, const std::string& path,
- std::string* error = nullptr);
- MatrixHal* splitInstance(MatrixHal* existingHal, const std::string& interface,
- const std::string& instance, bool isRegex);
- // Return whether instance is in "this"; that is, instance is in any <instance> tag or
- // matches any <regex-instance> tag.
- bool matchInstance(const std::string& halName, const Version& version,
- const std::string& interfaceName, const std::string& instance) const;
- friend struct HalManifest;
- friend struct RuntimeInfo;
- friend struct CompatibilityMatrixConverter;
- friend struct LibVintfTest;
- friend struct FrameworkCompatibilityMatrixCombineTest;
- friend struct DeviceCompatibilityMatrixCombineTest;
- friend class VintfObject;
- friend class AssembleVintfImpl;
- friend bool operator==(const CompatibilityMatrix &, const CompatibilityMatrix &);
- SchemaType mType;
- Level mLevel = Level::UNSPECIFIED;
- // entries only for framework compatibility matrix.
- struct {
- std::vector<MatrixKernel> mKernels;
- Sepolicy mSepolicy;
- Version mAvbMetaVersion;
- } framework;
- // entries only for device compatibility matrix.
- struct {
- #pragma clang diagnostic push
- #pragma clang diagnostic ignored "-Wdeprecated-declarations"
- Vndk mVndk;
- #pragma clang diagnostic pop
- VendorNdk mVendorNdk;
- SystemSdk mSystemSdk;
- } device;
- };
- } // namespace vintf
- } // namespace android
- #endif // ANDROID_VINTF_COMPATIBILITY_MATRIX_H
|