Tworzenie jąder Androida

Z tej strony dowiesz się, jak tworzyć jądra Androida na urządzeniach Cuttlefish.

Obsługiwane pliki manifestu jądra

Cuttlefish obsługuje te pliki manifestu jądra w najnowszej gałęzi wersji Androida i wersjach AOSP GSI.

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

Poniżej znajdziesz źródła jądra do tworzenia jądra na urządzeniach Cuttlefish.

Tworzenie jąder Androida

Aby tworzyć jądra na urządzeniach Cuttlefish:

  1. Sklonuj odpowiedni plik manifestu repozytorium jądra na urządzeniu Cuttlefish i wprowadź zmiany.

    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. Utwórz jądro i dysk RAM. Więcej informacji znajdziesz w artykule Tworzenie modułów dostawcy na urządzeniu wirtualnym.

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

    Jeśli używasz plików manifestu jądra common-android-4.19-stable, common-android-4.14-stable lub common-android11-5.4, uruchom:

    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

    Zamiast tworzyć lokalnie (aby uniknąć pobierania źródła jądra i konfigurowania środowiska programistycznego jądra), możesz pobrać odpowiednie artefakty na stronie ci.android.com.

  3. Uruchom jądro i dysk RAM za pomocą Cuttlefish.

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

    Jeśli uruchamiasz jądro inne niż GKI (w wersji 4.19 lub starszej), pomiń argument -initramfs_path.

    Jeśli uruchamiasz jądro w wersji Cuttlefish aarch64, użyj konfiguracji kompilacji aarch64 i artefaktu Image zamiast bzImage.

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