diff options
author | Amin Hassani <ahassani@chromium.org> | 2020-09-16 11:19:28 -0700 |
---|---|---|
committer | Amin Hassani <ahassani@chromium.org> | 2020-09-17 10:17:36 -0700 |
commit | e53b39b8b9c5c0871841bbbb86f23657c0b7f91b (patch) | |
tree | 12746e5e7e4716ba7fc94d3ed5c1a36c4d47d474 /boot_control_android.h | |
parent | a02a1f1dc837f22226499d9856a949fb180d099a (diff) | |
parent | 9956320ffa4edb340d20bd7f3c852a9e87437bd3 (diff) |
update_engine: Merge remote-tracking branch 'cros/upstream' into cros/master
Done with:
git merge cros/upstream --commit -s recursive
- Added EC key support and its unittests.
- Resolved a conlict on error codes. Since Android versions are not
uploading any UMA metrics, I gave the priority to the Android version
Since they can't be changed.
- Changed the openssl functions to get1 version (from get0) version
because of a current issue with gale. Once the issue is resolved we
need to change them back.
- Some remaining styling issues fixed by clang-format
BUG=b:163153182
TEST=CQ passes
TEST=unittests
Change-Id: Ib95034422b92433ce26e28336bc4806b34910d38
Diffstat (limited to 'boot_control_android.h')
-rw-r--r-- | boot_control_android.h | 42 |
1 files changed, 10 insertions, 32 deletions
diff --git a/boot_control_android.h b/boot_control_android.h index a6f33bed..5009dbd3 100644 --- a/boot_control_android.h +++ b/boot_control_android.h @@ -22,11 +22,11 @@ #include <string> #include <android/hardware/boot/1.0/IBootControl.h> -#include <base/files/file_util.h> #include <liblp/builder.h> #include "update_engine/common/boot_control.h" -#include "update_engine/dynamic_partition_control_interface.h" +#include "update_engine/common/dynamic_partition_control_interface.h" +#include "update_engine/dynamic_partition_control_android.h" namespace chromeos_update_engine { @@ -46,47 +46,25 @@ class BootControlAndroid : public BootControlInterface { BootControlInterface::Slot GetCurrentSlot() const override; bool GetPartitionDevice(const std::string& partition_name, BootControlInterface::Slot slot, + bool not_in_payload, + std::string* device, + bool* is_dynamic) const override; + bool GetPartitionDevice(const std::string& partition_name, + BootControlInterface::Slot slot, std::string* device) const override; bool IsSlotBootable(BootControlInterface::Slot slot) const override; bool MarkSlotUnbootable(BootControlInterface::Slot slot) override; bool SetActiveBootSlot(BootControlInterface::Slot slot) override; bool MarkBootSuccessfulAsync(base::Callback<void(bool)> callback) override; - bool InitPartitionMetadata(Slot slot, - const PartitionMetadata& partition_metadata, - bool update_metadata) override; - void Cleanup() override; + bool IsSlotMarkedSuccessful(BootControlInterface::Slot slot) const override; + DynamicPartitionControlInterface* GetDynamicPartitionControl() override; private: ::android::sp<::android::hardware::boot::V1_0::IBootControl> module_; - std::unique_ptr<DynamicPartitionControlInterface> dynamic_control_; + std::unique_ptr<DynamicPartitionControlAndroid> dynamic_control_; friend class BootControlAndroidTest; - // Wrapper method of IBootControl::getSuffix(). - bool GetSuffix(Slot slot, std::string* out) const; - - enum class DynamicPartitionDeviceStatus { - SUCCESS, - ERROR, - TRY_STATIC, - }; - - DynamicPartitionDeviceStatus GetDynamicPartitionDevice( - const base::FilePath& device_dir, - const std::string& partition_name_suffix, - Slot slot, - std::string* device) const; - - // Return true if |partition_name_suffix| is a block device of - // super partition metadata slot |slot|. - bool IsSuperBlockDevice(const base::FilePath& device_dir, - Slot slot, - const std::string& partition_name_suffix) const; - - // Whether the target partitions should be loaded as dynamic partitions. Set - // by InitPartitionMetadata() per each update. - bool is_target_dynamic_{false}; - DISALLOW_COPY_AND_ASSIGN(BootControlAndroid); }; |