Image DTB

Implementasi Android dapat menyertakan image blob hierarki perangkat (DTB) untuk digunakan oleh bootloader. Lokasi image DTB (dan opsi untuk menentukan parameter image DTB) berbeda-beda di antara rilis Android.

  • Di Android 11, perangkat yang menggunakan Generic Kernel Image (GKI) harus mendukung partisi booting vendor, yang mencakup semua informasi khusus vendor yang dipindahkan dari partisi booting. Karena image DTB berisi data khusus vendor, image tersebut kini menjadi bagian dari partisi booting vendor. Untuk menentukan parameter image DTB, lihat Header boot vendor.

  • Di Android 10, perangkat dapat menyertakan image DTB di partisi booting. Untuk menentukan parameter image DTB, lihat Menyertakan image DTB dalam image booting.

  • Di Android 9 dan yang lebih lama, image DTB dapat berada di partisi sendiri atau ditambahkan ke kernel image.gz untuk membuat kernel + image DTB (yang kemudian diteruskan ke mkbootimg untuk membuat boot.img).

Format gambar DTB

Di Android 10 dan yang lebih tinggi, image DTB harus menggunakan salah satu format berikut:

  • Blob DT yang digabungkan satu per satu. Bootloader menggunakan kolom totalsize di setiap header FDT untuk membaca dan mengurai blob yang sesuai.

  • Partisi DTB/DTBO. Bootloader memiliki cara yang efisien untuk memilih blob DT yang benar dengan memeriksa struct dt_table_entry (berisi kolom id, rev, dan custom) yang dapat menyimpan informasi identifikasi hardware untuk entri. Untuk mengetahui detailnya, lihat Partisi DTB/DTBO.

Menyertakan image DTB dalam image booting

Perangkat yang menjalankan Android 10 dapat menyertakan image DTB dalam image booting. Hal ini menghilangkan kebutuhan Android untuk mendukung skrip yang menambahkan gambar DTB ke image.gz di kernel, dan memungkinkan penggunaan pengujian Vendor Test Suite (VTS) untuk memverifikasi (dan menstandarkan) penempatan DTB.

Selain itu, untuk perangkat non-A/B, sebaiknya gunakan DTB sebagai bagian dari gambar pemulihan, bukan di partisi terpisah untuk mencegah masalah yang disebabkan oleh OTA yang terganggu. Selama OTA, jika masalah terjadi setelah partisi DTB diupdate (tetapi sebelum menyelesaikan update penuh), perangkat akan mencoba melakukan booting ke mode pemulihan untuk menyelesaikan OTA; Namun, karena partisi DTB telah diupdate, ketidakcocokan dapat terjadi dengan image pemulihan (yang belum diupdate). Memiliki image DTB sebagai bagian dari format image booting mencegah masalah tersebut dengan membuat image pemulihan mandiri (yaitu, tidak bergantung pada partisi lain).

Struktur image booting

Perangkat yang menjalankan Android 10 dapat menyertakan image DTB menggunakan struktur image booting berikut.

Bagian image booting Jumlah halaman
Header booting (1 halaman) 1
Kernel (halaman l) l = (kernel_size + page_size - 1) / page_size
Ramdisk (m halaman) m = (ramdisk_size + page_size - 1) / page_size
Bootloader tahap kedua (n halaman) n = (second_size + page_size - 1) / page_size
DTBO pemulihan (o halaman) o = (recovery_dtbo_size + page_size - 1) / page_size
DTB (halaman p) p = (dtb_size + page_size - 1) / page_size

Jalur image DTB

Untuk perangkat yang menjalankan Android 10, Anda dapat menggunakan alat mkbootimg.py dan argumen berikut untuk menentukan jalur ke image DTB.

Argumen Deskripsi
dtb Jalur ke image DTB yang akan disertakan dalam image booting/pemulihan.
dtb_offset Saat ditambahkan ke argumen base, memberikan alamat pemuatan fisik untuk hierarki perangkat akhir. Misalnya, jika argumen base adalah 0x10000000 dan argumen dtb_offset adalah 0x01000000, dtb_addr_field di header image booting akan diisi sebagai 0x11000000.

Variabel konfigurasi board BOARD_PREBUILT_DTBIMAGE_DIR harus digunakan untuk menentukan jalur ke image DTB. Jika lebih dari satu file dengan ekstensi *.dtb ada di direktori BOARD_PREBUILT_DTBIMAGE_DIR, sistem build Android akan menyambungkan file untuk membuat image DTB akhir yang digunakan dalam pembuatan image booting.

Untuk meneruskan argumen dtb ke mkbootimg.py dengan image DTB dari direktori yang ditentukan oleh BOARD_PREBUILT_DTBIMAGE_DIR, variabel konfigurasi papan BOARD_INCLUDE_DTB_IN_BOOTIMG harus ditetapkan ke true. Contoh:

BOARD_INCLUDE_DTB_IN_BOOTIMG := true

Anda dapat menambahkan argumen dtb_offset ke variabel konfigurasi board BOARD_MKBOOTIMG_ARGS dengan offset dan versi header lainnya. Contoh:

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)

Dukungan bootloader

Agar VTS berhasil berjalan di perangkat yang menjalankan Android 10, bootloader harus mendukung image booting yang diupdate dan harus menambahkan parameter command line kernel androidboot.dtb_idx untuk menunjukkan indeks hierarki perangkat (DT) yang dipilih. Anda hanya dapat menentukan satu (1) indeks. Misalnya, parameter androidboot.dtb_idx=N melaporkan N sebagai indeks berbasis nol dari hierarki perangkat yang dipilih oleh bootloader dari kumpulan DTB yang ada dalam image booting.