Android-Kernel entwickeln

Auf dieser Seite wird beschrieben, wie Sie Android-Kernel auf Cuttlefish-Geräten entwickeln.

Unterstützte Kernelmanifeste

Cuttlefish unterstützt die folgenden Kernelmanifeste im aktuellen Release-Branch von Android und in AOSP-GSI-Releases.

  • Am android-latest-release
    • common-android-mainline
  • Am android-15.0.0_r36
    • common-android16-6.12
    • common-android15-6.6
    • common-android14-6.1
    • common-android14-5.15
  • Am aosp-android13-gsi
    • common-android13-5.15
    • common-android13-5.10
  • Am aosp-android12-gsi
    • common-android12-5.10
    • common-android12-5.4
    • common-android-4.19-stable
  • Am aosp-android11-gsi
    • common-android11-5.4
    • common-android-4.19-stable
    • common-android-4.14-stable

Im Folgenden finden Sie Kernel-Quellen für die Kernel-Entwicklung auf Cuttlefish-Geräten.

Android-Kernel entwickeln

So entwickeln Sie Kernel auf Cuttlefish-Geräten:

  1. Klonen Sie das entsprechende Kernel-Repo-Manifest für Ihr Cuttlefish-Gerät und nehmen Sie alle erforderlichen Änderungen vor.

    mkdir common-android-mainline
    cd common-android-mainline
    repo init -u https://android.googlesource.com/kernel/manifest -b common-android-mainline
    repo sync -c -j$(nproc) -q
  2. Erstellen Sie den Kernel und die Ramdisk. Weitere Informationen finden Sie unter Anbietermodule für das virtuelle Gerät erstellen.

    tools/bazel run //common-modules/virtual-device:virtual_device_x86_64_dist

    Wenn Sie die Kernelmanifeste common-android-4.19-stable, common-android-4.14-stable oder common-android11-5.4 verwenden, führen Sie Folgendes aus:

    BUILD_CONFIG=common/build.config.gki.x86_64 build/build.sh && BUILD_CONFIG=common-modules/virtual-device/build.config.cuttlefish.x86_64 build/build.sh

    Anstatt lokal zu erstellen (um das Herunterladen des Kernel-Quellcodes und das Einrichten einer Kernel-Entwicklungsumgebung zu vermeiden), können Sie die relevanten Artefakte unter ci.android.com herunterladen.

  3. Starten Sie den Kernel und die Ramdisk mit Cuttlefish.

    cvd create \
        -kernel_path=./out/virtual_device_x86_64/dist/bzImage \
        -initramfs_path=./out/virtual_device_x86_64/dist/initramfs.img

    Wenn Sie einen Nicht-GKI-Kernel (alles unter 4.19) starten, lassen Sie das -initramfs_path-Argument weg.

    Wenn Sie den Kernel auf einer AArch64-Version von Cuttlefish starten, verwenden Sie die Build-Konfiguration aarch64 und das Artefakt Image anstelle von bzImage.

    cvd create \
        -kernel_path=./out/virtual_device_aarch64/dist/Image \
        -initramfs_path=./out/virtual_device_aarch64/dist/initramfs.img