Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit ae524f60 authored by Tao Bao's avatar Tao Bao Committed by Android Git Automerger
Browse files

am daebaa6e: Restrict the verification in block-based incremental OTAs

* commit 'daebaa6e':
  Restrict the verification in block-based incremental OTAs
parents 3e7688d0 daebaa6e
Loading
Loading
Loading
Loading
+22 −13
Original line number Diff line number Diff line
@@ -1024,20 +1024,22 @@ def ComputeDifferences(diffs):


class BlockDifference:
  def __init__(self, partition, tgt, src=None, check_first_block=False):
  def __init__(self, partition, tgt, src=None, check_first_block=False, version=None):
    self.tgt = tgt
    self.src = src
    self.partition = partition
    self.check_first_block = check_first_block

    if version is None:
      version = 1
      if OPTIONS.info_dict:
        version = max(
            int(i) for i in
            OPTIONS.info_dict.get("blockimgdiff_versions", "1").split(","))
    self.version = version

    b = blockimgdiff.BlockImageDiff(tgt, src, threads=OPTIONS.worker_threads,
                                    version=version)
                                    version=self.version)
    tmpdir = tempfile.mkdtemp()
    OPTIONS.tempfiles.append(tmpdir)
    self.path = os.path.join(tmpdir, partition)
@@ -1066,6 +1068,13 @@ class BlockDifference:
                         (self.device, self.src.care_map.to_string_raw(),
                          self.src.TotalSha1()))
      script.Print("Verified %s image..." % (self.partition,))
      # Abort the OTA update if it doesn't support resumable OTA (i.e. version<3)
      # and the checksum doesn't match the one in the source partition.
      if self.version < 3:
        script.AppendExtra(('else\n'
                            '  abort("%s partition has unexpected contents");\n'
                            'endif;') % (self.partition))
      else:
        script.AppendExtra(('else\n'
                            '  (range_sha1("%s", "%s") == "%s") ||\n'
                            '  abort("%s partition has unexpected contents");\n'
+26 −6
Original line number Diff line number Diff line
@@ -740,8 +740,16 @@ def WriteBlockIncrementalOTAPackage(target_zip, source_zip, output_zip):

  system_src = GetImage("system", OPTIONS.source_tmp, OPTIONS.source_info_dict)
  system_tgt = GetImage("system", OPTIONS.target_tmp, OPTIONS.target_info_dict)

  blockimgdiff_version = 1
  if OPTIONS.info_dict:
    blockimgdiff_version = max(
        int(i) for i in
        OPTIONS.info_dict.get("blockimgdiff_versions", "1").split(","))

  system_diff = common.BlockDifference("system", system_tgt, system_src,
                                       check_first_block=True)
                                       check_first_block=True,
                                       version=blockimgdiff_version)

  if HasVendorPartition(target_zip):
    if not HasVendorPartition(source_zip):
@@ -749,7 +757,8 @@ def WriteBlockIncrementalOTAPackage(target_zip, source_zip, output_zip):
    vendor_src = GetImage("vendor", OPTIONS.source_tmp, OPTIONS.source_info_dict)
    vendor_tgt = GetImage("vendor", OPTIONS.target_tmp, OPTIONS.target_info_dict)
    vendor_diff = common.BlockDifference("vendor", vendor_tgt, vendor_src,
                                         check_first_block=True)
                                         check_first_block=True,
                                         version=blockimgdiff_version)
  else:
    vendor_diff = None

@@ -810,7 +819,18 @@ else if get_stage("%(bcb_dev)s") != "3/3" then
  device_specific.IncrementalOTA_VerifyBegin()

  if oem_props is None:
    # When blockimgdiff version is less than 3 (non-resumable block-based OTA),
    # patching on a device that's already on the target build will damage the
    # system. Because operations like move don't check the block state, they
    # always apply the changes unconditionally.
    if blockimgdiff_version <= 2:
      script.AssertSomeFingerprint(source_fp)
    else:
      script.AssertSomeFingerprint(source_fp, target_fp)
  else:
    if blockimgdiff_version <= 2:
      script.AssertSomeThumbprint(
          GetBuildProp("ro.build.thumbprint", OPTIONS.source_info_dict))
    else:
      script.AssertSomeThumbprint(
          GetBuildProp("ro.build.thumbprint", OPTIONS.target_info_dict),