Используйте Cuttlefish с размером страницы 16 КБ на ARM64.

Для этой настройки требуется хост Linux ARM64 . На этой странице показано, как собрать и запустить Cuttlefish с поддержкой размера страницы 16 КБ на ARM64 . Инструкции на этой странице предполагают, что на вашем компьютере установлены пакеты Cuttlefish. Инструкции по их установке см. в разделе «Шаг 1 установки Cuttlefish» .

Вы можете запустить Cuttlefish, загрузив готовые артефакты непосредственно с сайта Android Continuous Integration или собрав их из AOSP, если вам нужно изменить исходный код.

Запустите Cuttlefish, загрузив артефакты.

Перейдите на сайт непрерывной интеграции Android и введите aosp-main-throttled в качестве имени ветки. Щелкните последнюю сборку для цели aosp_cf_arm64_phone_pgagnostic . Теперь следуйте инструкциям шага 5 установки Cuttlefish .

Запустите Cuttlefish, построив его из AOSP.

Соберите и запустите Cuttlefish с независимой от страницы целью:

$ 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

Проверьте размер страницы и загрузку

Чтобы проверить размер страницы и состояние загрузки:

  1. Доступ к оболочке от имени пользователя root:

    $ adb root
    adbd is already running as root
    $ adb shell
    vsoc_arm64_pgagnostic:/ #
    
  2. Проверьте размер страницы и состояние загрузки:

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

Используйте Cuttlefish с собственным ядром размером страницы 16 КБ.

Чтобы использовать собственное ядро ​​вместо готового ядра:

  1. Создайте каталог репо для общего ядра 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)
    
  2. Собираем ядро ​​размером страницы 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
    
  3. Убедитесь, что сборка выполнена успешно:

    # 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