Entwickeln Sie Android-Bootloader-Funktionen

Auf dieser Seite wird beschrieben, wie Sie Android-Bootloader- Funktionen auf einem Cuttlefish-Gerät erstellen, ausführen und entwickeln.

AOSP-Quellen

Um Android-Bootloader-Funktionen zu entwickeln, verwenden Sie die Cuttlefish-Konfiguration von U-Boot mit Cuttlefish in aosp-main oder in Generic System Image (GSI) -Zweigen für Android 11 oder höher. Im Folgenden sind die Quellen in AOSP aufgeführt:

Entwickeln Sie einen Bootloader

Gehen Sie folgendermaßen vor, um Bootloader-Funktionen lokal zu erstellen, auszuführen und zu entwickeln:

  1. Klonen Sie das Manifest für den Android-Fork von 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. Erstellen Sie das für Ihre Cuttlefish-Architektur geeignete Bootloader-Ziel. Zum Beispiel:

    • x86_64

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

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

    Die resultierende Bootloader-Binärdatei ( u-boot.bin für arm64 und u-boot.rom für x86_64) befindet sich in $PATH_TO_REPO/out/u-boot-mainline/dist .

  3. Starten Sie das Cuttlefish-Gerät mit dem Bootloader. Fügen Sie den Parameter pause_in_bootloader ein, um Autoboot zu deaktivieren und Ihnen die Interaktion mit dem Bootloader zu ermöglichen.

    $ launch_cvd \
        -bootloader /$PATH/$TO/u-boot-mainline/out/u-boot-mainline/dist/u-boot.rom \
        -pause_in_bootloader -console=true
    
  4. Um mit dem Bootloader zu interagieren, stellen Sie eine Verbindung zur Bootloader-Konsole her.

    $ screen ~/cuttlefish_runtime/console
    
  5. Wenn Sie mit den Bootloader-Interaktionen fertig sind, fahren Sie mit dem Booten fort, indem Sie boot in die Konsole eingeben.

Testen Sie den Bootloader-Fluss mit verschiedenen Kerneln

Um den Bootloader-Ablauf mit verschiedenen Kerneln oder Kernelmodulen zu testen, übergeben Sie die Zielartefakte (Kernel und Kernelmodule) mit den Argumenten --kernel_path und --initramfs_path . Der Assembler packt die Boot-Images basierend auf den in den Argumenten übergebenen Artefakten neu.

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

Weitere Informationen finden Sie unter Entwickeln von Android-Kerneln .