| Yifan Hong | 537802d | 2018-08-15 13:15:42 -0700 | [diff] [blame] | 1 | // | 
|  | 2 | // Copyright (C) 2018 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 | #ifndef UPDATE_ENGINE_DYNAMIC_PARTITION_CONTROL_INTERFACE_H_ | 
|  | 18 | #define UPDATE_ENGINE_DYNAMIC_PARTITION_CONTROL_INTERFACE_H_ | 
|  | 19 |  | 
|  | 20 | #include <stdint.h> | 
|  | 21 |  | 
|  | 22 | #include <memory> | 
|  | 23 | #include <string> | 
|  | 24 |  | 
|  | 25 | #include <base/files/file_util.h> | 
|  | 26 | #include <libdm/dm.h> | 
|  | 27 | #include <liblp/builder.h> | 
|  | 28 |  | 
|  | 29 | namespace chromeos_update_engine { | 
|  | 30 |  | 
|  | 31 | class DynamicPartitionControlInterface { | 
|  | 32 | public: | 
|  | 33 | virtual ~DynamicPartitionControlInterface() = default; | 
|  | 34 |  | 
|  | 35 | // Return true iff dynamic partitions is enabled on this device. | 
|  | 36 | virtual bool IsDynamicPartitionsEnabled() = 0; | 
|  | 37 |  | 
|  | 38 | // Map logical partition on device-mapper. | 
|  | 39 | // |super_device| is the device path of the physical partition ("super"). | 
|  | 40 | // |target_partition_name| is the identifier used in metadata; for example, | 
|  | 41 | // "vendor_a" | 
|  | 42 | // |slot| is the selected slot to mount; for example, 0 for "_a". | 
|  | 43 | // Returns true if mapped successfully; if so, |path| is set to the device | 
|  | 44 | // path of the mapped logical partition. | 
|  | 45 | virtual bool MapPartitionOnDeviceMapper( | 
|  | 46 | const std::string& super_device, | 
|  | 47 | const std::string& target_partition_name, | 
|  | 48 | uint32_t slot, | 
|  | 49 | std::string* path) = 0; | 
|  | 50 |  | 
|  | 51 | // Unmap logical partition on device mapper. This is the reverse operation | 
|  | 52 | // of MapPartitionOnDeviceMapper. | 
|  | 53 | // If |wait| is set, wait until the device is unmapped. | 
|  | 54 | // Returns true if unmapped successfully. | 
|  | 55 | virtual bool UnmapPartitionOnDeviceMapper( | 
|  | 56 | const std::string& target_partition_name, bool wait) = 0; | 
|  | 57 |  | 
|  | 58 | // Do necessary cleanups before destroying the object. | 
|  | 59 | virtual void Cleanup() = 0; | 
|  | 60 |  | 
|  | 61 | // Return true if a static partition exists at device path |path|. | 
|  | 62 | virtual bool DeviceExists(const std::string& path) = 0; | 
|  | 63 |  | 
|  | 64 | // Returns the current state of the underlying device mapper device | 
|  | 65 | // with given name. | 
|  | 66 | // One of INVALID, SUSPENDED or ACTIVE. | 
|  | 67 | virtual android::dm::DmDeviceState GetState(const std::string& name) = 0; | 
|  | 68 |  | 
|  | 69 | // Returns the path to the device mapper device node in '/dev' corresponding | 
|  | 70 | // to 'name'. If the device does not exist, false is returned, and the path | 
|  | 71 | // parameter is not set. | 
|  | 72 | virtual bool GetDmDevicePathByName(const std::string& name, | 
|  | 73 | std::string* path) = 0; | 
|  | 74 |  | 
|  | 75 | // Retrieve metadata from |super_device| at slot |source_slot|. | 
|  | 76 | virtual std::unique_ptr<android::fs_mgr::MetadataBuilder> LoadMetadataBuilder( | 
|  | 77 | const std::string& super_device, uint32_t source_slot) = 0; | 
|  | 78 |  | 
|  | 79 | // Write metadata |builder| to |super_device| at slot |target_slot|. | 
|  | 80 | virtual bool StoreMetadata(const std::string& super_device, | 
|  | 81 | android::fs_mgr::MetadataBuilder* builder, | 
|  | 82 | uint32_t target_slot) = 0; | 
|  | 83 |  | 
|  | 84 | // Return a possible location for devices listed by name. | 
|  | 85 | virtual bool GetDeviceDir(std::string* path) = 0; | 
|  | 86 | }; | 
|  | 87 |  | 
|  | 88 | }  // namespace chromeos_update_engine | 
|  | 89 |  | 
|  | 90 | #endif  // UPDATE_ENGINE_DYNAMIC_PARTITION_CONTROL_INTERFACE_H_ |