Android 11 представляет концепцию Generic Kernel Image и раздел загрузки поставщика. Раздел загрузки поставщика хранит модули ядра, совместимые с GKI, и загружается на первом этапе init. Модули ядра до выпуска Android 11 также хранятся в разделах поставщика и ODM и загружаются процессами поставщика.
Для Android 11 или выше ядро и все модули ядра могут обновляться независимо от остальных разделов. Чтобы включить обновления для модулей ядра, хранящихся в разделе поставщика (без обновления раздела поставщика), переместите все модули раздела поставщика в новый раздел под названием Vendor DLKM (динамически загружаемый модуль ядра). Затем вы можете обновить этот раздел независимо. Аналогично вы можете переместить все модули ядра, хранящиеся в разделе ODM, в новый раздел под названием ODM DLKM . Этот раздел также можно обновлять независимо.
Расположение раздела
Разделы vendor_dlkm
и odm_dlkm
расположены в суперразделе как еще один динамический раздел.
содержимое vendor_dlkm в /vendor/lib/modules
- Модули ядра поставщика
- Файлы конфигурации
modprobe
- Файл
modules.load
Содержимое odm_dlkm в /odm/lib/modules
- Модули ядра ODM
- Файлы конфигурации
modprobe
- Файл
modules.load
Дополнительную информацию о файлах конфигурации модулей ядра см. в разделе Поддержка модулей ядра.
Поддержка сборки
Создание vendor_dlkm
и odm_dlkm
аналогично созданию других динамических разделов.
пример сборки vendor_dlkm
Соберите vendor_dlkm
, как показано в следующих примерах.
BoardConfig.mk
BOARD_USES_VENDOR_DLKMIMAGE := true
BOARD_VENDOR_DLKMIMAGE_FILE_SYSTEM_TYPE := ext4
TARGET_COPY_OUT_VENDOR_DLKM := vendor_dlkm
BOARD_<GROUP_NAME>_PARTITION_LIST += vendor_dlkm
Замените <GROUP_NAME>
соответствующим именем группы обновления. Группа обновления должна быть группой, в которой находится раздел поставщика.
Для устройств A/B и Virtual A/B, device.mk
AB_OTA_PARTITIONS += vendor_dlkm
fstab
Добавьте следующую запись для vendor_dlkm
в fstab. Измените флаги в соответствии с устройством. Используйте CL Add vendor_dlkm
to CF в качестве примера.
vendor_dlkm /vendor_dlkm ext4 noatime,ro,errors=panic wait,logical,first_stage_mount,slotselect,avb
пример сборки odm_dlkm
Соберите odm_dlkm
, как показано в следующих примерах.
BoardConfig.mk
BOARD_USES_ODM_DLKIMAGE := true
BOARD_ODM_DLKIMAGE_FILE_SYSTEM_TYPE := ext4
TARGET_COPY_OUT_ODM_DLKM := odm_dlkm
BOARD_<group_name>_PARTITION_LIST += odm_dlkm
Для устройств A/B и Virtual A/B, device.mk
AB_OTA_PARTITIONS += odm_dlkm
fstab
Добавьте следующую запись для odm_dlkm
в fstab. Измените флаги в соответствии с устройством. Используйте CL Add odm_dlkm
to CF в качестве примера.
odm_dlkm /odm_dlkm ext4 noatime,ro,errors=panic wait,logical,first_stage_mount,slotselect,avb
Копировать модули ядра в раздел
Чтобы выбрать модули ядра, которые вы хотите скопировать в раздел vendor_dlkm
, перечислите их в BOARD_VENDOR_KERNEL_MODULES
.
Если вы хотите переопределить содержимое modules.load
, вы можете указать это в BOARD_VENDOR_KERNEL_MODULES_LOAD
.
Во время сборки модули, перечисленные в BOARD_VENDOR_KERNEL_MODULES
, устанавливаются в $ANDROID_PRODUCT_OUT/vendor_dlkm/lib/modules
. В /vendor/lib/modules
создается символическая ссылка, ведущая к /vendor_dlkm/lib/modules
.
Аналогично, чтобы выбрать модули ядра, которые вы хотите скопировать в раздел odm_dlkm
, перечислите их в BOARD_ODM_KERNEL_MODULES
. Сборка платформы запускает depmod
на модулях и копирует выходные файлы depmod
в образ. Сборка создает файл modules.load
и сохраняет его в образе. Этот файл содержит все модули, перечисленные в BOARD_ODM_KERNEL_MODULES
.
Если вы хотите переопределить содержимое modules.load
, вы можете указать это в BOARD_ODM_KERNEL_MODULES_LOAD
.
Во время сборки модули, перечисленные в BOARD_ODM_KERNEL_MODULES
, устанавливаются в $ANDROID_PRODUCT_OUT/odm_dlkm/lib/modules
. В /odm/lib/modules
создается символическая ссылка, ведущая к /odm_dlkm/lib/modules
.
Всегда используйте /vendor/lib/modules
и /odm/lib/modules
для модулей ядра поставщика и ODM.
Никогда не используйте /vendor_dlkm/lib/modules. Устройства без раздела vendor_dlkm
устанавливают BOARD_VENDOR_KERNEL_MODULES
в /vendor/lib/modules
напрямую. Это проблематично, так как /vendor_dlkm/lib/modules
не существует.
Никогда не используйте /odm_dlkm/lib/modules
. Устройства без раздела odm_dlkm
устанавливают BOARD_ODM_KERNEL_MODULES
в /odm/lib/modules
напрямую. Это проблематично, так как /odm_dlkm/lib/modules
не существует.
Монтаж перегородок и загрузка модулей
Во время first_stage_init
разделы vendor_dlkm
и odm_dlkm
монтируются в каталоги /vendor_dlkm
и /odm_dlkm
соответственно. Когда это происходит, становятся доступны символические ссылки на /vendor/lib/modules
и /odm/lib/modules
.
Процесс поставщика (например, скрипт .rc
) может затем загрузить модули ядра на основе порядка, указанного в modules.load
. Процесс поставщика может также загрузить модули позднее, если это необходимо.
Сопутствующая документация
Документацию по созданию раздела загрузки поставщика (содержащего RAMDisk поставщика) см. в разделе Поддержка модулей ядра .