Разработка функций загрузчика Android

На этой странице описывается, как создавать, запускать и разрабатывать функции загрузчика Android на устройстве Cuttlefish.

Исходники AOSP

Для разработки функций загрузчика Android используйте конфигурацию U-boot Cuttlefish с Cuttlefish в aosp-main или в ветвях общего образа системы (GSI) для Android 11 или более поздней версии. Ниже приведены источники в AOSP:

Разработать загрузчик

Чтобы создать, запустить и разработать функции загрузчика локально, выполните следующие действия:

  1. Клонируйте манифест Android-форка U-boot:

    $ mkdir u-boot-mainline
    $ cd u-boot-mainline
    $ repo init -u https://android.googlesource.com/kernel/manifest -b u-boot-mainline
    $ repo sync -j$(nproc) -q
    
  2. Создайте целевой загрузчик, соответствующий вашей архитектуре Cuttlefish. Например:

    • x86_64

      $ tools/bazel run //u-boot:crosvm_x86_64_dist
      
    • aarch64

      $ tools/bazel run //u-boot:crosvm_aarch64_dist
      

    Полученный двоичный файл загрузчика ( u-boot.bin для Arm64 и u-boot.rom для x86_64) находится в $PATH_TO_REPO/out/u-boot-mainline/dist .

  3. Запустите устройство Cuttlefish с загрузчиком. Включите параметр pause_in_bootloader , чтобы отключить автозагрузку и позволить вам взаимодействовать с загрузчиком.

    $ launch_cvd \
        -bootloader /$PATH/$TO/u-boot-mainline/out/u-boot-mainline/dist/u-boot.rom \
        -pause_in_bootloader -console=true
    
  4. Для взаимодействия с загрузчиком подключитесь к консоли загрузчика.

    $ screen ~/cuttlefish_runtime/console
    
  5. Завершив взаимодействие с загрузчиком, продолжите загрузку, введя boot в консоль.

Тестирование потока загрузчика с разными ядрами

Чтобы протестировать поток загрузчика с различными ядрами или модулями ядра, передайте целевые артефакты (ядро и модули ядра), используя аргументы --kernel_path и --initramfs_path . Ассемблер переупаковывает загрузочные образы на основе артефактов, переданных в аргументах.

cvd start \
    -kernel_path=/$PATH/$TO/common-android14-6.1/out/android14-6.1/dist/bzImage \
    -initramfs_path=/$PATH/$TO/common-android14-6.1/out/android14-6.1/dist/initramfs.img

Дополнительные сведения см. в разделе Разработка ядер Android .