Le implementazioni Android possono includere un'immagine DTB (Device Tree Blob) da utilizzare il bootloader. La posizione dell'immagine DTB (e le opzioni per specificare i parametri immagine DTB) variano a seconda delle release di Android.
In Android 11, i dispositivi che utilizzano l'immagine del kernel generico (GKI) devono supportare la partizione di avvio del fornitore, che include tutte le informazioni specifiche del fornitore spostate dalla partizione di avvio. Poiché l'immagine DTB contiene dati specifici del fornitore, parte della partizione di avvio del fornitore. Per specificare i parametri delle immagini DTB, consulta Intestazione boot del fornitore.
In Android 10, i dispositivi possono includere l'immagine DTB nella partizione di avvio. Per specificare i parametri dell'immagine DTB, consulta Inclusione dell'immagine DTB nell'immagine di avvio.
In Android 9 e versioni precedenti, l'immagine DTB può esistere in propria partizione o essere aggiunto al kernel
image.gz
per creare il kernel + immagine DTB (che viene poi passata amkbootimg
per creareboot.img
).
Formato dell'immagine DTB
In Android 10 e versioni successive, l'immagine DTB deve utilizzare una dei seguenti formati:
BLOB DT concatenati uno dopo l'altro. Il bootloader utilizza la classe Campo
totalsize
in ogni intestazione FDT per leggere e analizzare il blob corrispondente.Partizioni DTB/DTBO. Il bootloader ha un modo efficiente per selezionare il blob DT corretto esaminando la struttura
dt_table_entry
(contiene i campiid
,rev
ecustom
) che può contenere informazioni di identificazione dell'hardware per la voce. Per maggiori dettagli, vedi DTB/DTBO Partitions.
Includi l'immagine DTB nell'immagine di avvio
I dispositivi con Android 10 possono includere l'immagine DTB nell'immagine di avvio. In questo modo, Android non dovrà più supportare script che aggiungono
l'immagine DTB in image.gz
nel kernel e consente l'uso di Test del fornitore
Test Suite (VTS) per verificare (e standardizzare) i DTB
posizionamento.
Inoltre, per i dispositivi non A/B, è più sicuro avere il DTB all'interno dell'immagine di recupero anziché in una partizione separata per evitare problemi causati da OTA interrotte. Durante un aggiornamento OTA, se si verifica un problema dopo l'aggiornamento della partizione DTB (ma prima del completamento dell'aggiornamento completo), il dispositivo tenta di avviarsi in modalità di ripristino per completare l'OTA. Tuttavia, poiché la partizione DTB è già stata aggiornata, potrebbe verificarsi una mancata corrispondenza con l'immagine di ripristino (che non è stata ancora aggiornata). L'immagine DTB all'interno del formato dell'immagine di avvio previene questi problemi rendendo l'immagine di ripristino autosufficiente (ovvero non dipende da un'altra partizione).
Struttura dell'immagine di avvio
I dispositivi con Android 10 possono includere un'immagine DTB utilizzando la seguente struttura di immagini di avvio.
Sezione Immagine di avvio | Numero di pagine |
---|---|
Intestazione del boot (1 pagina) | 1 |
Kernel (pagine L) | l = (kernel_size + page_size -
1) / page_size |
Ramdisk (m pagine) | m = (ramdisk_size + page_size -
1) / page_size |
Bootloader di seconda fase (n pagine) | n = (second_size + page_size -
1) / page_size |
DTBO (o pagine) di recupero | o = (recovery_dtbo_size + page_size -
1) / page_size |
DTB (pagine) | p = (dtb_size + page_size -
1) / page_size |
Percorso immagine DTB
Per i dispositivi con Android 10, puoi utilizzare lo strumento mkbootimg.py
e i seguenti argomenti per specificare il percorso dell'immagine DTB.
Argomento | Descrizione |
---|---|
dtb |
Percorso dell'immagine DTB da includere nelle immagini di avvio/ripristino. |
dtb_offset |
Se aggiunta all'argomento base , fornisce il carico fisico
per la struttura di dispositivi finale. Ad esempio, se l'argomento base è 0x10000000 e l'argomento dtb_offset è 0x01000000 , dtb_addr_field nell'intestazione dell'immagine di avvio viene inserito come 0x11000000 . |
È necessario utilizzare la variabile di configurazione della scheda BOARD_PREBUILT_DTBIMAGE_DIR
per specificare
il percorso dell'immagine DTB. Se più di un file con estensione *.dtb
viene
presente nella directory BOARD_PREBUILT_DTBIMAGE_DIR
, il sistema di compilazione di Android
concatena i file per creare l'immagine DTB finale utilizzata nell'immagine di avvio
per la creazione di contenuti.
Per passare l'argomento dtb
a mkbootimg.py
con l'immagine DTB dal
directory specificata da BOARD_PREBUILT_DTBIMAGE_DIR
, la variabile di configurazione della scheda
BOARD_INCLUDE_DTB_IN_BOOTIMG
deve essere impostato su true
. Ad esempio:
BOARD_INCLUDE_DTB_IN_BOOTIMG := true
Puoi aggiungere l'argomento dtb_offset
alla variabile di configurazione della scheda BOARD_MKBOOTIMG_ARGS
con gli altri offset e la versione dell'intestazione. Ad esempio:
BOARD_MKBOOTIMG_ARGS := --ramdisk_offset $(BOARD_RAMDISK_OFFSET) --dtb_offset $(BOARD_DTB_OFFSET) --tags_offset $(BOARD_KERNEL_TAGS_OFFSET) --header_version $(BOARD_BOOTIMG_HEADER_VERSION)
Supporto del bootloader
Affinché VTS venga eseguito correttamente sui dispositivi con Android
10, il bootloader deve supportare l'immagine di avvio aggiornata
e deve aggiungere il parametro della riga di comando androidboot.dtb_idx
del kernel per indicare
l'indice della struttura ad albero dei dispositivi (DT) selezionata. Puoi specificare un solo (1)
indici. Ad esempio, il parametro androidboot.dtb_idx=N
indica N
come
indice a partire da zero della struttura ad albero del dispositivo selezionata dal bootloader dall'insieme di
DTB presenti nell'immagine di avvio.