Android-Kernel entwickeln

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

Unterstützte Kernel-Manifeste

Sepia unterstützt die folgenden Kernel-Manifeste auf Haupt- und AOSP GSI-Releases.

  • Am aosp-main <ph type="x-smartling-placeholder">
      </ph>
    • common-android14-6.1
    • common-android14-5.15
    • common-android-mainline
  • Am aosp-android13-gsi <ph type="x-smartling-placeholder">
      </ph>
    • common-android13-5.15
    • common-android13-5.10
  • Am aosp-android12-gsi <ph type="x-smartling-placeholder">
      </ph>
    • common-android12-5.10
    • common-android12-5.4
    • common-android-4.19-stable
  • Am aosp-android11-gsi <ph type="x-smartling-placeholder">
      </ph>
    • 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-Repository-Manifest für Ihr Cuttlefish-Gerät und Änderungen vornehmen.

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

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

    Bei Verwendung von common-android-4.19-stable, common-android-4.14-stable oder common-android11-5.4 Kernel-Manifeste. Führen Sie folgenden Befehl 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 den Build lokal zu erstellen (um das Herunterladen der Kernel-Quelle zu vermeiden, Kernel-Entwicklungsumgebung einrichten) können Sie die entsprechenden Artefakte auf ci.android.com.

  3. Starten Sie den Kernel und Ramdisk mit Cuttlefish.

    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
    

    Beim Starten eines Nicht-GKI-Kernels (alle Vorgänge, die unter 4.19), lassen Sie das Argument -initramfs_path weg.

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

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