[RFC PATCH 0/6] Introduce a vringh accessor for IO memory

From: Shunsuke Mie
Date: Mon Dec 26 2022 - 21:25:49 EST


Vringh is a host-side implementation of virtio rings, and supports the
vring located on three kinds of memories, userspace, kernel space and a
space translated iotlb.

The goal of this patchset is to refactor vringh and introduce a new vringh
accessor for the vring located on the io memory region. The io memory
accessor (iomem) is used by a driver that is not published yet, but I'm
planning to publish it. Drivers affected by these changes are not included
in this patchset. e.g. caif_virtio and vdpa (sim_net, sim_blk and net/mlx5)
drivers.

This patchset can separate into 3 parts:
1. Fix and prepare some code related vringh [1, 2, 3/6]
2. Unify the vringh APIs and change related [4, 5/6]
3. Support IOMEM to vringh [6/6]

This first part is preparation for the second part which has a little fix
and changes. A test code for vringh named vringh_test is also updated along
with the changes. In the second part, unify the vringh API for each
accessors that are user, kern and iotlb. The main point is struct
vringh_ops that fill the gap between all accessors. The final part
introduces an iomem support to vringh according to the unified API in the
second part.

Those changes are tested for the user accessor using vringh_test and kern
and iomem using a non published driver, but I think I can add a link to a
patchset for the driver in the next version of this patchset.

Shunsuke Mie (6):
vringh: fix a typo in comments for vringh_kiov
vringh: remove vringh_iov and unite to vringh_kiov
tools/virtio: convert to new vringh user APIs
vringh: unify the APIs for all accessors
tools/virtio: convert to use new unified vringh APIs
vringh: IOMEM support

drivers/vhost/Kconfig | 6 +
drivers/vhost/vringh.c | 721 ++++++++++++-------------------------
include/linux/vringh.h | 147 +++-----
tools/virtio/vringh_test.c | 123 ++++---
4 files changed, 356 insertions(+), 641 deletions(-)

--
2.25.1