Android 10 поддерживает динамические разделы — систему разделения пользовательского пространства, которая может создавать, изменять размер и уничтожать разделы во время беспроводных обновлений (OTA).
На этой странице описано, как изменить размер динамических разделов во время обновления для устройств A/B, запущенных с поддержкой динамических разделов, для устройств под управлением Android 9 и более ранних версий .
Фон
На устройстве есть один super
. Этот раздел не имеет суффикса слота. Блочное устройство должно существовать вместе с записью blk_device
для /misc
в fstab
. Например, если в файле fstab
указано:
/dev/block/bootdevice/by-name/misc /misc # Other fields
Тогда блочное устройство для super
должно существовать в /dev/block/bootdevice/by-name/super
, но раздел super
не обязательно должен быть указан в файле fstab
.
В super
есть два слота метаданных с номерами 0 и 1, соответствующие слотам A/B для разделов. На этой странице слоты метаданных называются Метаданные S (источник) и Метаданные T (цель). Аналогичным образом разделы называются system_s
, vendor_t
и т. д.
Перед обновлением метаданные S содержат информацию об используемых динамических разделах (обычно system_s
, vendor_s
, product_s
и т. д.). Система считывает экстенты этих разделов во время обновления, поэтому их невозможно удалить.
Разделы принадлежат группам обновлений . Подробности см. в разделе «Реализация динамических разделов» .
Ниже приведен пример метаданных на устройстве.
- Метаданные 0
- Группа
foo_a
-
system_a
разделов_a - Раздел
product_services_a
- Другие разделы обновлены Foo
-
- Группа bar_a
-
vendor_a
- Раздел
product_a
- Другие разделы обновлены Баром
-
- Группа
foo_b
(осталась от предыдущего обновления) - Группа
bar_b
(осталась от предыдущего обновления)
- Группа
- Метаданные 1
- Группа
foo_a
(осталась от предыдущего обновления) - Группа
bar_a
(осталась от предыдущего обновления) - Группа
foo_b
-
system_b
разделов_b - Раздел
product_services_b
- Другие разделы обновлены Foo
-
- Группа
bar_b
-
vendor_b
- Раздел
product_b
- Другие разделы обновлены Баром
-
- Группа
Вы можете использовать инструмент lpdump
(исходный код в разделе system/extras/partition_tools
), чтобы сбросить метаданные на ваше устройство. Например:
lpdump --slot 0 /dev/block/bootdevice/by-name/super
lpdump --slot 1 /dev/block/bootdevice/by-name/super
Обновление потока
- Инициализируйте метаданные
super
.- Загрузите экстенты исходных динамических разделов из метаданных S. Пусть M — загруженные метаданные.
- Удалите целевые группы и разделы (например,
foo_t
,bar_t
) из M, чтобы M содержал только разделы и группы с суффиксом_s
. - Добавьте целевые группы и разделы в соответствии с полем
dynamic_partition_metadata
в манифесте обновления.
Размер каждого раздела можно найти вnew_partition_info
. - Запишите M в метаданные T.
- Сопоставьте добавленные разделы в сопоставителе устройств как доступные для записи.
- Примените обновление на блочных устройствах.
- При необходимости сопоставьте исходные разделы в сопоставителе устройств как доступные только для чтения. Это необходимо для загрузки неопубликованных файлов, поскольку исходные разделы не сопоставляются до обновления.
- Примените полное или дельта-обновление ко всем блочным устройствам в целевом слоте.
- Подключите разделы, чтобы запустить сценарий после установки, а затем отключите разделы.
- Отмените сопоставление целевых разделов.
До и после обновления следующие системные свойства должны иметь соответствующие значения:
ro.boot.dynamic_partitions=true ro.boot.dynamic_partitions_retrofit=true
Добавьте группы и разделы в манифест обновления.
При выполнении OTA-обновления на устройстве A/B с динамическими разделами или на устройстве A/B, в котором добавляется поддержка динамических разделов, вам необходимо добавить группы и разделы в манифест обновления. Во фрагменте ниже показана дополнительная информация о манифесте обновления для поддержки динамических разделов. См. update_metadata.proto для получения подробной документации по каждому полю.
message DeltaArchiveManifest { optional DynamicPartitionMetadata dynamic_partition_metadata; } message DynamicPartitionMetadata { repeated DynamicPartitionGroup groups; } message DynamicPartitionGroup { required string name; optional uint64 size; // maximum size of group repeated string partition_names; }