android_packages_modules_Vi.../microdroid
Alice Wang 43c884b00a [rpc_binder] Use RPC binder over UDS for vm_payload_service
Test: atest MicrodroidTests ComposHostTestCases
Bug: 222479468
Change-Id: I61f82f6e2c93b7cf2793c1a812cddc0436c33d82
2022-11-11 06:37:14 +00:00
..
initrd Migrate away from structopt 2022-09-13 08:20:01 -07:00
kdump Load crashkernel using kexec 2022-08-23 00:02:27 +09:00
kernel Update the Microdroid kernel build instructions 2022-11-07 11:18:22 +09:00
payload Remove support for command-line args 2022-10-17 15:06:26 +01:00
vm_payload [rpc_binder] Use RPC binder over UDS for vm_payload_service 2022-11-11 06:37:14 +00:00
Android.bp Remove unused microdroid kernel module build rules 2022-10-28 14:57:51 +00:00
README.md Remove support for command-line args 2022-10-17 15:06:26 +01:00
bootconfig.app_debuggable Use console=ttynull to disable console 2022-09-23 15:05:40 +09:00
bootconfig.arm64
bootconfig.common Increase nr_uart to 4 2022-06-18 19:06:08 +09:00
bootconfig.full_debuggable Remove logd from Microdroid 2022-09-14 07:04:43 +09:00
bootconfig.normal Use console=ttynull to disable console 2022-09-23 15:05:40 +09:00
bootconfig.x86_64 Add one more virtio-console device 2021-11-01 20:07:15 +09:00
build.prop Remove hard-coded build.prop values 2022-04-29 22:22:42 +09:00
dummy_dtb.img
empty_kernel
fstab.microdroid microdroid: use a single vbmeta for all partitions 2021-10-26 12:11:26 +09:00
init.rc Remove cgroup specific setup from microdroid/init.rc 2022-10-24 11:46:13 +01:00
linker.config.json
microdroid.json Revert^2 "Boot VM without bootloader - using init ramdisk" 2022-09-28 15:22:19 +00:00
microdroid_event-log-tags microdroid: add event-log-tags 2022-03-24 03:16:27 +00:00
microdroid_manifest.xml Remove keystore and keymint from the images 2022-01-28 00:38:33 +00:00
microdroid_vendor_compatibility_matrix.xml Remove keystore and keymint from the images 2022-01-28 00:38:33 +00:00
microdroid_vendor_manifest.xml
uboot-env.txt Remove microdroid U-Boot environment 2022-02-03 21:29:54 -08:00
ueventd.rc Migrate DICE access to IVmPayloadService 2022-10-09 10:10:13 +00:00

README.md

Microdroid

Microdroid is a (very) lightweight version of Android that is intended to run on on-device virtual machines. It is built from the same source code as the regular Android, but it is much smaller; no system server, no HALs, no GUI, etc. It is intended to host headless & native workloads only.

Prerequisites

Any 64-bit target (either x86_64 or arm64) is supported. 32-bit target is not supported. Note that we currently don't support user builds; only userdebug builds are supported.

The only remaining requirement is that com.android.virt APEX has to be pre-installed. To do this, add the following line in your product makefile.

$(call inherit-product, packages/modules/Virtualization/apex/product_packages.mk)

Build the target after adding the line, and flash it. This step needs to be done only once for the target.

If you are using aosp_oriole (Pixel 6) or aosp_cf_x86_64_phone (Cuttlefish), adding above line is not necessary as it's already done.

Building and installing microdroid

Microdroid is part of the com.android.virt APEX. To build it and install to the device:

banchan com.android.virt aosp_arm64
UNBUNDLED_BUILD_SDKS_FROM_SOURCE=true m apps_only dist
adb install out/dist/com.android.virt.apex
adb reboot

If your target is x86_64 (e.g. aosp_cf_x86_64_phone), replace aosp_arm64 with aosp_x86_64.

Building an app

An app in microdroid is a shared library file embedded in an APK. The shared library should have an entry point AVmPayload_main as shown below:

extern "C" int AVmPayload_main() {
  printf("Hello Microdroid!\n");
}

Then build it as a shared library:

cc_library_shared {
  name: "MyMicrodroidApp",
  srcs: ["**/*.cpp"],
  sdk_version: "current",
}

Then you need a configuration file in JSON format that defines what to load and execute in microdroid. The name of the file can be anything and you may have multiple configuration files if needed.

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

The value of task.command should match with the name of the shared library defined above. If your app requires APEXes to be imported, you can declare the list in apexes key like following.

{
  "os": ...,
  "task": ...,
  "apexes": [
    {"name": "com.android.awesome_apex"}
  ]
}

Embed the shared library and the VM configuration file in an APK:

android_app {
  name: "MyApp",
  srcs: ["**/*.java"], // if there is any java code
  jni_libs: ["MyMicrodroidApp"],
  use_embedded_native_libs: true,
  sdk_version: "current",
}

// The VM configuration file can be embedded by simply placing it at `./assets`
// directory.

Finally, you build the APK.

TARGET_BUILD_APPS=MyApp m apps_only dist

Running the app on microdroid

First of all, install the APK to the target device.

adb install out/dist/MyApp.apk

ALL_CAPs below are placeholders. They need to be replaced with correct values:

  • VM_CONFIG_FILE: the name of the VM config file that you embedded in the APK. (e.g. vm_config.json)
  • PACKAGE_NAME_OF_YOUR_APP: package name of your app (e.g. com.acme.app).
  • PATH_TO_YOUR_APP: path to the installed APK on the device. Can be obtained via the following command.
    adb shell pm path PACKAGE_NAME_OF_YOUR_APP
    
    It shall report a cryptic path similar to /data/app/~~OgZq==/com.acme.app-HudMahQ==/base.apk.

Execute the following commands to launch a VM. The VM will boot to microdroid and then automatically execute your app (the shared library MyMicrodroidApp.so).

TEST_ROOT=/data/local/tmp/virt
adb shell /apex/com.android.virt/bin/vm run-app \
--log $TEST_ROOT/log.txt \
PATH_TO_YOUR_APP \
$TEST_ROOT/MyApp.apk.idsig \
$TEST_ROOT/instance.img \
assets/VM_CONFIG_FILE

The last command lets you know the CID assigned to the VM. The console output from the VM is stored to $TEST_ROOT/log.txt file for debugging purpose. If you omit the --log $TEST_ROOT/log.txt option, it will be emitted to the current console.

Stopping the VM can be done as follows:

adb shell /apex/com.android.virt/bin/vm stop $CID

, where $CID is the reported CID value. This works only when the vm was invoked with the --daemonize flag. If the flag was not used, press Ctrl+C on the console where the vm run-app command was invoked.

ADB

On userdebug builds, you can have an adb connection to microdroid. To do so, first, delete $TEST_ROOT/instance.img; this is because changing debug settings requires a new instance. Then add the --debug=full flag to the /apex/com.android.virt/bin/vm run-app command, and then

vm_shell

Done. Now you are logged into Microdroid. Have fun!

Once you have an adb connection with vm_shell, localhost:8000 will be the serial of microdroid.

Debugging the payload on microdroid

Like a normal adb device, you can debug native processes using lldbclient.py script, either by running a new process, or attaching to an existing process. Use vm_shell tool above, and then run lldbclient.py.

development/scripts/lldbclient.py -s localhost:8000 --chroot . --user '' \
    (-p PID | -n NAME | -r ...)