Tworzenie jąder Androida

Na tej stronie opisaliśmy, jak tworzyć jądra Androida na urządzeniach Cuttlefish.

Obsługiwane pliki manifestu jądra

Cuttlefish obsługuje poniższe pliki manifestu jądra w głównej i AOSP GSI.

  • aosp-main
    • common-android-mainline
    • common-android16-6.12
    • common-android15-6.6
    • common-android14-6.1
    • common-android14-5.15
  • aosp-android13-gsi
    • common-android13-5.15
    • common-android13-5.10
  • aosp-android12-gsi
    • common-android12-5.10
    • common-android12-5.4
    • common-android-4.19-stable
  • 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 służących do tworzenia jej jądra na urządzeniach Cuttlefish.

Tworzenie jąder Androida

Aby opracować jądra na urządzeniach Cuttlefish, wykonaj te czynności:

  1. Skopiuj odpowiedni plik manifestu repozytorium jądra dla urządzenia 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 pamięć RAM. Więcej informacji znajdziesz w artykule Tworzenie modułów dostawcy na potrzeby urządzenia wirtualnego.

    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 kompilować na komputerze lokalnym (aby uniknąć pobierania kodu źródłowego jądra i ustawiania środowiska programistycznego dla jądra) możesz pobrać odpowiednie elementy na stronie ci.android.com.

  3. Uruchom jądro i pamięć 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

    W przypadku uruchamiania jądra systemu innego niż GKI (wszystko, co jest w wersji 4.19 lub niższej), pomiń argument -initramfs_path.

    Jeśli uruchamiasz ją w wersji Cuttlefish w wersji 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