Android 11 introduce il concetto di immagine del kernel generica e la partizione di avvio del fornitore. La partizione di avvio del fornitore memorizza i moduli del kernel compatibili con GKI e viene caricata dall'inizializzazione della prima fase. I moduli del kernel precedenti al rilascio di Android 11 vengono archiviati anche nelle partizioni vendor e ODM e vengono caricati dai processi del fornitore.
Per Android 11 o versioni successive, il kernel e tutti i moduli del kernel possono essere aggiornati indipendentemente dal resto delle partizioni. Per attivare gli aggiornamenti per i moduli kernel archiviati nella partizione fornitore (senza un aggiornamento della partizione fornitore), sposta tutti i moduli della partizione fornitore in una nuova partizione denominata Vendor DLKM (modulo kernel caricabile dinamicamente). Puoi quindi aggiornare questa partizione in modo indipendente. Allo stesso modo, puoi spostare tutti i moduli del kernel archiviati nella partizione ODM in una nuova partizione denominata ODM DLKM. Questa partizione può essere aggiornata anche in modo indipendente.
Posizione della partizione
Le partizioni vendor_dlkm
e odm_dlkm
si trovano nella superpartizione come
un'altra partizione dinamica.
vendor_dlkm contents in /vendor/lib/modules
- Moduli kernel del fornitore
modprobe
file di configurazione- Un file
modules.load
Contenuti di odm_dlkm in /odm/lib/modules
- Moduli kernel ODM
modprobe
file di configurazione- Un file
modules.load
Per ulteriori dettagli sui file di configurazione dei moduli del kernel, consulta Supporto dei moduli del kernel.
Supporto per la build
La creazione di vendor_dlkm
e odm_dlkm
è simile a quella di altre partizioni dinamiche.
vendor_dlkm build example
Crea vendor_dlkm
come mostrato negli esempi seguenti.
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
Sostituisci <GROUP_NAME>
con il nome appropriato del gruppo di aggiornamento. Il gruppo di aggiornamento deve essere il gruppo in cui si trova la partizione del fornitore.
Per i dispositivi A/B e A/B virtuale, device.mk
AB_OTA_PARTITIONS += vendor_dlkm
fstab
Aggiungi la seguente voce per vendor_dlkm
a fstab. Modifica i flag in base
al dispositivo. Utilizza la CL Aggiungi vendor_dlkm
a
CF
come esempio.
vendor_dlkm /vendor_dlkm ext4 noatime,ro,errors=panic wait,logical,first_stage_mount,slotselect,avb
odm_dlkm build example
Crea odm_dlkm
come mostrato negli esempi seguenti.
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
Per i dispositivi A/B e A/B virtuali, device.mk
AB_OTA_PARTITIONS += odm_dlkm
fstab
Aggiungi la seguente voce per odm_dlkm
a fstab. Modifica i flag in base al
dispositivo. Utilizza la CL Aggiungi odm_dlkm
a
CF
come esempio.
odm_dlkm /odm_dlkm ext4 noatime,ro,errors=panic wait,logical,first_stage_mount,slotselect,avb
Copiare i moduli del kernel in una partizione
Per selezionare i moduli del kernel da copiare nella partizione vendor_dlkm
,
elencali in BOARD_VENDOR_KERNEL_MODULES
.
Se vuoi ignorare i contenuti di modules.load
, puoi specificarli in
BOARD_VENDOR_KERNEL_MODULES_LOAD
.
Al momento della build, i moduli elencati in BOARD_VENDOR_KERNEL_MODULES
vengono installati
in $ANDROID_PRODUCT_OUT/vendor_dlkm/lib/modules
. Un link simbolico
viene creato in /vendor/lib/modules
e rimanda a /vendor_dlkm/lib/modules
.
Allo stesso modo, per selezionare i moduli del kernel da copiare nella partizione odm_dlkm
, elencali in BOARD_ODM_KERNEL_MODULES
. La build della piattaforma esegue
depmod
sui moduli e copia i file di output depmod
nell'immagine.
La build crea un file modules.load
e lo archivia nell'immagine.
Questo file contiene tutti i moduli elencati in BOARD_ODM_KERNEL_MODULES
.
Se vuoi ignorare i contenuti di modules.load
, puoi specificarli in
BOARD_ODM_KERNEL_MODULES_LOAD
.
Al momento della compilazione, i moduli elencati in BOARD_ODM_KERNEL_MODULES
vengono installati in
$ANDROID_PRODUCT_OUT/odm_dlkm/lib/modules
. Viene creato un link simbolico in
/odm/lib/modules
che porta a /odm_dlkm/lib/modules
.
Utilizza sempre /vendor/lib/modules
e /odm/lib/modules
per i moduli kernel del fornitore
e dell'ODM.
Non utilizzare mai /vendor_dlkm/lib/modules. I dispositivi senza una partizione vendor_dlkm
installano BOARD_VENDOR_KERNEL_MODULES
direttamente su /vendor/lib/modules
. Ciò costituisce un problema, in quanto /vendor_dlkm/lib/modules
non esiste.
Non utilizzare mai /odm_dlkm/lib/modules
. I dispositivi senza una partizione odm_dlkm
installano BOARD_ODM_KERNEL_MODULES
direttamente su /odm/lib/modules
. Questo è
problematico perché /odm_dlkm/lib/modules
non esiste.
Montaggio della partizione e caricamento del modulo
Durante first_stage_init
, le partizioni vendor_dlkm
e odm_dlkm
vengono
montate rispettivamente nelle directory /vendor_dlkm
e /odm_dlkm
. Quando
ciò accade, i link simbolici in /vendor/lib/modules
e /odm/lib/modules
diventano
disponibili.
Un processo fornitore (come uno script .rc
) può quindi caricare i moduli del kernel in base
all'ordine specificato in modules.load
. Se necessario, la procedura del fornitore può anche caricare i moduli in un secondo momento.
Documentazione correlata
Per la documentazione relativa alla creazione di una partizione vendor-boot (che contiene il RAMDisk del fornitore), consulta Supporto dei moduli del kernel.