Ta konfiguracja wymaga hosta z systemem Linux ARM64
. Na tej stronie dowiesz się, jak tworzyć
uruchom mątwę z obsługą rozmiaru strony 16 KB w witrynie ARM64
. Instrukcje dotyczące
zakładamy, że na komputerze są zainstalowane pakiety Cuttlefish. Dla:
jak je zainstalować, dowiesz się z kroku 1 sekcji Instalowanie mątwy.
Możesz uruchomić Cuttlefish, pobierając artefaktów bezpośrednio z trybu ciągłego Androida, witrynę integracji, a jeśli chcesz wprowadzić zmiany, utwórz je w AOSP; do kodu źródłowego.
Uruchom Cuttlefish, pobierając artefakty
Otwórz witrynę poświęconą ciągłej integracji na urządzeniach z Androidem.
wpisz aosp-main-throttled
jako nazwę gałęzi. Kliknij najnowszą kompilację dla
Cel: aosp_cf_arm64_phone_pgagnostic
. Teraz postępuj zgodnie z instrukcjami z kroku
5 z sekcji Zainstaluj mątwę.
Wystrzel Cuttlefish, skompilując je z AOSP
Utwórz i uruchom Cuttlefish z celem niezależnym od 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 rozruchu
Aby sprawdzić rozmiar strony i stan uruchamiania:
Uzyskaj dostęp do powłoki jako użytkownik root:
$ adb root adbd is already running as root $ adb shell vsoc_arm64_pgagnostic:/ #
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
Użyj mątwy z jądrem strony o niestandardowym rozmiarze 16 KB
Aby użyć niestandardowego jądra zamiast gotowego jądra:
Utwórz katalog repozytorium dla wspólnego jądra Androida i zsynchronizuj katalog:
$ 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)
Skompiluj jądro 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
Sprawdź, czy kompilacja została wykonana:
# Generated files $ ls out/android14-6.1/dist/Image $ ls out/android14-6.1/dist/initramfs.img
Uruchom Cuttlefish z jądłem strony o niestandardowym 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