xref: /aosp_15_r20/system/libvintf/include/vintf/VintfObjectRecovery.h (revision 70a7ec852fcefd15a4fb57f8f183a8b1c3aacb08)
1*70a7ec85SAndroid Build Coastguard Worker /*
2*70a7ec85SAndroid Build Coastguard Worker  * Copyright (C) 2021 The Android Open Source Project
3*70a7ec85SAndroid Build Coastguard Worker  *
4*70a7ec85SAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*70a7ec85SAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*70a7ec85SAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*70a7ec85SAndroid Build Coastguard Worker  *
8*70a7ec85SAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*70a7ec85SAndroid Build Coastguard Worker  *
10*70a7ec85SAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*70a7ec85SAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*70a7ec85SAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*70a7ec85SAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*70a7ec85SAndroid Build Coastguard Worker  * limitations under the License.
15*70a7ec85SAndroid Build Coastguard Worker  */
16*70a7ec85SAndroid Build Coastguard Worker 
17*70a7ec85SAndroid Build Coastguard Worker #pragma once
18*70a7ec85SAndroid Build Coastguard Worker 
19*70a7ec85SAndroid Build Coastguard Worker #if defined(__ANDROID__) && !defined(__ANDROID_RECOVERY__)
20*70a7ec85SAndroid Build Coastguard Worker #error VintfObjectRecovery is only supported in recovery and host.
21*70a7ec85SAndroid Build Coastguard Worker #endif
22*70a7ec85SAndroid Build Coastguard Worker 
23*70a7ec85SAndroid Build Coastguard Worker #include <vintf/VintfObject.h>
24*70a7ec85SAndroid Build Coastguard Worker 
25*70a7ec85SAndroid Build Coastguard Worker namespace android::vintf {
26*70a7ec85SAndroid Build Coastguard Worker 
27*70a7ec85SAndroid Build Coastguard Worker /**
28*70a7ec85SAndroid Build Coastguard Worker  * A special variant of VintfObject for the recovery ramdisk.
29*70a7ec85SAndroid Build Coastguard Worker  *
30*70a7ec85SAndroid Build Coastguard Worker  * In recovery ramdisk, there is no Treble split. All VINTF data is stored in /system/etc/vintf.
31*70a7ec85SAndroid Build Coastguard Worker  *
32*70a7ec85SAndroid Build Coastguard Worker  * All getDevice* / getFramework* functions return nullptr. Instead, getRecovery* should be
33*70a7ec85SAndroid Build Coastguard Worker  * used instead.
34*70a7ec85SAndroid Build Coastguard Worker  */
35*70a7ec85SAndroid Build Coastguard Worker class VintfObjectRecovery : public VintfObject {
36*70a7ec85SAndroid Build Coastguard Worker    public:
37*70a7ec85SAndroid Build Coastguard Worker     /*
38*70a7ec85SAndroid Build Coastguard Worker      * Get global instance. Results are cached.
39*70a7ec85SAndroid Build Coastguard Worker      */
40*70a7ec85SAndroid Build Coastguard Worker     static std::shared_ptr<VintfObjectRecovery> GetInstance();
41*70a7ec85SAndroid Build Coastguard Worker 
42*70a7ec85SAndroid Build Coastguard Worker     /*
43*70a7ec85SAndroid Build Coastguard Worker      * Return the API that access the HAL manifests built from component pieces on the
44*70a7ec85SAndroid Build Coastguard Worker      * recovery partition.
45*70a7ec85SAndroid Build Coastguard Worker      *
46*70a7ec85SAndroid Build Coastguard Worker      * Returned manifest has SchemaType::DEVICE.
47*70a7ec85SAndroid Build Coastguard Worker      *
48*70a7ec85SAndroid Build Coastguard Worker      * No SKU manifest support.
49*70a7ec85SAndroid Build Coastguard Worker      */
50*70a7ec85SAndroid Build Coastguard Worker     std::shared_ptr<const HalManifest> getRecoveryHalManifest();
51*70a7ec85SAndroid Build Coastguard Worker 
52*70a7ec85SAndroid Build Coastguard Worker     // Not supported. Call getRecoveryHalManifest instead.
getDeviceHalManifest()53*70a7ec85SAndroid Build Coastguard Worker     std::shared_ptr<const HalManifest> getDeviceHalManifest() override { return nullptr; }
getFrameworkHalManifest()54*70a7ec85SAndroid Build Coastguard Worker     std::shared_ptr<const HalManifest> getFrameworkHalManifest() override { return nullptr; }
55*70a7ec85SAndroid Build Coastguard Worker 
56*70a7ec85SAndroid Build Coastguard Worker     // Not supported. No compatibility check in recovery because there is no Treble split.
getDeviceCompatibilityMatrix()57*70a7ec85SAndroid Build Coastguard Worker     std::shared_ptr<const CompatibilityMatrix> getDeviceCompatibilityMatrix() override {
58*70a7ec85SAndroid Build Coastguard Worker         return nullptr;
59*70a7ec85SAndroid Build Coastguard Worker     }
getFrameworkCompatibilityMatrix()60*70a7ec85SAndroid Build Coastguard Worker     std::shared_ptr<const CompatibilityMatrix> getFrameworkCompatibilityMatrix() override {
61*70a7ec85SAndroid Build Coastguard Worker         return nullptr;
62*70a7ec85SAndroid Build Coastguard Worker     }
63*70a7ec85SAndroid Build Coastguard Worker 
64*70a7ec85SAndroid Build Coastguard Worker     /** Builder of VintfObjectRecovery. See VintfObjectBuilder for details. */
65*70a7ec85SAndroid Build Coastguard Worker     class Builder : public details::VintfObjectBuilder {
66*70a7ec85SAndroid Build Coastguard Worker        public:
67*70a7ec85SAndroid Build Coastguard Worker         Builder();
68*70a7ec85SAndroid Build Coastguard Worker     };
69*70a7ec85SAndroid Build Coastguard Worker 
70*70a7ec85SAndroid Build Coastguard Worker    private:
71*70a7ec85SAndroid Build Coastguard Worker     VintfObjectRecovery() = default;
72*70a7ec85SAndroid Build Coastguard Worker     status_t fetchRecoveryHalManifest(HalManifest* out, std::string* error);
73*70a7ec85SAndroid Build Coastguard Worker     details::LockedSharedPtr<HalManifest> mRecoveryManifest;
74*70a7ec85SAndroid Build Coastguard Worker };
75*70a7ec85SAndroid Build Coastguard Worker 
76*70a7ec85SAndroid Build Coastguard Worker }  // namespace android::vintf
77