[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v2 0/6] virtio,vhost: Add VIRTIO_F_NOTIFICATION_DATA support
From: |
Jonah Palmer |
Subject: |
[PATCH v2 0/6] virtio,vhost: Add VIRTIO_F_NOTIFICATION_DATA support |
Date: |
Wed, 13 Mar 2024 07:54:06 -0400 |
The goal of these patches are to add support to a variety of virtio and
vhost devices for the VIRTIO_F_NOTIFICATION_DATA transport feature. This
feature indicates that a driver will pass extra data (instead of just a
virtqueue's index) when notifying the corresponding device.
The data passed in by the driver when this feature is enabled varies in
format depending on if the device is using a split or packed virtqueue
layout:
Split VQ
- Upper 16 bits: shadow_avail_idx
- Lower 16 bits: virtqueue index
Packed VQ
- Upper 16 bits: 1-bit wrap counter & 15-bit shadow_avail_idx
- Lower 16 bits: virtqueue index
Also, due to the limitations of ioeventfd not being able to carry the
extra provided by the driver, having both VIRTIO_F_NOTIFICATION_DATA
feature and ioeventfd enabled is a functional mismatch. The user must
explicitly disable ioeventfd for the device in the Qemu arguments when
using this feature, else the device will fail to complete realization.
For example, a device must explicitly enable notification_data as well
as disable ioeventfd:
-device virtio-scsi-pci,...,ioeventfd=off,notification_data=on
A significant aspect of this effort has been to maintain compatibility
across different backends. As such, the feature is offered by backend
devices only when supported, with fallback mechanisms where backend
support is absent.
v2: Don't disable ioeventfd by default, user must disable it
Drop tags on patch 2/6
Jonah Palmer (6):
virtio/virtio-pci: Handle extra notification data
virtio: Prevent creation of device using notification-data with ioeventfd
virtio-mmio: Handle extra notification data
virtio-ccw: Handle extra notification data
vhost/vhost-user: Add VIRTIO_F_NOTIFICATION_DATA to vhost feature bits
virtio: Add VIRTIO_F_NOTIFICATION_DATA property definition
hw/block/vhost-user-blk.c | 1 +
hw/net/vhost_net.c | 2 ++
hw/s390x/s390-virtio-ccw.c | 16 +++++++++++----
hw/scsi/vhost-scsi.c | 1 +
hw/scsi/vhost-user-scsi.c | 1 +
hw/virtio/vhost-user-fs.c | 2 +-
hw/virtio/vhost-user-vsock.c | 1 +
hw/virtio/virtio-mmio.c | 9 ++++++--
hw/virtio/virtio-pci.c | 10 ++++++---
hw/virtio/virtio.c | 40 ++++++++++++++++++++++++++++++++++++
include/hw/virtio/virtio.h | 7 ++++++-
net/vhost-vdpa.c | 1 +
12 files changed, 80 insertions(+), 11 deletions(-)
--
2.39.3
- [PATCH v2 0/6] virtio,vhost: Add VIRTIO_F_NOTIFICATION_DATA support,
Jonah Palmer <=
- [PATCH v2 4/6] virtio-ccw: Handle extra notification data, Jonah Palmer, 2024/03/13
- [PATCH v2 3/6] virtio-mmio: Handle extra notification data, Jonah Palmer, 2024/03/13
- [PATCH v2 5/6] vhost/vhost-user: Add VIRTIO_F_NOTIFICATION_DATA to vhost feature bits, Jonah Palmer, 2024/03/13
- [PATCH v2 2/6] virtio: Prevent creation of device using notification-data with ioeventfd, Jonah Palmer, 2024/03/13
- [PATCH v2 1/6] virtio/virtio-pci: Handle extra notification data, Jonah Palmer, 2024/03/13