diff options
| author | Yifan Hong <elsk@google.com> | 2019-08-12 19:43:11 -0700 | 
|---|---|---|
| committer | Yifan Hong <elsk@google.com> | 2019-08-14 14:17:22 -0700 | 
| commit | 8367b9f73aefb8ae97b4760bebc3f98f0c9ffd1c (patch) | |
| tree | 73e87b0cac611696c2d1ed3c970e4cef4ecd9e52 /fs_mgr/liblp/builder.cpp | |
| parent | 4644f842085d465422193dc2a48ca71dfef4f4a9 (diff) | |
liblp: MetadataBuilder::GetBlockDevicePartitionName
Allow to retrieve name of a block device partition at
a certain index. If the index is out of range, return
empty string.
This is needed for an hypothetical edge case when an
intersection of two LinearExtent needs to be computed,
and the two metadata have a different list of block
device names. In reality, Virtual A/B devices are always
launched with dynamic partitions, so it will always return
"super" for index 0 and "" otherwise.
Test: liblp_test_static
Bug: 135752105
Change-Id: I9ea59edefdc41d0e69e3644aa2452676372938b4
Diffstat (limited to 'fs_mgr/liblp/builder.cpp')
| -rw-r--r-- | fs_mgr/liblp/builder.cpp | 22 | 
1 files changed, 15 insertions, 7 deletions
diff --git a/fs_mgr/liblp/builder.cpp b/fs_mgr/liblp/builder.cpp index 33ea8c5927..e789524f5f 100644 --- a/fs_mgr/liblp/builder.cpp +++ b/fs_mgr/liblp/builder.cpp @@ -140,7 +140,7 @@ std::unique_ptr<MetadataBuilder> MetadataBuilder::New(const LpMetadata& metadata      }      if (opener) {          for (size_t i = 0; i < builder->block_devices_.size(); i++) { -            std::string partition_name = GetBlockDevicePartitionName(builder->block_devices_[i]); +            std::string partition_name = builder->GetBlockDevicePartitionName(i);              BlockDeviceInfo device_info;              if (opener->GetInfo(partition_name, &device_info)) {                  builder->UpdateBlockDeviceInfo(i, device_info); @@ -164,7 +164,7 @@ std::unique_ptr<MetadataBuilder> MetadataBuilder::NewForUpdate(const IPartitionO      // name and system properties.      // See comments for UpdateMetadataForOtherSuper.      auto super_device = GetMetadataSuperBlockDevice(*metadata.get()); -    if (GetBlockDevicePartitionName(*super_device) != "super" && +    if (android::fs_mgr::GetBlockDevicePartitionName(*super_device) != "super" &&          IsRetrofitDynamicPartitionsDevice()) {          if (!UpdateMetadataForOtherSuper(metadata.get(), source_slot_number, target_slot_number)) {              return nullptr; @@ -192,7 +192,8 @@ bool MetadataBuilder::UpdateMetadataForOtherSuper(LpMetadata* metadata, uint32_t      // Translate block devices.      auto source_block_devices = std::move(metadata->block_devices);      for (const auto& source_block_device : source_block_devices) { -        std::string partition_name = GetBlockDevicePartitionName(source_block_device); +        std::string partition_name = +                android::fs_mgr::GetBlockDevicePartitionName(source_block_device);          std::string slot_suffix = GetPartitionSlotSuffix(partition_name);          if (slot_suffix.empty() || slot_suffix != source_slot_suffix) {              // This should never happen. It means that the source metadata @@ -375,7 +376,7 @@ bool MetadataBuilder::Init(const std::vector<BlockDeviceInfo>& block_devices,              block_devices_.emplace_back(out);          }      } -    if (GetBlockDevicePartitionName(block_devices_[0]) != super_partition) { +    if (GetBlockDevicePartitionName(0) != super_partition) {          LERROR << "No super partition was specified.";          return false;      } @@ -849,7 +850,7 @@ uint64_t MetadataBuilder::AlignSector(const LpMetadataBlockDevice& block_device,  bool MetadataBuilder::FindBlockDeviceByName(const std::string& partition_name,                                              uint32_t* index) const {      for (size_t i = 0; i < block_devices_.size(); i++) { -        if (GetBlockDevicePartitionName(block_devices_[i]) == partition_name) { +        if (GetBlockDevicePartitionName(i) == partition_name) {              *index = i;              return true;          } @@ -974,7 +975,8 @@ static bool CompareBlockDevices(const LpMetadataBlockDevice& first,      // Note: we don't compare alignment, since it's a performance thing and      // won't affect whether old extents continue to work.      return first.first_logical_sector == second.first_logical_sector && first.size == second.size && -           GetBlockDevicePartitionName(first) == GetBlockDevicePartitionName(second); +           android::fs_mgr::GetBlockDevicePartitionName(first) == +                   android::fs_mgr::GetBlockDevicePartitionName(second);  }  bool MetadataBuilder::ImportPartitions(const LpMetadata& metadata, @@ -1057,7 +1059,7 @@ bool MetadataBuilder::IsRetrofitDynamicPartitionsDevice() {  }  bool MetadataBuilder::IsRetrofitMetadata() const { -    return GetBlockDevicePartitionName(block_devices_[0]) != LP_METADATA_DEFAULT_PARTITION_NAME; +    return GetBlockDevicePartitionName(0) != LP_METADATA_DEFAULT_PARTITION_NAME;  }  bool MetadataBuilder::AddLinearExtent(Partition* partition, const std::string& block_device, @@ -1121,5 +1123,11 @@ bool MetadataBuilder::ChangeGroupSize(const std::string& group_name, uint64_t ma      return true;  } +std::string MetadataBuilder::GetBlockDevicePartitionName(uint64_t index) const { +    return index < block_devices_.size() +                   ? android::fs_mgr::GetBlockDevicePartitionName(block_devices_[index]) +                   : ""; +} +  }  // namespace fs_mgr  }  // namespace android  | 
