All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH V11 00/19] virtio_ring in order support
@ 2025-12-25  4:25 Jason Wang
  2025-12-25  4:25 ` [PATCH V11 01/19] virtio_ring: rename virtqueue_reinit_xxx to virtqueue_reset_xxx() Jason Wang
                   ` (18 more replies)
  0 siblings, 19 replies; 31+ messages in thread
From: Jason Wang @ 2025-12-25  4:25 UTC (permalink / raw)
  To: mst, jasowang, xuanzhuo, eperezma, virtualization, linux-kernel

Hello all:

This sereis tries to implement the VIRTIO_F_IN_ORDER to
virtio_ring. This is done by introducing virtqueue ops so we can
implement separate helpers for different virtqueue layout/features
then the in-order were implemented on top.

Tests shows 2%-19% imporvment with packed virtqueue PPS with KVM guest
vhost-net/testpmd on the host.

Changes since v10:

- Remove the always false check of last_used against num
- Drop the extra "fix" in the commit log of patch 10

Changes sinve v9:

- Fix the total_len calcuation and count only in buffer length
- Fix the comment for the condtiion when batching is not detected

Changes since v8:

- Rebase to vhost.git linux-next branch
- Fix issue when indirect descriptor is disabled
- use UINT_MAX instead of vq->num to indicate no batching is pending
- Tweak the comments for used_entry
- Various coding style tweaks and typo fixes
- Try to use in_order varianet in in_order ops

Changes since v7:

- Rebase on vhost.git linux-next branch
- Tweak the comment to explain the usage of free_head

Changes since v6:

- Rebase on vhost.git linux-next branch
- Fix poking packed virtqueue in more_used_split_in_order()
- Fix calling detach_buf_packed_in_order() unconditonally in
  virtqueue_detach_unused_buf_packed()
- Typo and indentation fixes
- Fix wrong changelog of patch 7

Changes since v5:

- rebase on vhost.git linux-next branch
- reorder the total_len to reduce memory comsuming

Changes since v4:

- Fix build error when DEBUG is enabled
- Fix function duplications
- Remove unnecessary new lines

Changes since v3:

- Re-benchmark with the recent vhost-net in order support
- Rename the batched used id and length
- Other minor tweaks

Changes since v2:

- Fix build warning when DEBUG is enabled

Changes since v1:

- use const global array of function pointers to avoid indirect
  branches to eliminate retpoline when mitigation is enabled
- fix used length calculation when processing used ids in a batch
- fix sparse warnings

Jason Wang (19):
  virtio_ring: rename virtqueue_reinit_xxx to virtqueue_reset_xxx()
  virtio_ring: switch to use vring_virtqueue in virtqueue_poll variants
  virtio_ring: unify logic of virtqueue_poll() and more_used()
  virtio_ring: switch to use vring_virtqueue for virtqueue resize
    variants
  virtio_ring: switch to use vring_virtqueue for virtqueue_kick_prepare
    variants
  virtio_ring: switch to use vring_virtqueue for virtqueue_add variants
  virtio: switch to use vring_virtqueue for virtqueue_get variants
  virtio_ring: switch to use vring_virtqueue for enable_cb_prepare
    variants
  virtio_ring: use vring_virtqueue for enable_cb_delayed variants
  virtio_ring: switch to use vring_virtqueue for disable_cb variants
  virtio_ring: switch to use vring_virtqueue for detach_unused_buf
    variants
  virtio_ring: switch to use unsigned int for virtqueue_poll_packed()
  virtio_ring: introduce virtqueue ops
  virtio_ring: determine descriptor flags at one time
  virtio_ring: factor out core logic of buffer detaching
  virtio_ring: factor out core logic for updating last_used_idx
  virtio_ring: factor out split indirect detaching logic
  virtio_ring: factor out split detaching logic
  virtio_ring: add in order support

 drivers/virtio/virtio_ring.c | 927 +++++++++++++++++++++++++++--------
 1 file changed, 713 insertions(+), 214 deletions(-)

-- 
2.31.1


^ permalink raw reply	[flat|nested] 31+ messages in thread
* [PATCH V11 00/19] virtio_ring in order support
@ 2025-12-30  6:46 Jason Wang
  2025-12-30  6:46 ` [PATCH V11 13/19] virtio_ring: introduce virtqueue ops Jason Wang
  0 siblings, 1 reply; 31+ messages in thread
From: Jason Wang @ 2025-12-30  6:46 UTC (permalink / raw)
  To: mst, jasowang; +Cc: xuanzhuo, eperezma, virtualization, linux-kernel

Hello all:

This sereis tries to implement the VIRTIO_F_IN_ORDER to
virtio_ring. This is done by introducing virtqueue ops so we can
implement separate helpers for different virtqueue layout/features
then the in-order were implemented on top.

Tests shows 2%-19% imporvment with packed virtqueue PPS with KVM guest
vhost-net/testpmd on the host.

Changes since v10:

- Add comment to explain the total_in_len
- Tweak the VIRTQUEUE_CALL/VOID_VIRTQUEUE_CALL to use temporary
  instead of evaluating vq multiple times
- Rewind avail_wrap_counter on failure in virtqueue_add_packed_in_order()
- Fix coding style issues

Changes sinve v9:

- Fix the total_len calcuation and count only in buffer length
- Fix the comment for the condtiion when batching is not detected

Changes since v8:

- Rebase to vhost.git linux-next branch
- Fix issue when indirect descriptor is disabled
- use UINT_MAX instead of vq->num to indicate no batching is pending
- Tweak the comments for used_entry
- Various coding style tweaks and typo fixes
- Try to use in_order varianet in in_order ops

Changes since v7:

- Rebase on vhost.git linux-next branch
- Tweak the comment to explain the usage of free_head

Changes since v6:

- Rebase on vhost.git linux-next branch
- Fix poking packed virtqueue in more_used_split_in_order()
- Fix calling detach_buf_packed_in_order() unconditonally in
  virtqueue_detach_unused_buf_packed()
- Typo and indentation fixes
- Fix wrong changelog of patch 7

Changes since v5:

- rebase on vhost.git linux-next branch
- reorder the total_len to reduce memory comsuming

Changes since v4:

- Fix build error when DEBUG is enabled
- Fix function duplications
- Remove unnecessary new lines

Changes since v3:

- Re-benchmark with the recent vhost-net in order support
- Rename the batched used id and length
- Other minor tweaks

Changes since v2:

- Fix build warning when DEBUG is enabled

Changes since v1:

- use const global array of function pointers to avoid indirect
  branches to eliminate retpoline when mitigation is enabled
- fix used length calculation when processing used ids in a batch
- fix sparse warnings

Jason Wang (19):
  virtio_ring: rename virtqueue_reinit_xxx to virtqueue_reset_xxx()
  virtio_ring: switch to use vring_virtqueue in virtqueue_poll variants
  virtio_ring: unify logic of virtqueue_poll() and more_used()
  virtio_ring: switch to use vring_virtqueue for virtqueue resize
    variants
  virtio_ring: switch to use vring_virtqueue for virtqueue_kick_prepare
    variants
  virtio_ring: switch to use vring_virtqueue for virtqueue_add variants
  virtio: switch to use vring_virtqueue for virtqueue_get variants
  virtio_ring: switch to use vring_virtqueue for enable_cb_prepare
    variants
  virtio_ring: use vring_virtqueue for enable_cb_delayed variants
  virtio_ring: switch to use vring_virtqueue for disable_cb variants
  virtio_ring: switch to use vring_virtqueue for detach_unused_buf
    variants
  virtio_ring: switch to use unsigned int for virtqueue_poll_packed()
  virtio_ring: introduce virtqueue ops
  virtio_ring: determine descriptor flags at one time
  virtio_ring: factor out core logic of buffer detaching
  virtio_ring: factor out core logic for updating last_used_idx
  virtio_ring: factor out split indirect detaching logic
  virtio_ring: factor out split detaching logic
  virtio_ring: add in order support

 drivers/virtio/virtio_ring.c | 928 +++++++++++++++++++++++++++--------
 1 file changed, 713 insertions(+), 215 deletions(-)

-- 
2.31.1


^ permalink raw reply	[flat|nested] 31+ messages in thread

end of thread, other threads:[~2025-12-30  6:47 UTC | newest]

Thread overview: 31+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-12-25  4:25 [PATCH V11 00/19] virtio_ring in order support Jason Wang
2025-12-25  4:25 ` [PATCH V11 01/19] virtio_ring: rename virtqueue_reinit_xxx to virtqueue_reset_xxx() Jason Wang
2025-12-25  4:25 ` [PATCH V11 02/19] virtio_ring: switch to use vring_virtqueue in virtqueue_poll variants Jason Wang
2025-12-25  4:25 ` [PATCH V11 03/19] virtio_ring: unify logic of virtqueue_poll() and more_used() Jason Wang
2025-12-25  4:25 ` [PATCH V11 04/19] virtio_ring: switch to use vring_virtqueue for virtqueue resize variants Jason Wang
2025-12-25  4:25 ` [PATCH V11 05/19] virtio_ring: switch to use vring_virtqueue for virtqueue_kick_prepare variants Jason Wang
2025-12-25  4:25 ` [PATCH V11 06/19] virtio_ring: switch to use vring_virtqueue for virtqueue_add variants Jason Wang
2025-12-25  4:25 ` [PATCH V11 07/19] virtio: switch to use vring_virtqueue for virtqueue_get variants Jason Wang
2025-12-25  4:25 ` [PATCH V11 08/19] virtio_ring: switch to use vring_virtqueue for enable_cb_prepare variants Jason Wang
2025-12-25  4:25 ` [PATCH V11 09/19] virtio_ring: use vring_virtqueue for enable_cb_delayed variants Jason Wang
2025-12-25  4:25 ` [PATCH V11 10/19] virtio_ring: switch to use vring_virtqueue for disable_cb variants Jason Wang
2025-12-25  4:26 ` [PATCH V11 11/19] virtio_ring: switch to use vring_virtqueue for detach_unused_buf variants Jason Wang
2025-12-25  4:26 ` [PATCH V11 12/19] virtio_ring: switch to use unsigned int for virtqueue_poll_packed() Jason Wang
2025-12-25  4:26 ` [PATCH V11 13/19] virtio_ring: introduce virtqueue ops Jason Wang
2025-12-26 19:37   ` Michael S. Tsirkin
2025-12-29  7:16     ` Jason Wang
2025-12-26 19:45   ` Michael S. Tsirkin
2025-12-29  7:16     ` Jason Wang
2025-12-25  4:26 ` [PATCH V11 14/19] virtio_ring: determine descriptor flags at one time Jason Wang
2025-12-26 19:33   ` Michael S. Tsirkin
2025-12-29  7:16     ` Jason Wang
2025-12-25  4:26 ` [PATCH V11 15/19] virtio_ring: factor out core logic of buffer detaching Jason Wang
2025-12-25  4:26 ` [PATCH V11 16/19] virtio_ring: factor out core logic for updating last_used_idx Jason Wang
2025-12-25  4:26 ` [PATCH V11 17/19] virtio_ring: factor out split indirect detaching logic Jason Wang
2025-12-25  4:26 ` [PATCH V11 18/19] virtio_ring: factor out split " Jason Wang
2025-12-25  4:26 ` [PATCH V11 19/19] virtio_ring: add in order support Jason Wang
2025-12-26 19:57   ` Michael S. Tsirkin
2025-12-27 10:09     ` Michael S. Tsirkin
2025-12-29  7:15       ` Jason Wang
2025-12-29  7:18     ` Jason Wang
  -- strict thread matches above, loose matches on Subject: below --
2025-12-30  6:46 [PATCH V11 00/19] virtio_ring " Jason Wang
2025-12-30  6:46 ` [PATCH V11 13/19] virtio_ring: introduce virtqueue ops Jason Wang

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.