Użyj mątwy o rozmiarze strony 16 KB na ARM64

Ta konfiguracja wymaga hosta ARM64 Linux. Z tej strony dowiesz się, jak utworzyć i uruchomić Cuttlefish z obsługą rozmiaru strony 16 KB w przeglądarce ARM64. Instrukcje na tej stronie zakładają, że na maszynie są zainstalowane pakiety Cuttlefish. Instrukcje dotyczące ich instalacji znajdziesz w kroku 1 w artykule Instalowanie Cuttlefish.

Cuttlefish możesz uruchomić, pobierając gotowe artefakty bezpośrednio ze strony ciągłej integracji Androida lub skompilując je w AOSP, jeśli chcesz zmodyfikować kod źródłowy.

Uruchom Cuttlefish, pobierając artefakty

Otwórz stronę z integracją ciągłą na Androida i wpisz aosp-main-throttled jako nazwę gałęzi. Kliknij najnowszą kompilację dla celu aosp_cf_arm64_phone_pgagnostic. Teraz wykonaj czynności opisane w kroku 5 sekcji Instalowanie Cuttlefish.

Uruchom Cuttlefish, budując go na podstawie AOSP

Utwórz i uruchom kampanię Cuttlefish z docelowym typem strony:

$ mkdir main && cd main
$ repo init
-u https://android.googlesource.com/platform/manifest -b main
$ repo sync
-c -j32

# Build cf agnostic target.
$ source build
/envsetup.sh
$ lunch aosp_cf_arm64_phone_pgagnostic
-trunk_staging-userdebug
$ m

# Launch cf with a kernel with 16 KB page size support.
$ launch_cvd
...
...
VIRTUAL_DEVICE_DISPLAY_POWER_MODE_CHANGED
virtio_input_hid_handle_status
: unknown type 20
virtio_input_hid_handle_status
: unknown type 20
virtio_input_hid_handle_status
: unknown type 20
virtio_input_hid_handle_status
: unknown type 20
Generating new secret with slot ID: 4
VIRTUAL_DEVICE_BOOT_STARTED
VIRTUAL_DEVICE_NETWORK_MOBILE_CONNECTED

Sprawdzanie rozmiaru strony i boot

Aby sprawdzić rozmiar strony i stan uruchamiania:

  1. Uzyskaj dostęp do powłoki jako root:

    $ adb root
    adbd
    is already running as root
    $ adb shell
    vsoc_arm64_pgagnostic
    :/ #
  2. Sprawdź rozmiar strony i stan uruchamiania:

    vsoc_arm64_pgagnostic:/ # getconf PAGE_SIZE
    16384
    vsoc_arm64_pgagnostic:/
    # getprop | grep sys.boot.completed
    sys
    .boot_completed: 1

Korzystanie z Cuttlefish z niestandardowym jądrem obsługującym strony o rozmiarze 16 KB

Aby użyć niestandardowego jądra zamiast gotowego:

  1. Utwórz katalog repozytorium dla wspólnego jądra Androida i zsynchronizuj go:

    $ 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)
  2. Kompilowanie jądra systemu obsługującego strony o rozmiarze 16 KB:

    $ tools/bazel run --lto=none //common:kernel_aarch64_16k_dist
    $ tools
    /bazel run --lto=none //common-modules/virtual-device:virtual_device_aarch64_16k_dist -- \
       
    --dist_dir=out/android14-6.1/dist
  3. Sprawdź, czy kompilacja została uruchomiona:

    # Generated files
    $ ls
    out/android14-6.1/dist/Image
    $ ls
    out/android14-6.1/dist/initramfs.img

Uruchom Cuttlefish z jądrem systemu obsługującym strony o rozmiarze 16 KB

Aby użyć nowo utworzonego jądra w grze Cuttlefish:

$ launch_cvd -kernel_path ~/common-android14-6.1/out/android14-6.1/dist/Image \
     
-initramfs_path ~/common-android14-6.1/out/android14-6.1/dist/initramfs.img \
     
--resume=false --userdata_format=ext4 \
     
--data_policy=always_create --blank_data_image_mb=8000
     
-userdata_format=ext4