Для этой установки требуется хост Linux на базе ARM64 . На этой странице показано, как собрать и запустить Cuttlefish с поддержкой размера страницы 16 КБ на ARM64 . Инструкции на этой странице предполагают, что пакеты Cuttlefish установлены на вашем компьютере. Инструкции по их установке см. в шаге 1 установки Cuttlefish .
Запустить Cuttlefish можно либо загрузив предварительно собранные компоненты непосредственно с сайта Android Continuous Integration, либо собрав их из AOSP, если вам необходимо изменить исходный код.
Запустите Cuttlefish, загрузив необходимые артефакты.
Перейдите на сайт Android Continuous Integration и введите aosp-main-throttled в качестве имени ветки. Щелкните по последней сборке для целевого объекта aosp_cf_arm64_phone_pgagnostic . Теперь следуйте инструкциям из шага 5 установки Cuttlefish .
Запустите Cuttlefish, используя подход AOSP при разработке.
Создайте и запустите Cuttlefish с целевым объектом, не зависящим от размера страницы:
$ 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
Проверьте размер страницы и загрузку.
Для проверки размера страницы и состояния загрузки:
Получите доступ к командной оболочке от имени root:
$ adb root adbd is already running as root $ adb shell vsoc_arm64_pgagnostic:/ #Проверьте размер страницы и состояние загрузки:
vsoc_arm64_pgagnostic:/ # getconf PAGE_SIZE 16384 vsoc_arm64_pgagnostic:/ # getprop | grep sys.boot.completed sys.boot_completed: 1
Используйте Cuttlefish с ядром, устанавливающим пользовательский размер страницы 16 КБ.
Чтобы использовать собственное ядро вместо предварительно собранного:
Создайте каталог репозитория для общего ядра Android и синхронизируйте этот каталог:
$ 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)Собрать ядро с размером страницы 16 КБ:
$ 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Убедитесь, что сборка выполнена успешно:
# Generated files $ ls out/android14-6.1/dist/Image $ ls out/android14-6.1/dist/initramfs.img
Запустите Cuttlefish с ядром, использующим пользовательскую страницу размером 16 КБ.
Чтобы использовать ваше недавно собранное ядро в 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