На этой странице описывается, как создавать, запускать и разрабатывать функции загрузчика Android на устройстве Cuttlefish.
Исходники AOSP
Для разработки функций загрузчика Android используйте конфигурацию U-boot Cuttlefish с Cuttlefish в aosp-main
или в ветвях общего образа системы (GSI) для Android 11 или более поздней версии. Ниже приведены источники в AOSP:
Разработать загрузчик
Чтобы создать, запустить и разработать функции загрузчика локально, выполните следующие действия:
Клонируйте манифест 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
Создайте целевой загрузчик, соответствующий вашей архитектуре 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
.Запустите устройство 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
Для взаимодействия с загрузчиком подключитесь к консоли загрузчика.
$ screen ~/cuttlefish_runtime/console
Завершив взаимодействие с загрузчиком, продолжите загрузку, введя
boot
в консоль.
Тестирование потока загрузчика с разными ядрами
Чтобы протестировать поток загрузчика с различными ядрами или модулями ядра, передайте целевые артефакты (ядро и модули ядра), используя аргументы --kernel_path
и --initramfs_path
. Ассемблер переупаковывает загрузочные образы на основе артефактов, переданных в аргументах.
cvd create \
-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 .
,На этой странице описывается, как создавать, запускать и разрабатывать функции загрузчика Android на устройстве Cuttlefish.
Исходники AOSP
Для разработки функций загрузчика Android используйте конфигурацию U-boot Cuttlefish с Cuttlefish в aosp-main
или в ветвях общего образа системы (GSI) для Android 11 или более поздней версии. Ниже приведены источники в AOSP:
Разработать загрузчик
Чтобы создать, запустить и разработать функции загрузчика локально, выполните следующие действия:
Клонируйте манифест 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
Создайте целевой загрузчик, соответствующий вашей архитектуре 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
.Запустите устройство 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
Для взаимодействия с загрузчиком подключитесь к консоли загрузчика.
$ screen ~/cuttlefish_runtime/console
Завершив взаимодействие с загрузчиком, продолжите загрузку, введя
boot
в консоль.
Тестирование потока загрузчика с разными ядрами
Чтобы протестировать поток загрузчика с различными ядрами или модулями ядра, передайте целевые артефакты (ядро и модули ядра), используя аргументы --kernel_path
и --initramfs_path
. Ассемблер переупаковывает загрузочные образы на основе артефактов, переданных в аргументах.
cvd create \
-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 .