Cette page explique comment développer des noyaux Android sur des appareils Cuttlefish.
Fichiers manifestes du noyau compatibles
Cuttlefish est compatible avec les fichiers manifestes du noyau suivants sur la branche de la dernière version d'Android et les versions AOSP GSI.
- Le
android-latest-releasecommon-android-mainline
- Le
android-15.0.0_r36common-android16-6.12common-android15-6.6common-android14-6.1common-android14-5.15
- Le
aosp-android13-gsicommon-android13-5.15common-android13-5.10
- Le
aosp-android12-gsicommon-android12-5.10common-android12-5.4common-android-4.19-stable
- Le
aosp-android11-gsicommon-android11-5.4common-android-4.19-stablecommon-android-4.14-stable
Vous trouverez ci-dessous les sources du noyau pour le développement du noyau sur les appareils Cuttlefish.
kernel/common-android-mainlinekernel/common-android16-6.12kernel/common-android15-6.6kernel/common-android14-6.1kernel/common-android14-5.15kernel/common-android13-5.15kernel/common-android13-5.10
Développer des noyaux Android
Pour développer des noyaux sur des appareils Cuttlefish, procédez comme suit :
Clonez le fichier manifeste du dépôt du noyau approprié pour votre appareil Cuttlefish et apportez les modifications nécessaires.
mkdir common-android-mainlinecd common-android-mainlinerepo init -u https://android.googlesource.com/kernel/manifest -b common-android-mainlinerepo sync -c -j$(nproc) -qCréez le noyau et le disque RAM. Pour en savoir plus, consultez Créer les modules du fournisseur pour l'appareil virtuel.
tools/bazel run //common-modules/virtual-device:virtual_device_x86_64_distSi vous utilisez des fichiers manifestes de noyau
common-android-4.19-stable,common-android-4.14-stableoucommon-android11-5.4, exécutez :BUILD_CONFIG=common/build.config.gki.x86_64 build/build.sh && BUILD_CONFIG=common-modules/virtual-device/build.config.cuttlefish.x86_64 build/build.shAu lieu de compiler en local (pour éviter de télécharger la source du noyau et de configurer un environnement de développement du noyau), vous pouvez télécharger les artefacts concernés sur ci.android.com.
Lancez le noyau et le ramdisk avec Cuttlefish.
cvd create \ -kernel_path=./out/virtual_device_x86_64/dist/bzImage \ -initramfs_path=./out/virtual_device_x86_64/dist/initramfs.imgSi vous lancez un noyau non-GKI (version 4.19 ou antérieure), omettez l'argument
-initramfs_path.Si vous lancez le noyau sur une version aarch64 de Cuttlefish, utilisez la configuration de compilation
aarch64et l'artefactImageau lieu debzImage.cvd create \ -kernel_path=./out/virtual_device_aarch64/dist/Image \ -initramfs_path=./out/virtual_device_aarch64/dist/initramfs.img