| Multi-process QEMU |
| ================== |
| |
| This document describes how to configure and use multi-process qemu. |
| For the design document refer to docs/devel/qemu-multiprocess. |
| |
| 1) Configuration |
| ---------------- |
| |
| multi-process is enabled by default for targets that enable KVM |
| |
| |
| 2) Usage |
| -------- |
| |
| Multi-process QEMU requires an orchestrator to launch. |
| |
| Following is a description of command-line used to launch mpqemu. |
| |
| * Orchestrator: |
| |
| - The Orchestrator creates a unix socketpair |
| |
| - It launches the remote process and passes one of the |
| sockets to it via command-line. |
| |
| - It then launches QEMU and specifies the other socket as an option |
| to the Proxy device object |
| |
| * Remote Process: |
| |
| - QEMU can enter remote process mode by using the "remote" machine |
| option. |
| |
| - The orchestrator creates a "remote-object" with details about |
| the device and the file descriptor for the device |
| |
| - The remaining options are no different from how one launches QEMU with |
| devices. |
| |
| - Example command-line for the remote process is as follows: |
| |
| /usr/bin/qemu-system-x86_64 \ |
| -machine x-remote \ |
| -device lsi53c895a,id=lsi0 \ |
| -drive id=drive_image2,file=/build/ol7-nvme-test-1.qcow2 \ |
| -device scsi-hd,id=drive2,drive=drive_image2,bus=lsi0.0,scsi-id=0 \ |
| -object x-remote-object,id=robj1,devid=lsi0,fd=4, |
| |
| * QEMU: |
| |
| - Since parts of the RAM are shared between QEMU & remote process, a |
| memory-backend-memfd is required to facilitate this, as follows: |
| |
| -object memory-backend-memfd,id=mem,size=2G |
| |
| - A "x-pci-proxy-dev" device is created for each of the PCI devices emulated |
| in the remote process. A "socket" sub-option specifies the other end of |
| unix channel created by orchestrator. The "id" sub-option must be specified |
| and should be the same as the "id" specified for the remote PCI device |
| |
| - Example commandline for QEMU is as follows: |
| |
| -device x-pci-proxy-dev,id=lsi0,socket=3 |