Написать приложение AVF

Приложение, совместимое с AVF, состоит из двух частей: части приложения, работающей на хостовой ОС Android, и части приложения, работающей на Microdroid внутри pVM.

Часть приложения, работающая на Android, реализует пользовательский интерфейс, неконфиденциальную бизнес-логику, а также создает и управляет жизненным циклом pVM.

Часть приложения, работающая на Microdroid внутри pVM, отвечает за выполнение всех задач, которые необходимо выполнять безопасно.

Для запуска и взаимодействия с частью приложения, работающей в среде pVM, ваше хост-приложение создает среду pVM и запускает в ней собственную разделяемую библиотеку. Эта библиотека реализует службу Binder, которую хост-часть приложения использует для связи с частью приложения, находящейся внутри среды pVM. На рисунке 1 показаны две части приложения и канал связи Binder:

Загрузка и обмен данными в приложении AVF

Рисунок 1. Загрузка и обмен данными приложения AVF.

Настройте конфигурационный файл.

В файле vm_config.json должны быть записи для операционной системы pVM и разделяемой библиотеки. В приведенном ниже файле assets/vm_config.json показаны записи конфигурационных файлов для Microdroid и разделяемой нативной библиотеки:

{
  "os": {
    "name": "microdroid"
  },
  "task": {
    "type": "microdroid_launcher",
    "command": "MicrodroidTestNativeLib.so"
  }
}

Реализуйте службу привязки.

В вашей общей библиотеке реализуйте службу связывания. Например:

extern "C"
int android_native_main(int, char**) {
  // Implement your binder service here
}

Создайте код приложения

В хост-части вашего приложения создайте код, который подготавливает файл конфигурации, загружает (или создает) дескриптор виртуальной машины и запускает ее. Например:

// Prepare the configuration file
VirtualMachineConfig config = new VirtualMachineConfig
  .Builder(getApplication(), "assets/vm_config.json")
  .build();

// Load (or create) the handle to a VM
VirtualMachine vm = VirtualMachineManager
  .getInstance(getApplication())
  .getOrCreate("my_vm", config);

// Run the VM
vm.run();

Взаимодействуйте с частью вашего приложения, отвечающей за виртуальную машину.

Для взаимодействия с виртуальной машиной (ВМ) вашего приложения сначала необходимо зарегистрировать функцию обратного вызова, чтобы получать уведомления о готовности службы Binder на ВМ. После получения уведомления вы подключаетесь к серверу Binder, а затем взаимодействуете с ним, используя пользовательский интерфейс AIDL. Например:

// Register the callback
vm.setCallback(Executors.newSingleThreadExecutor(),
  new VirtualmachineCallback() {
  @Override
  public void onPayloadReady(VirtualMachine vm) {
    // Connect to the binder server
    IBinder binder = vm.connectToVsockServer(PORT).get();
    IMyService svc = IMyService.Stub.asInterface(binder);
    // Talk with server using custom AIDL interface
    Result res = svc.doSomething();
  }
}); //exception handling & proper threading omitted
vm.run();

Чтобы загрузить исходный код демонстрационного приложения, демонстрирующего шаги, описанные в этом документе, обратитесь к MicrodroidDemo .