ডায়নামিক পার্টিশন সহ নন-এ/বি ডিভাইসগুলির জন্য ওটিএ

অ্যান্ড্রয়েড 10 ডাইনামিক পার্টিশন সমর্থন করে, একটি ইউজারস্পেস পার্টিশনিং সিস্টেম যা ওভার-দ্য-এয়ার (OTA) আপডেটের সময় পার্টিশন তৈরি, আকার পরিবর্তন এবং ধ্বংস করতে পারে।

এই পৃষ্ঠাটি বর্ণনা করে যে কীভাবে OTA ক্লায়েন্টরা অ-A/B ডিভাইসগুলির জন্য একটি আপডেটের সময় গতিশীল পার্টিশনের আকার পরিবর্তন করে।

নন-A/B ডিভাইসগুলির জন্য, আপডেট প্যাকেজের ভিতরে updater ব্যবহার করে গতিশীল পার্টিশনের জন্য OTA আপডেট প্রয়োগ করা হয়।

লঞ্চ ডিভাইস আপডেট করুন

এই বিভাগটি নন-A/B ডিভাইসগুলির ক্ষেত্রে প্রযোজ্য যেগুলি গতিশীল পার্টিশন সমর্থন সহ চালু হয়; এই ডিভাইসগুলি Android 10 থেকে উচ্চতর রিলিজে আপগ্রেড হয়।

আপডেট প্যাকেজ তৈরি করুন

OTA আপডেট প্যাকেজগুলি ota_from_target_files স্ক্রিপ্ট দ্বারা তৈরি করা হয়, build/make/tools/releasetools অধীনে অবস্থিত। ডিফল্টরূপে, স্ক্রিপ্ট একটি প্যাকেজ তৈরি করে যা system এবং vendor পার্টিশন আপডেট করে। যদি অতিরিক্ত গতিশীল পার্টিশন থাকে, যেমন product , product_services , বা odm , তাদের আপডেট অবশ্যই ডিভাইস-নির্দিষ্ট কোডে তৈরি করতে হবে।

আপডেট তৈরি করতে, বর্ধিত পাইথন মডিউলে, FullOTA_GetBlockDifferences() এবং IncrementalOTA_GetBlockDifferences() প্রয়োগ করুন। এই দুটি ফাংশন BlockDifference অবজেক্টের একটি তালিকা প্রদান করে, প্রতিটি আপডেট প্যাচ বর্ণনা করে যা একটি পার্টিশনে প্রয়োগ করা হবে। এই দুটি ফাংশন দ্বারা প্রত্যাবর্তিত পার্টিশনগুলি ম্যানুয়ালি পরিবর্তন করা উচিত নয় বা অন্য কোথাও যাচাই করা উচিত নয়, উদাহরণস্বরূপ *_InstallBegin() বা *_InstallEnd() এ।

একটি আপডেট প্রজন্মের উদাহরণ:

# device/yoyodyne/tardis/releasetools.py

import os
from common import BlockDifference, EmptyImage, GetUserImage

# The joined list of user image partitions of source and target builds.
# - Items should be added to the list if new dynamic partitions are added.
# - Items should not be removed from the list even if dynamic partitions are
#   deleted. When generating an incremental OTA package, this script needs to
#   know that an image is present in source build but not in target build.
USERIMAGE_PARTITIONS = [
    "product",
    "odm",
]

def GetUserImages(input_tmp, input_zip):
  return {partition: GetUserImage(partition, input_tmp, input_zip)
          for partition in USERIMAGE_PARTITIONS
          if os.path.exists(os.path.join(input_tmp,
                                         "IMAGES", partition + ".img"))}

def FullOTA_GetBlockDifferences(info):
  images = GetUserImages(info.input_tmp, info.input_zip)
  return [BlockDifference(partition, image)
          for partition, image in images.items()]

def IncrementalOTA_GetBlockDifferences(info):
  source_images = GetUserImages(info.source_tmp, info.source_zip)
  target_images = GetUserImages(info.target_tmp, info.target_zip)

  # Use EmptyImage() as a placeholder for partitions that will be deleted.
  for partition in source_images:
    target_images.setdefault(partition, EmptyImage())

  # Use source_images.get() because new partitions are not in source_images.
  return [BlockDifference(partition, target_image, source_images.get(partition))
          for partition, target_image in target_images.items()]

আপডেট প্রবাহ

পর্দার পিছনে, নিম্নলিখিত ফাংশনগুলি এডিফাই স্ক্রিপ্টে যুক্ত করা হয়েছে:

  • unmap_partition(name)
    • ম্যাপ করা হলে পার্টিশনটি আনম্যাপ করুন, অন্যথায় কিছুই করবেন না।
    • সাফল্যের উপর স্ট্রিং t , অথবা ব্যর্থতার উপর একটি খালি স্ট্রিং ফেরত দিন।
  • map_partition(name)
    • ইতিমধ্যে ম্যাপ করা না থাকলে পার্টিশনটি ম্যাপ করুন।
    • সাফল্যের উপর ম্যাপ করা ব্লক ডিভাইসের পরম পথ বা ব্যর্থতার উপর একটি খালি স্ট্রিং ফেরত দিন।
  • update_dynamic_partitions(op_list)
    • প্রদত্ত অপারেশন তালিকাটি ডায়নামিক পার্টিশন মেটাডেটাতে প্রয়োগ করুন, প্রয়োজনে পার্টিশনগুলি আনম্যাপ করুন।
    • সাফল্যের উপর t , অথবা ব্যর্থতার উপর একটি খালি স্ট্রিং ফেরত দিন।

update_dynamic_partitions এর op_list আর্গুমেন্ট আপডেট প্যাকেজের একটি ফাইলের দিকে নির্দেশ করে। ফাইলের প্রতিটি লাইন একটি অপারেশন নির্দিষ্ট করে। কোনো অপারেশন ব্যর্থ হলে, update_dynamic_partitions অবিলম্বে একটি খালি স্ট্রিং প্রদান করে। অপারেশনগুলি হল:

  • resize partition-name size
    • পার্টিশনটি আনম্যাপ করুন, তারপরে এটির size পরিবর্তন করুন।
  • remove partition_name
    • পার্টিশনটি আনম্যাপ করুন, তারপর এটি সরান।
  • add partition-name group-name
    • নির্দিষ্ট গ্রুপে একটি নতুন পার্টিশন যোগ করুন।
    • গোষ্ঠীটি বিদ্যমান না থাকলে বা পার্টিশনটি ইতিমধ্যেই বিদ্যমান থাকলে বাতিল করুন।
  • move partition-name group-name
    • পার্টিশনটিকে নির্দিষ্ট গ্রুপে সরান।
    • গোষ্ঠীটি বিদ্যমান না থাকলে বা পার্টিশন বিদ্যমান না থাকলে বাতিল করুন।
  • add_group group-name maximum-size
    • প্রদত্ত নাম এবং সর্বাধিক আকার সহ একটি গ্রুপ যোগ করুন।
    • যদি গ্রুপটি আগে থেকেই থাকে তাহলে বাতিল করুন।
    • maximum_size 0 মানে গ্রুপে পার্টিশনের কোনো আকারের সীমা নেই। গ্রুপের পার্টিশনগুলি ডিভাইসে উপলব্ধ স্থান অতিক্রম না করে তা নিশ্চিত করার জন্য অতিরিক্ত পরীক্ষার প্রয়োজন।
  • resize_group group-name maximum-size
    • গ্রুপটিকে প্রদত্ত সর্বাধিক আকারে পুনরায় আকার দিন।
    • গোষ্ঠীটি বিদ্যমান না থাকলে বাতিল করুন।
    • maximum_size 0 মানে গ্রুপে পার্টিশনের কোনো আকারের সীমা নেই। গ্রুপের পার্টিশনগুলি ডিভাইসে উপলব্ধ স্থান অতিক্রম না করে তা নিশ্চিত করার জন্য অতিরিক্ত পরীক্ষার প্রয়োজন।
  • remove_group group-name
    • একটি গ্রুপ সরান.
    • গ্রুপে পার্টিশন থাকলে বাতিল করুন।
  • remove_all_groups
    • ডিভাইস ম্যাপার থেকে সমস্ত পার্টিশন আনম্যাপ করুন।
    • সমস্ত পার্টিশন এবং গ্রুপ সরান.

বর্ধিত ওটিএ

ক্রমবর্ধমান OTA আপডেটগুলি নিম্নলিখিত যুক্তি ব্যবহার করে:

  1. পার্টিশন সঙ্কুচিত করুন/পার্টিশন মুছুন/পার্টিশনগুলিকে গোষ্ঠীর বাইরে সরান (যাতে দলগুলি সঙ্কুচিত করার জন্য যথেষ্ট জায়গা রয়েছে)
  2. গোষ্ঠীগুলি সঙ্কুচিত করুন (যাতে দলগুলি বাড়াতে পর্যাপ্ত জায়গা থাকে)
  3. গ্রুপ বাড়ান (যাতে আমাদের পার্টিশন বাড়াতে/যোগ করার জন্য পর্যাপ্ত জায়গা থাকে)
  4. পার্টিশন বাড়ান/ পার্টিশন যোগ করুন/ পার্টিশনগুলিকে নতুন গ্রুপে সরান

বিস্তারিতভাবে, update-script এই যুক্তি দিয়ে তৈরি করা হয়েছে:

for each shrinking partition:
    block_image_update(map_partition(name), …)

update_dynamic_partitions(op_list)

for each growing / adding partition:
    block_image_update(map_partition(name), …)

update_dynamic_partitions জন্য op_list ফাইলটি এই যুক্তি দিয়ে তৈরি করা হয়েছে:

for each deleting partition:
    remove
for each partition that changes groups:
    move to "default"
for each shrinking partition:
    resize
for each shrinking / removing group:
    resize_group / remove_group
for each growing / adding group:
    resize_group / add_group
for each adding partition:
    add
for each growing / adding partition:
    resize
for each partition that changes groups:
    move to target group

সম্পূর্ণ OTA

সম্পূর্ণ OTA আপডেট নিম্নলিখিত যুক্তি ব্যবহার করে:

  1. সমস্ত বিদ্যমান গ্রুপ এবং পার্টিশন মুছুন
  2. গ্রুপ যোগ করুন
  3. পার্টিশন যোগ করুন

বিস্তারিতভাবে, update-script এই যুক্তি দিয়ে তৈরি করা হয়েছে:

update_dynamic_partitions(op_list)

for each adding partition:
    block_image_update(map_partition(name), …)

update_dynamic_partitions জন্য op_list ফাইলটি এই যুক্তি দিয়ে তৈরি করা হয়েছে:

remove_all_groups
for each adding group:
    add_group
for each adding partition:
    add
for each adding partition:
    resize