From: "Michael S. Tsirkin" <mst@redhat.com>
To: Xie Yongji <xieyongji@bytedance.com>
Cc: jasowang@redhat.com, stefanha@redhat.com, sgarzare@redhat.com,
kwolf@redhat.com, mreitz@redhat.com, mlureau@redhat.com,
jsnow@redhat.com, eblake@redhat.com, Coiby.Xu@gmail.com,
hreitz@redhat.com, qemu-block@nongnu.org, qemu-devel@nongnu.org
Subject: Re: [PATCH v5 0/8] Support exporting BDSs via VDUSE
Date: Fri, 13 May 2022 06:03:00 -0400 [thread overview]
Message-ID: <20220513060205-mutt-send-email-mst@kernel.org> (raw)
In-Reply-To: <20220504074051.90-1-xieyongji@bytedance.com>
On Wed, May 04, 2022 at 03:40:43PM +0800, Xie Yongji wrote:
> Hi all,
>
> Last few months ago, VDUSE (vDPA Device in Userspace) [1] has
> been merged into Linux kernel as a framework that make it
> possible to emulate a vDPA device in userspace. This series
> aimed at implementing a VDUSE block backend based on the
> qemu-storage-daemon infrastructure.
>
> To support that, we firstly introduce a VDUSE library as a
> subproject (like what libvhost-user does) to help implementing
> VDUSE backends in QEMU. Then a VDUSE block export is implemented
> based on this library. At last, we add resize and reconnect support
> to the VDUSE block export and VDUSE library.
>
> Since we don't support vdpa-blk in QEMU currently, the VM case is
> tested with my previous patchset [2].
>
> [1] https://www.kernel.org/doc/html/latest/userspace-api/vduse.html
> [2] https://www.mail-archive.com/qemu-devel@nongnu.org/msg797569.html
>
> Please review, thanks!
This needs review by storage maintainers.
> V4 to V5:
> - Abstract out the logic for virito-blk I/O process from
> vhost-user-blk-server and reuse it [Kevin]
> - Fix missing VIRTIO_BLK_F_FLUSH [Kevin]
> - Support discard and write_zeroes [Kevin]
> - Rebase to the newest tree
>
> V3 to V4:
> - Fix some comments on QAPI [Eric]
>
> V2 to V3:
> - Introduce vduse_get_virtio_features() [Stefan]
> - Update MAINTAINERS file [Stefan]
> - Fix handler of VIRTIO_BLK_T_GET_ID request [Stefan]
> - Add barrier for vduse_queue_inflight_get() [Stefan]
>
> V1 to V2:
> - Move vduse header to linux-headers [Stefan]
> - Add two new API to support creating device from /dev/vduse/$NAME or
> file descriptor [Stefan]
> - Check VIRTIO_F_VERSION_1 during intialization [Stefan]
> - Replace malloc() + memset to calloc() [Stefan]
> - Increase default queue size to 256 for vduse-blk [Stefan]
> - Zero-initialize virtio-blk config space [Stefan]
> - Add a patch to support reset blk->dev_ops
> - Validate vq->log->inflight fields [Stefan]
> - Add vduse_set_reconnect_log_file() API to support specifing the
> reconnect log file
> - Fix some bugs [Stefan]
>
> Xie Yongji (8):
> block: Support passing NULL ops to blk_set_dev_ops()
> block-backend: Introduce blk_get_guest_block_size()
> block/export: Abstract out the logic of virtio-blk I/O process
> linux-headers: Add vduse.h
> libvduse: Add VDUSE (vDPA Device in Userspace) library
> vduse-blk: Implement vduse-blk export
> vduse-blk: Add vduse-blk resize support
> libvduse: Add support for reconnecting
>
> MAINTAINERS | 9 +
> block/block-backend.c | 8 +-
> block/export/export.c | 6 +
> block/export/meson.build | 7 +-
> block/export/vduse-blk.c | 346 +++++
> block/export/vduse-blk.h | 20 +
> block/export/vhost-user-blk-server.c | 249 +---
> block/export/virtio-blk-handler.c | 237 ++++
> block/export/virtio-blk-handler.h | 33 +
> include/sysemu/block-backend-io.h | 1 +
> linux-headers/linux/vduse.h | 306 ++++
> meson.build | 28 +
> meson_options.txt | 4 +
> qapi/block-export.json | 25 +-
> scripts/meson-buildoptions.sh | 7 +
> scripts/update-linux-headers.sh | 2 +-
> subprojects/libvduse/include/atomic.h | 1 +
> subprojects/libvduse/include/compiler.h | 1 +
> subprojects/libvduse/libvduse.c | 1386 +++++++++++++++++++
> subprojects/libvduse/libvduse.h | 247 ++++
> subprojects/libvduse/linux-headers/linux | 1 +
> subprojects/libvduse/meson.build | 10 +
> subprojects/libvduse/standard-headers/linux | 1 +
> 23 files changed, 2695 insertions(+), 240 deletions(-)
> create mode 100644 block/export/vduse-blk.c
> create mode 100644 block/export/vduse-blk.h
> create mode 100644 block/export/virtio-blk-handler.c
> create mode 100644 block/export/virtio-blk-handler.h
> create mode 100644 linux-headers/linux/vduse.h
> create mode 120000 subprojects/libvduse/include/atomic.h
> create mode 120000 subprojects/libvduse/include/compiler.h
> create mode 100644 subprojects/libvduse/libvduse.c
> create mode 100644 subprojects/libvduse/libvduse.h
> create mode 120000 subprojects/libvduse/linux-headers/linux
> create mode 100644 subprojects/libvduse/meson.build
> create mode 120000 subprojects/libvduse/standard-headers/linux
>
> --
> 2.20.1
next prev parent reply other threads:[~2022-05-13 10:09 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-05-04 7:40 [PATCH v5 0/8] Support exporting BDSs via VDUSE Xie Yongji
2022-05-04 7:40 ` [PATCH v5 1/8] block: Support passing NULL ops to blk_set_dev_ops() Xie Yongji
2022-05-18 13:22 ` Stefan Hajnoczi
2022-05-04 7:40 ` [PATCH v5 2/8] block-backend: Introduce blk_get_guest_block_size() Xie Yongji
2022-05-18 13:16 ` Stefan Hajnoczi
2022-05-19 8:03 ` Yongji Xie
2022-05-04 7:40 ` [PATCH v5 3/8] block/export: Abstract out the logic of virtio-blk I/O process Xie Yongji
2022-05-18 13:13 ` Stefan Hajnoczi
2022-05-19 8:09 ` Yongji Xie
2022-05-04 7:40 ` [PATCH v5 4/8] linux-headers: Add vduse.h Xie Yongji
2022-05-18 13:22 ` Stefan Hajnoczi
2022-05-04 7:40 ` [PATCH v5 5/8] libvduse: Add VDUSE (vDPA Device in Userspace) library Xie Yongji
2022-05-18 13:46 ` Stefan Hajnoczi
2022-05-19 8:11 ` Yongji Xie
2022-05-04 7:40 ` [PATCH v5 6/8] vduse-blk: Implement vduse-blk export Xie Yongji
2022-05-18 13:50 ` Stefan Hajnoczi
2022-05-04 7:40 ` [PATCH v5 7/8] vduse-blk: Add vduse-blk resize support Xie Yongji
2022-05-18 13:51 ` Stefan Hajnoczi
2022-05-04 7:40 ` [PATCH v5 8/8] libvduse: Add support for reconnecting Xie Yongji
2022-05-18 14:03 ` Stefan Hajnoczi
2022-05-19 8:25 ` Yongji Xie
2022-05-19 9:44 ` Stefan Hajnoczi
2022-05-19 10:02 ` Yongji Xie
2022-05-19 11:28 ` Stefan Hajnoczi
2022-05-13 10:03 ` Michael S. Tsirkin [this message]
2022-05-17 13:02 ` [PATCH v5 0/8] Support exporting BDSs via VDUSE Yongji Xie
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20220513060205-mutt-send-email-mst@kernel.org \
--to=mst@redhat.com \
--cc=Coiby.Xu@gmail.com \
--cc=eblake@redhat.com \
--cc=hreitz@redhat.com \
--cc=jasowang@redhat.com \
--cc=jsnow@redhat.com \
--cc=kwolf@redhat.com \
--cc=mlureau@redhat.com \
--cc=mreitz@redhat.com \
--cc=qemu-block@nongnu.org \
--cc=qemu-devel@nongnu.org \
--cc=sgarzare@redhat.com \
--cc=stefanha@redhat.com \
--cc=xieyongji@bytedance.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).