For the virtio net send queue, if it supports premapped mode, then we need to collect the dma info of every desc of this buf to do unmap inside the driver. The key is that one xmit may contains multiple dma address. (A skb may contain 19 dma address) Here I introduce a new helper to resolve this. And we also need to consider the virtqueue_resize and free the unused buffers. For on the same page of the API design before other job, I post this RFC patch set. Thanks. v2: 1. use union to reuse the sq-sg 2. introduce virtqueue_get_dma_premapped() 3. move WARN_ON_ONCE() to the detach_buf_{split,packed} 4. rename the virtqueue_detach_unused_buf_premapped() to virtqueue_detach_unused_buf_dma() v1: 1. introduce new struct virtio_dma_head to replace the scatterlist 2. fix some small problems Xuan Zhuo (5): virtio_ring: introduce virtqueue_get_buf_ctx_dma() virtio_ring: virtqueue_disable_and_recycle let the callback detach bufs virtio_ring: introduce virtqueue_detach_unused_buf_dma() virtio_ring: introduce virtqueue_get_dma_premapped() virtio_net: sq support premapped mode drivers/net/virtio/main.c | 163 ++++++++++++++++++---- drivers/net/virtio/virtio_net.h | 13 +- drivers/virtio/virtio_ring.c | 231 +++++++++++++++++++++++--------- include/linux/virtio.h | 22 ++- 4 files changed, 334 insertions(+), 95 deletions(-) -- 2.32.0.3.g01195cf9f