Essa configuração requer um host do Linux ARM64
. Esta página mostra como criar e
iniciar o Cuttlefish com suporte a tamanho de página de 16 KB no ARM64
. As instruções
desta página presumem que os pacotes Cuttlefish estejam instalados na sua máquina. Para
instruções de instalação, consulte a etapa 1 de Instalar o Cuttlefish.
É possível iniciar o Cuttlefish fazendo o download dos artefatos pré-criados diretamente do site de integração contínua do Android ou criando-os no AOSP se você precisar modificar o código-fonte.
Fazer o download dos artefatos para iniciar o Cuttlefish
Navegue até o site de integração contínua do Android e
insira aosp-main-throttled
como o nome da ramificação. Clique no build mais recente para o
destino aosp_cf_arm64_phone_pgagnostic
. Agora, siga as instruções da etapa
5 de Instalar o Cuttlefish.
Iniciar o Cuttlefish criando um build do AOSP
Crie e inicie o Cuttlefish com um destino independente da página:
$ 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
Verificar o tamanho da página e a inicialização
Para verificar o tamanho da página e o status da inicialização:
Acesse o shell como raiz:
$ adb root adbd is already running as root $ adb shell vsoc_arm64_pgagnostic:/ #
Verifique o tamanho da página e o status de inicialização:
vsoc_arm64_pgagnostic:/ # getconf PAGE_SIZE 16384 vsoc_arm64_pgagnostic:/ # getprop | grep sys.boot.completed sys.boot_completed: 1
Usar o Cuttlefish com um kernel personalizado de 16 KB
Para usar um kernel personalizado, em vez de um pré-criado:
Crie um diretório de repositório para um kernel comum do Android e sincronize o diretório:
$ 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)
Crie o kernel de tamanho de página de 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
Verifique se o build foi executado:
# Generated files $ ls out/android14-6.1/dist/Image $ ls out/android14-6.1/dist/initramfs.img
Iniciar o Cuttlefish com o kernel personalizado de tamanho de página de 16 KB
Para usar o kernel recém-criado no 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