vhost-user back ends
vhost-user back ends are way to service the request of VirtIO devices outside of QEMU itself. To do this there are a number of things required.
vhost-user device
These are simple stub devices that ensure the VirtIO device is visible
to the guest. The code is mostly boilerplate although each device has
a chardev option which specifies the ID of the --chardev
device that connects via a socket to the vhost-user daemon.
Each device will have an virtio-mmio and virtio-pci variant. See your platform details for what sort of virtio bus to use.
| Device | Type | Notes | 
|---|---|---|
| vhost-user-blk | Block storage | |
| vhost-user-fs | File based storage driver | |
| vhost-user-gpio | Proxy gpio pins to host | |
| vhost-user-gpu | GPU driver | |
| vhost-user-i2c | Proxy i2c devices to host | |
| vhost-user-input | Generic input driver | |
| vhost-user-rng | Entropy driver | |
| vhost-user-scmi | System Control and Management Interface | |
| vhost-user-snd | Audio device | |
| vhost-user-scsi | SCSI based storage | |
| vhost-user-vsock | Socket based communication | 
The referenced daemons are not exhaustive, any conforming backend implementing the device and using the vhost-user protocol should work.
vhost-user-test-device
The vhost-user-test-device is a generic development device intended for expert use while developing new backends. The user needs to specify all the required parameters including:
Device
virtio-id
The
num_vqsit needs and theirvq_size
The
config_sizeif needed
Note
While this is a useful device for development it is not recommended for production use.
vhost-user daemon
This is a separate process that is connected to by QEMU via a socket following the Vhost-user Protocol. There are a number of daemons that can be built when enabled by the project although any daemon that meets the specification for a given device can be used.
Example
First start your daemon.
$ virtio-foo --socket-path=/var/run/foo.sock $OTHER_ARGS
Then you start your QEMU instance specifying the device, chardev and memory objects.
$ qemu-system-x86_64 \
    -m 4096 \
    -chardev socket,id=ba1,path=/var/run/foo.sock \
    -device vhost-user-foo,chardev=ba1,$OTHER_ARGS \
    -object memory-backend-memfd,id=mem,size=4G,share=on \
    -numa node,memdev=mem \
      ...