پارتیشن بندی پویا با استفاده از ماژول dm-linear device-mapper در هسته لینوکس پیاده سازی می شود. super
پارتیشن حاوی ابرداده است که نام ها و محدوده بلوک هر پارتیشن پویا را در super
فهرست می کند. در init
اول، این ابرداده تجزیه و اعتبارسنجی میشود و دستگاههای بلوک مجازی برای نمایش هر پارتیشن پویا ایجاد میشوند.
هنگام اعمال OTA، پارتیشن های پویا به طور خودکار ایجاد می شوند، اندازه آنها تغییر می کند یا در صورت نیاز حذف می شوند. برای دستگاههای A/B، دو نسخه از ابرداده وجود دارد و تغییرات فقط روی نسخهای اعمال میشود که نشاندهنده شکاف هدف است.
از آنجایی که پارتیشنهای پویا در فضای کاربران پیادهسازی میشوند، پارتیشنهای مورد نیاز بوتلودر را نمیتوان پویا کرد. به عنوان مثال، boot
، dtbo
، و vbmeta
توسط بوت لودر خوانده می شوند و بنابراین باید به عنوان پارتیشن های فیزیکی باقی بمانند.
هر پارتیشن پویا می تواند به یک گروه به روز رسانی تعلق داشته باشد. این گروه ها حداکثر فضایی را که پارتیشن های آن گروه می توانند مصرف کنند محدود می کنند. به عنوان مثال، system
و vendor
می توانند به گروهی تعلق داشته باشند که اندازه کل system
و vendor
را محدود می کند.
پیاده سازی پارتیشن های پویا در دستگاه های جدید
این بخش نحوه پیادهسازی پارتیشنهای پویا را در دستگاههای جدیدی که با اندروید 10 و بالاتر راهاندازی میشوند، توضیح میدهد. برای بهروزرسانی دستگاههای موجود، به ارتقای دستگاههای Android مراجعه کنید.
تغییرات پارتیشن
برای دستگاه هایی که با اندروید 10 راه اندازی می شوند، پارتیشنی به نام super
ایجاد کنید. پارتیشن super
به صورت داخلی اسلات های A/B را کنترل می کند، بنابراین دستگاه های A/B به پارتیشن های جداگانه super_a
و super_b
نیاز ندارند. تمام پارتیشنهای AOSP فقط خواندنی که توسط بوتلودر استفاده نمیشوند باید پویا باشند و باید از جدول پارتیشن GUID (GPT) حذف شوند. پارتیشن های خاص فروشنده لازم نیست پویا باشند و ممکن است در GPT قرار گیرند.
برای تخمین اندازه super
، اندازه پارتیشن هایی که از GPT حذف می شوند را اضافه کنید. برای دستگاه های A/B، این باید شامل اندازه هر دو اسلات باشد. شکل 1 نمونه ای از جدول پارتیشن را قبل و بعد از تبدیل به پارتیشن های پویا نشان می دهد.
پارتیشن های پویا پشتیبانی شده عبارتند از:
- سیستم
- فروشنده
- محصول
- خروجی سیستم
- ODM
برای دستگاه هایی که با Android 10 راه اندازی می شوند، گزینه خط فرمان هسته androidboot.super_partition
باید خالی باشد تا دستور sysprop ro.boot.super_partition
خالی باشد.
تراز پارتیشن
اگر پارتیشن super
به درستی تراز نشده باشد، ماژول نقشهبردار دستگاه ممکن است کارایی کمتری داشته باشد. پارتیشن super
باید با حداقل اندازه درخواست ورودی/خروجی که توسط لایه بلوک تعیین می شود، تراز شود. بهطور پیشفرض، سیستم ساخت (از طریق lpmake
، که تصویر پارتیشن super
را تولید میکند)، فرض میکند که یک تراز 1 مگابایتی برای هر پارتیشن پویا کافی است. با این حال، فروشندگان باید اطمینان حاصل کنند که پارتیشن super
به درستی تراز شده است.
با بررسی sysfs
می توانید حداقل اندازه درخواست یک دستگاه بلوک را تعیین کنید. به عنوان مثال:
# ls -l /dev/block/by-name/super lrwxrwxrwx 1 root root 16 1970-04-05 01:41 /dev/block/by-name/super -> /dev/block/sda17 # cat /sys/block/sda/queue/minimum_io_size 786432
میتوانید تراز پارتیشن super
را به روشی مشابه تأیید کنید:
# cat /sys/block/sda/sda17/alignment_offset
افست تراز باید 0 باشد.
پیکربندی دستگاه تغییر می کند
برای فعال کردن پارتیشن بندی پویا، پرچم زیر را در device.mk
اضافه کنید:
PRODUCT_USE_DYNAMIC_PARTITIONS := true
تغییرات پیکربندی برد
شما باید اندازه پارتیشن super
را تنظیم کنید:
BOARD_SUPER_PARTITION_SIZE := <size-in-bytes>
در دستگاه های A/B، اگر اندازه کل تصاویر پارتیشن پویا بیش از نیمی از اندازه پارتیشن super
باشد، سیستم ساخت خطا می دهد.
شما می توانید لیست پارتیشن های پویا را به صورت زیر پیکربندی کنید. برای دستگاههایی که از گروههای بهروزرسانی استفاده میکنند، گروهها را در متغیر BOARD_SUPER_PARTITION_GROUPS
فهرست کنید. سپس نام هر گروه دارای یک متغیر BOARD_ group _SIZE
و BOARD_ group _PARTITION_LIST
است. برای دستگاههای A/B، حداکثر اندازه یک گروه باید فقط یک اسلات را پوشش دهد، زیرا نام گروهها در داخل اسلات پسوند هستند.
در اینجا یک دستگاه نمونه است که همه پارتیشن ها را در گروهی به نام example_dynamic_partitions
قرار می دهد:
BOARD_SUPER_PARTITION_GROUPS := example_dynamic_partitions BOARD_EXAMPLE_DYNAMIC_PARTITIONS_SIZE := 6442450944 BOARD_EXAMPLE_DYNAMIC_PARTITIONS_PARTITION_LIST := system vendor product
در اینجا یک دستگاه نمونه است که خدمات سیستم و محصول را در group_foo
و vendor
، product
و odm
در group_bar
قرار می دهد:
BOARD_SUPER_PARTITION_GROUPS := group_foo group_bar BOARD_GROUP_FOO_SIZE := 4831838208 BOARD_GROUP_FOO_PARTITION_LIST := system product_services BOARD_GROUP_BAR_SIZE := 1610612736 BOARD_GROUP_BAR_PARTITION_LIST := vendor product odm
- برای دستگاههای راهاندازی مجازی A/B، مجموع حداکثر اندازههای همه گروهها باید حداکثر باشد:
BOARD_SUPER_PARTITION_SIZE
- سربار
به پیاده سازی A/B مجازی مراجعه کنید. - برای دستگاههای پرتاب A/B، مجموع حداکثر اندازههای همه گروهها باید باشد:
BOARD_SUPER_PARTITION_SIZE
/ 2 - سربار - برای دستگاههای غیر A/B و دستگاههای مقاومسازی A/B، مجموع حداکثر اندازههای همه گروهها باید باشد:
BOARD_SUPER_PARTITION_SIZE
- سربار - در زمان ساخت، مجموع اندازههای تصاویر هر پارتیشن در یک گروه بهروزرسانی نباید از حداکثر اندازه گروه تجاوز کند.
- سربار در محاسبات برای محاسبه ابرداده ها، ترازها و غیره مورد نیاز است. سربار معقول 4 مگابایت است، اما میتوانید در صورت نیاز دستگاه، سربار بزرگتری را انتخاب کنید.
اندازه پارتیشن های پویا
قبل از پارتیشن های پویا، اندازه پارتیشن ها بیش از حد تخصیص داده می شد تا اطمینان حاصل شود که فضای کافی برای به روز رسانی های آینده دارند. اندازه واقعی همانطور که هست گرفته شد و اکثر پارتیشن های فقط خواندنی مقداری فضای خالی در سیستم فایل خود داشتند. در پارتیشن های پویا، این فضای آزاد غیرقابل استفاده است و می تواند برای رشد پارتیشن ها در طول OTA استفاده شود. بسیار مهم است که اطمینان حاصل شود که پارتیشن ها فضا را هدر نمی دهند و به حداقل اندازه ممکن اختصاص داده می شوند.
برای تصاویر ext4 فقط خواندنی، اگر اندازه پارتیشن هاردکد مشخص نشده باشد، سیستم ساخت به طور خودکار حداقل اندازه را اختصاص می دهد. سیستم ساخت با تصویر متناسب است تا فایل سیستم تا حد امکان فضای بلااستفاده کمتری داشته باشد. این تضمین می کند که دستگاه فضایی را که می تواند برای OTA استفاده شود هدر نمی دهد.
علاوه بر این، تصاویر ext4 را میتوان با فعال کردن حذف مجدد در سطح بلوک فشردهتر کرد. برای فعال کردن این، از تنظیمات زیر استفاده کنید:
BOARD_EXT4_SHARE_DUP_BLOCKS := true
اگر تخصیص خودکار حداقل اندازه پارتیشن نامطلوب باشد، دو راه برای کنترل اندازه پارتیشن وجود دارد. میتوانید حداقل فضای خالی را با BOARD_ partition IMAGE_PARTITION_RESERVED_SIZE
تعیین کنید، یا میتوانید BOARD_ partition IMAGE_PARTITION_SIZE
را تعیین کنید تا پارتیشنهای پویا را به یک اندازه خاص وادار کنید. هیچ کدام از اینها توصیه نمی شود مگر در موارد ضروری.
به عنوان مثال:
BOARD_PRODUCTIMAGE_PARTITION_RESERVED_SIZE := 52428800
این باعث می شود سیستم فایل در product.img
50 مگابایت فضای بلااستفاده داشته باشد.
تغییرات سیستم به عنوان ریشه
دستگاه هایی که با اندروید 10 راه اندازی می شوند نباید از سیستم به عنوان ریشه استفاده کنند.
دستگاههای دارای پارتیشنهای پویا (چه با پارتیشنهای دینامیک راهاندازی شوند یا بهروزرسانی شوند) نباید از system-as-root استفاده کنند. هسته لینوکس نمی تواند پارتیشن super
را تفسیر کند و بنابراین نمی تواند خود system
نصب کند. اکنون system
توسط init
مرحله اول که در ramdisk قرار دارد نصب شده است.
BOARD_BUILD_SYSTEM_ROOT_IMAGE
را تنظیم نکنید. در Android 10، پرچم BOARD_BUILD_SYSTEM_ROOT_IMAGE
فقط برای تشخیص اینکه آیا سیستم توسط هسته نصب شده است یا توسط مرحله اول init
در ramdisk استفاده می شود.
تنظیم BOARD_BUILD_SYSTEM_ROOT_IMAGE
روی true
باعث ایجاد خطای ساخت می شود در حالی که PRODUCT_USE_DYNAMIC_PARTITIONS
نیز true
است.
وقتی BOARD_USES_RECOVERY_AS_BOOT
روی true تنظیم شود، تصویر بازیابی به صورت boot.img ساخته میشود که حاوی ramdisk بازیابی است. پیش از این، بوت لودر از پارامتر خط فرمان هسته skip_initramfs
برای تصمیم گیری در مورد اینکه در کدام حالت بوت شود استفاده می کرد. برای دستگاه های اندروید 10، بوت لودر نباید skip_initramfs
به خط فرمان هسته ارسال کند. در عوض، bootloader باید androidboot.force_normal_boot=1
برای رد شدن از بازیابی و بوت کردن اندروید معمولی عبور دهد. دستگاههایی که با Android 12 یا جدیدتر راهاندازی میشوند باید از bootconfig برای عبور androidboot.force_normal_boot=1
استفاده کنند.
تنظیمات AVB تغییر می کند
هنگام استفاده از Android Verified Boot 2.0 ، اگر دستگاه از توصیفگرهای پارتیشن زنجیره ای استفاده نمی کند، هیچ تغییری لازم نیست. اگر از پارتیشنهای زنجیرهای استفاده میکنید و یکی از پارتیشنهای تایید شده پویا است، تغییرات لازم است.
در اینجا یک پیکربندی مثال برای دستگاهی است که vbmeta
برای system
و پارتیشنهای vendor
زنجیرهای میکند.
BOARD_AVB_SYSTEM_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem BOARD_AVB_SYSTEM_ALGORITHM := SHA256_RSA2048 BOARD_AVB_SYSTEM_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP) BOARD_AVB_SYSTEM_ROLLBACK_INDEX_LOCATION := 1 BOARD_AVB_VENDOR_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem BOARD_AVB_VENDOR_ALGORITHM := SHA256_RSA2048 BOARD_AVB_VENDOR_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP) BOARD_AVB_VENDOR_ROLLBACK_INDEX_LOCATION := 1
با این پیکربندی، بوت لودر انتظار دارد یک پاورقی vbmeta در انتهای system
و پارتیشن های vendor
پیدا کند. از آنجایی که این پارتیشن ها دیگر برای بوت لودر قابل مشاهده نیستند (در super
قرار دارند)، دو تغییر لازم است.
- پارتیشن های
vbmeta_system
وvbmeta_vendor
را به جدول پارتیشن دستگاه اضافه کنید. برای دستگاههای A/B،vbmeta_system_a
،vbmeta_system_b
،vbmeta_vendor_a
، وvbmeta_vendor_b
را اضافه کنید. اگر یک یا چند مورد از این پارتیشن ها را اضافه کنید، باید به اندازه پارتیشنvbmeta
باشند. - با افزودن
VBMETA_
پرچمهای پیکربندی را تغییر نام دهید و مشخص کنید زنجیرهبندی به کدام پارتیشنها گسترش مییابد:BOARD_AVB_VBMETA_SYSTEM := system BOARD_AVB_VBMETA_SYSTEM_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem BOARD_AVB_VBMETA_SYSTEM_ALGORITHM := SHA256_RSA2048 BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP) BOARD_AVB_VBMETA_SYSTEM_ROLLBACK_INDEX_LOCATION := 1 BOARD_AVB_VBMETA_VENDOR := vendor BOARD_AVB_VBMETA_VENDOR_KEY_PATH := external/avb/test/data/testkey_rsa2048.pem BOARD_AVB_VBMETA_VENDOR_ALGORITHM := SHA256_RSA2048 BOARD_AVB_VBMETA_VENDOR_ROLLBACK_INDEX := $(PLATFORM_SECURITY_PATCH_TIMESTAMP) BOARD_AVB_VBMETA_VENDOR_ROLLBACK_INDEX_LOCATION := 1
ممکن است یک دستگاه از یکی، هر دو یا هیچ یک از این پارتیشن ها استفاده نکند. تغییرات تنها زمانی لازم است که به یک پارتیشن منطقی زنجیر شوند.
تغییرات بوت لودر AVB
اگر بوت لودر libavb را تعبیه کرده است، وصله های زیر را وارد کنید:
- 818cf56740775446285466eda984acedd4baeac0 — "libavb: فقط زمانی از GUID های پارتیشن پرس و جو کنید که خط cmdline به آنها نیاز دارد."
- 5abd6bc2578968d24406d834471adfd995a0c2e9 — "اجازه دهید پارتیشن سیستم وجود نداشته باشد"
- 9ba3b6613b4e5130fa01a11d984c6b5f0eb3af05 — "اصلاح AvbSlotVerifyData->cmdline ممکن است NULL باشد"
اگر از پارتیشن های زنجیره ای استفاده می کنید، یک پچ اضافی اضافه کنید:
- 49936b4c0109411fdd38bd4ba3a32a01c40439a9 — "libavb: پشتیبانی از vbmeta blobs در ابتدای پارتیشن."
خط فرمان کرنل تغییر می کند
یک پارامتر جدید، androidboot.boot_devices
، باید به خط فرمان هسته اضافه شود. این توسط init
برای فعال کردن /dev/block/by-name
استفاده میشود. این باید جزء مسیر دستگاه برای پیوند نمادین نام اصلی ایجاد شده توسط ueventd
باشد، یعنی /dev/block/platform/ device-path /by-name/ partition-name
. دستگاههایی که با Android 12 یا جدیدتر راهاندازی میشوند باید از bootconfig برای ارسال androidboot.boot_devices
برای init
استفاده کنند.
به عنوان مثال، اگر پیوند نمادین پارتیشن فوقالعاده /dev/block/platform/ soc/100000.ufshc /by-name/super
باشد، میتوانید پارامتر خط فرمان را به صورت زیر در فایل BoardConfig.mk اضافه کنید:
BOARD_KERNEL_CMDLINE += androidboot.boot_devices=soc/100000.ufshc
BOARD_BOOTCONFIG += androidboot.boot_devices=soc/100000.ufshc
تغییرات fstab
درخت دستگاه و همپوشانی درخت دستگاه نباید حاوی ورودی های fstab باشد. از یک فایل fstab استفاده کنید که بخشی از ramdisk خواهد بود.
برای پارتیشن های منطقی باید تغییراتی در فایل fstab اعمال شود:
- فیلد fs_mgr flags باید شامل پرچم
logical
و پرچمfirst_stage_mount
معرفی شده در اندروید 10 باشد که نشان می دهد پارتیشن قرار است در مرحله اول نصب شود. - یک پارتیشن ممکن است
avb= vbmeta partition name
به عنوان یک پرچمfs_mgr
مشخص کند و سپس پارتیشنvbmeta
مشخص شده توسط مرحله اولinit
قبل از تلاش برای نصب هر دستگاه مقداردهی اولیه می شود. - فیلد
dev
باید نام پارتیشن باشد.
ورودی های fstab زیر سیستم، فروشنده و محصول را به عنوان پارتیشن های منطقی با رعایت قوانین بالا تنظیم می کنند.
#<dev> <mnt_point> <type> <mnt_flags options> <fs_mgr_flags> system /system ext4 ro,barrier=1 wait,slotselect,avb=vbmeta,logical,first_stage_mount vendor /vendor ext4 ro,barrier=1 wait,slotselect,avb,logical,first_stage_mount product /product ext4 ro,barrier=1 wait,slotselect,avb,logical,first_stage_mount
فایل fstab را در مرحله اول ramdisk کپی کنید.
SELinux تغییر می کند
دستگاه بلوک پارتیشن فوق العاده باید با برچسب super_block_device
علامت گذاری شود. به عنوان مثال، اگر پیوند نمادین پارتیشن فوق العاده /dev/block/platform/ soc/100000.ufshc /by-name/super
است، خط زیر را به file_contexts
اضافه کنید:
/dev/block/platform/soc/10000\.ufshc/by-name/super u:object_r:super_block_device:s0
فست بوت
بوت لودر (یا هر ابزار چشمک زن غیر فضای کاربری) پارتیشن های پویا را درک نمی کند، بنابراین نمی تواند آنها را فلش کند. برای رفع این مشکل، دستگاه ها باید از یک پیاده سازی فضای کاربری پروتکل fastboot به نام fastbootd استفاده کنند.
برای اطلاعات بیشتر در مورد نحوه اجرای fastbootd، به انتقال Fastboot به فضای کاربری مراجعه کنید.
نصب مجدد adb
برای توسعه دهندگانی که از بیلدهای eng یا userdebug استفاده می کنند، adb remount
برای تکرار سریع بسیار مفید است. پارتیشن های پویا مشکلی را برای adb remount
ایجاد می کنند زیرا دیگر فضای خالی در هر فایل سیستم وجود ندارد. برای رفع این مشکل، دستگاه ها می توانند همپوشانی ها را فعال کنند. تا زمانی که فضای خالی در پارتیشن فوق العاده وجود دارد، adb remount
به طور خودکار یک پارتیشن پویا موقت ایجاد می کند و از overlayf ها برای نوشتن استفاده می کند. پارتیشن موقت scratch
نام دارد، بنابراین از این نام برای پارتیشن های دیگر استفاده نکنید.
برای اطلاعات بیشتر در مورد نحوه فعال کردن همپوشانی ها، روی همپوشانی README در AOSP مراجعه کنید.
دستگاه های اندروید را ارتقا دهید
اگر دستگاهی را به اندروید 10 ارتقا می دهید و می خواهید پشتیبانی از پارتیشن های پویا را در OTA قرار دهید، نیازی به تغییر جدول پارتیشن داخلی ندارید. برخی از تنظیمات اضافی مورد نیاز است.
پیکربندی دستگاه تغییر می کند
برای بازسازی پارتیشن بندی پویا، پرچم های زیر را در device.mk
اضافه کنید:
PRODUCT_USE_DYNAMIC_PARTITIONS := true PRODUCT_RETROFIT_DYNAMIC_PARTITIONS := true
تغییرات پیکربندی برد
شما باید متغیرهای برد زیر را تنظیم کنید:
-
BOARD_SUPER_PARTITION_BLOCK_DEVICES
را روی فهرست دستگاههای بلوک مورد استفاده برای ذخیره وسعت پارتیشنهای پویا تنظیم کنید. این لیستی از نام پارتیشن های فیزیکی موجود در دستگاه است. -
BOARD_SUPER_PARTITION_ partition _DEVICE_SIZE
را به ترتیب به اندازه هر دستگاه بلوک درBOARD_SUPER_PARTITION_BLOCK_DEVICES
تنظیم کنید. این لیست اندازه پارتیشن های فیزیکی موجود در دستگاه است. این معمولاًBOARD_ partition IMAGE_PARTITION_SIZE
در پیکربندیهای برد موجود است. -
BOARD_ partition IMAGE_PARTITION_SIZE
را برای همه پارتیشنهای موجود درBOARD_SUPER_PARTITION_BLOCK_DEVICES
لغو تنظیم کنید. -
BOARD_SUPER_PARTITION_SIZE
را روی مجموعBOARD_SUPER_PARTITION_ partition _DEVICE_SIZE
تنظیم کنید. -
BOARD_SUPER_PARTITION_METADATA_DEVICE
را روی دستگاه بلوکی که در آن فراداده پارتیشن پویا ذخیره می شود، تنظیم کنید. باید یکی ازBOARD_SUPER_PARTITION_BLOCK_DEVICES
باشد. معمولاً این رویsystem
تنظیم می شود. - به ترتیب
BOARD_SUPER_PARTITION_GROUPS
،BOARD_ group _SIZE
وBOARD_ group _PARTITION_LIST
را تنظیم کنید. برای جزئیات بیشتر به تغییرات پیکربندی برد در دستگاه های جدید مراجعه کنید.
به عنوان مثال، اگر دستگاه از قبل دارای پارتیشنهای سیستم و فروشنده است و میخواهید آنها را به پارتیشنهای پویا تبدیل کنید و یک پارتیشن محصول جدید در طول بهروزرسانی اضافه کنید، این پیکربندی برد را تنظیم کنید:
BOARD_SUPER_PARTITION_BLOCK_DEVICES := system vendor BOARD_SUPER_PARTITION_METADATA_DEVICE := system # Rename BOARD_SYSTEMIMAGE_PARTITION_SIZE to BOARD_SUPER_PARTITION_SYSTEM_DEVICE_SIZE. BOARD_SUPER_PARTITION_SYSTEM_DEVICE_SIZE := <size-in-bytes> # Rename BOARD_VENDORIMAGE_PARTITION_SIZE to BOARD_SUPER_PARTITION_VENDOR_DEVICE_SIZE BOARD_SUPER_PARTITION_VENDOR_DEVICE_SIZE := <size-in-bytes> # This is BOARD_SUPER_PARTITION_SYSTEM_DEVICE_SIZE + BOARD_SUPER_PARTITION_VENDOR_DEVICE_SIZE BOARD_SUPER_PARTITION_SIZE := <size-in-bytes> # Configuration for dynamic partitions. For example: BOARD_SUPER_PARTITION_GROUPS := group_foo BOARD_GROUP_FOO_SIZE := <size-in-bytes> BOARD_GROUP_FOO_PARTITION_LIST := system vendor product
SELinux تغییر می کند
دستگاه های بلوک پارتیشن فوق العاده باید با ویژگی super_block_device_type
علامت گذاری شوند. برای مثال، اگر دستگاه از قبل دارای پارتیشنهای system
و vendor
است، میخواهید از آنها بهعنوان دستگاههای بلوک برای ذخیره گسترههای پارتیشنهای پویا استفاده کنید، و پیوندهای نمادین آنها بهعنوان system_block_device
علامتگذاری میشوند:
/dev/block/platform/soc/10000\.ufshc/by-name/system u:object_r:system_block_device:s0 /dev/block/platform/soc/10000\.ufshc/by-name/vendor u:object_r:system_block_device:s0
سپس خط زیر را به device.te
اضافه کنید:
typeattribute system_block_device super_block_device_type;
برای پیکربندی های دیگر، به پیاده سازی پارتیشن های پویا در دستگاه های جدید مراجعه کنید.
برای اطلاعات بیشتر درباره بهروزرسانیهای مقاومسازی، OTA برای دستگاههای A/B بدون پارتیشن پویا را ببینید.
تصاویر کارخانه
برای دستگاهی که با پشتیبانی از پارتیشنهای پویا راهاندازی میشود، از استفاده از userspace fastboot برای فلش کردن تصاویر کارخانه خودداری کنید، زیرا بوت شدن در فضای کاربر کندتر از سایر روشهای فلش کردن است.
برای رفع این مشکل، make dist
اکنون یک تصویر super.img
اضافی می سازد که می تواند مستقیماً به پارتیشن فوق العاده فلش شود. این به طور خودکار محتویات پارتیشن های منطقی را بسته بندی می کند، به این معنی که شامل system.img
، vendor.img
و غیره، علاوه بر ابرداده های پارتیشن super
است. این تصویر را می توان مستقیماً بدون هیچ ابزار اضافی یا با استفاده از fastbootd به پارتیشن super
فلش کرد. پس از ساخت، super.img
در ${ANDROID_PRODUCT_OUT}
قرار می گیرد.
برای دستگاههای A/B که با پارتیشنهای پویا راهاندازی میشوند، super.img
حاوی تصاویر در شکاف A است. پس از فلش مستقیم تصویر فوق العاده، قبل از راه اندازی مجدد دستگاه، شکاف A را به عنوان قابل بوت علامت گذاری کنید.
برای دستگاههای مقاومسازی، make dist
مجموعهای از تصاویر super_*.img
را ایجاد کنید که میتوانند مستقیماً به پارتیشنهای فیزیکی مربوطه فلش شوند. برای مثال، زمانی که BOARD_SUPER_PARTITION_BLOCK_DEVICES
فروشنده سیستم است، ساختهای dist super_system.img
و super_vendor.img
را make dist
. این تصاویر در پوشه OTA در target_files.zip
قرار می گیرند.
دستگاه نقشهبردار ذخیرهسازی-تنظیم دستگاه
پارتیشن بندی پویا تعدادی از اشیاء نقشهبردار دستگاه غیر قطعی را در خود جای میدهد. اینها ممکن است همه آنطور که انتظار میرود نمونهسازی نشوند، بنابراین باید همه مانتها را ردیابی کنید و ویژگیهای Android همه پارتیشنهای مرتبط را با دستگاههای ذخیرهسازی زیربناییشان بهروزرسانی کنید.
مکانیزمی در داخل init
مانت ها را ردیابی می کند و به طور ناهمزمان ویژگی های اندروید را به روز می کند. مدت زمانی که این کار طول می کشد تضمین نمی شود که در یک دوره خاص باشد، بنابراین باید زمان کافی برای واکنش همه محرک های on property
فراهم کنید. ویژگی ها dev.mnt.blk. <partition>
به عنوان مثال dev.mnt.blk. <partition>
که در آن <partition>
root
، system
، data
یا vendor
است. همانطور که در این مثال ها نشان داده شده است، هر ویژگی با نام دستگاه ذخیره سازی پایه مرتبط است:
taimen:/ % getprop | grep dev.mnt.blk [dev.mnt.blk.data]: [sda] [dev.mnt.blk.firmware]: [sde] [dev.mnt.blk.metadata]: [sde] [dev.mnt.blk.persist]: [sda] [dev.mnt.blk.root]: [dm-0] [dev.mnt.blk.vendor]: [dm-1] blueline:/ $ getprop | grep dev.mnt.blk [dev.mnt.blk.data]: [dm-4] [dev.mnt.blk.metadata]: [sda] [dev.mnt.blk.mnt.scratch]: [sda] [dev.mnt.blk.mnt.vendor.persist]: [sdf] [dev.mnt.blk.product]: [dm-2] [dev.mnt.blk.root]: [dm-0] [dev.mnt.blk.system_ext]: [dm-3] [dev.mnt.blk.vendor]: [dm-1] [dev.mnt.blk.vendor.firmware_mnt]: [sda]
زبان init.rc
اجازه میدهد تا ویژگیهای Android را به عنوان بخشی از قوانین گسترش دهند و دستگاههای ذخیرهسازی را میتوان در صورت نیاز با دستوراتی مانند این توسط پلتفرم تنظیم کرد:
write /sys/block/${dev.mnt.blk.root}/queue/read_ahead_kb 128 write /sys/block/${dev.mnt.blk.data}/queue/read_ahead_kb 128
هنگامی که پردازش دستور در مرحله دوم شروع init
شود، epoll loop
فعال می شود و مقادیر شروع به به روز رسانی می کنند. با این حال، از آنجایی که تریگرهای ویژگی تا init
فعال نیستند، نمیتوان از آنها در مراحل اولیه راهاندازی برای مدیریت root
، system
یا vendor
استفاده کرد. ممکن است انتظار داشته باشید که read_ahead_kb
پیشفرض کرنل تا زمانی که اسکریپتهای init.rc
نتوانند در early-fs
(زمانی که دیمونها و امکانات مختلف شروع میشوند) نادیده گرفته شوند، کافی باشد. بنابراین، Google توصیه میکند که از ویژگی on property
، همراه با یک ویژگی init.rc
-controlled مانند sys.read_ahead_kb
، برای مقابله با زمانبندی عملیات و جلوگیری از شرایط مسابقه، مانند مثالهای زیر، استفاده کنید:
on property:dev.mnt.blk.root=* && property:sys.read_ahead_kb=* write /sys/block/${dev.mnt.blk.root}/queue/read_ahead_kb ${sys.read_ahead_kb:-2048} on property:dev.mnt.blk.system=* && property:sys.read_ahead_kb=* write /sys/block/${dev.mnt.blk.system}/queue/read_ahead_kb ${sys.read_ahead_kb:-2048} on property:dev.mnt.blk.vendor=* && property:sys.read_ahead_kb=* write /sys/block/${dev.mnt.blk.vendor}/queue/read_ahead_kb ${sys.read_ahead_kb:-2048} on property:dev.mnt.blk.product=* && property:sys.read_ahead_kb=* write /sys/block/${dev.mnt.blk.system_ext}/queue/read_ahead_kb ${sys.read_ahead_kb:-2048} on property:dev.mnt.blk.oem=* && property:sys.read_ahead_kb=* write /sys/block/${dev.mnt.blk.oem}/queue/read_ahead_kb ${sys.read_ahead_kb:-2048} on property:dev.mnt.blk.data=* && property:sys.read_ahead_kb=* write /sys/block/${dev.mnt.blk.data}/queue/read_ahead_kb ${sys.read_ahead_kb:-2048} on early-fs: setprop sys.read_ahead_kb ${ro.read_ahead_kb.boot:-2048} on property:sys.boot_completed=1 setprop sys.read_ahead_kb ${ro.read_ahead_kb.bootcomplete:-128}