Partizioni DLKM del fornitore e dell'ODM

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.

Per la documentazione relativa alla creazione di una partizione vendor-boot (che contiene il RAMDisk del fornitore), consulta Supporto dei moduli del kernel.