Important

This is the latest documentation for the unstable development branch of Project ACRN (master).
Use the drop-down menu on the left to select documentation for a stable release such as v3.2 or v3.0.

MMIO Device Passthrough

The ACRN Hypervisor supports both PCI and MMIO device passthrough. However there are some constraints on and hypervisor assumptions about MMIO devices: there can be no DMA access to the MMIO device and the MMIO device may not use IRQs.

Here is how ACRN supports MMIO device passthrough:

  • For a pre-launched VM, the VM configuration tells the ACRN hypervisor the addresses of the physical MMIO device’s regions and where they are mapped to in the pre-launched VM. The hypervisor then removes these MMIO regions from the Service VM and fills the vACPI table for this MMIO device based on the device’s physical ACPI table.

  • For a post-launched VM, the same actions are done as in a pre-launched VM, plus we use the command line to tell which MMIO device we want to pass through to the post-launched VM.

    If the MMIO device has ACPI Tables, use --acpidev_pt HID[,UID] and if not, use --mmiodev_pt MMIO_regions.

Note

The vTPM and PT TPM in the ACRN-DM have the same HID so we can’t support them both at the same time. The VM will fail to boot if both are used.

These issues remain to be implemented:

  • Save the MMIO regions in a field of the VM structure in order to release the resources when the post-launched VM shuts down abnormally.

  • Allocate the guest MMIO regions for the MMIO device in a guest-reserved MMIO region instead of being hard-coded. With this, we could add more passthrough MMIO devices.

  • De-assign the MMIO device from the Service VM first before passing through it to the post-launched VM and not only removing the MMIO regions from the Service VM.