Auf dieser Seite wird beschrieben, wie Android-Kernel auf Cuttlefish-Geräten entwickelt werden.
Unterstützte Kernelmanifeste
Cuttlefish unterstützt die folgenden Kernelmanifeste in Haupt- und AOSP-GSI-Releases.
- Am
aosp-main
common-android-mainline
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 Kernelquellen für die Kernelentwicklung auf Cuttlefish-Geräten.
kernel/common-android-mainline
kernel/common-android16-6.12
kernel/common-android15-6.6
kernel/common-android14-6.1
kernel/common-android14-5.15
kernel/common-android13-5.15
kernel/common-android13-5.10
Android-Kernel entwickeln
So entwickeln Sie Kernel auf Cuttlefish-Geräten:
Klonen Sie das entsprechende Kernel-Repository-Manifest für Ihr Cuttlefish-Gerät und nehmen Sie die gewünschten Ä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
Erstellen Sie den Kernel und das RAM-Disk. 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 Kernel-Manifeste
common-android-4.19-stable
,common-android-4.14-stable
odercommon-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 den Build lokal zu erstellen, können Sie die entsprechenden Artefakte unter ci.android.com herunterladen, um den Download des Kernel-Quellcodes zu vermeiden und eine Kernel-Entwicklungsumgebung einzurichten.
Starten Sie den Kernel und 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 starten (Version 4.19 oder niedriger), lassen Sie das Argument
-initramfs_path
weg.Wenn Sie den Kernel in einer aarch64-Version von Cuttlefish starten, verwenden Sie die Build-Konfiguration
aarch64
und das ArtefaktImage
anstelle vonbzImage
.cvd create \ -kernel_path=./out/virtual_device_aarch64/dist/Image \ -initramfs_path=./out/virtual_device_aarch64/dist/initramfs.img