Questa configurazione richiede un host Linux ARM64. Questa pagina mostra come creare e
avviare Cuttlefish con il supporto delle dimensioni pagina di 16 KB su ARM64. Le istruzioni riportate in
questa pagina presuppongono che i pacchetti Cuttlefish siano installati sul tuo computer. Per
istruzioni per l'installazione, vedi il passaggio 1 di Installare Cuttlefish.
Puoi avviare Cuttlefish scaricando gli artefatti precompilati direttamente dal sito di integrazione continua di Android o compilandoli da AOSP se devi modificare il codice sorgente.
Avvia Cuttlefish scaricando gli artefatti
Vai al sito di integrazione continua di Android e
inserisci aosp-main-throttled come nome del ramo. Fai clic sull'ultima build per la destinazione
aosp_cf_arm64_phone_pgagnostic. Ora, segui le istruzioni del passaggio
5 di Installare Cuttlefish.
Avvia Cuttlefish creando da AOSP
Crea e avvia Cuttlefish con una destinazione indipendente dalla pagina:
$ mkdir android-latest-branch && cd android-latest-branch
$ repo init -u https://android.googlesource.com/platform/manifest -b android-latest-release
$ 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
Verificare le dimensioni della pagina e l'avvio
Per verificare le dimensioni della pagina e lo stato di avvio:
- Accedi alla shell come root: - $ adb root adbd is already running as root $ adb shell vsoc_arm64_pgagnostic:/ #
- Verifica le dimensioni della pagina e lo stato di avvio: - vsoc_arm64_pgagnostic:/ # getconf PAGE_SIZE 16384 vsoc_arm64_pgagnostic:/ # getprop | grep sys.boot.completed sys.boot_completed: 1
Utilizzare Cuttlefish con un kernel personalizzato per dimensione pagina di 16 kB
Per utilizzare un kernel personalizzato anziché uno precompilato:
- Crea una directory del repository per un kernel comune di Android e sincronizzala: - $ 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)
- Crea un kernel con dimensioni pagina di 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
- Verifica che la build sia stata eseguita correttamente: - # Generated files $ ls out/android14-6.1/dist/Image $ ls out/android14-6.1/dist/initramfs.img
Avvia Cuttlefish con il kernel personalizzato per dimensioni pagina di 16 KB
Per utilizzare il kernel appena creato in 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
