]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
virtio_ring: add a func argument 'recycle_done' to virtqueue_reset()
authorKoichiro Den <koichiro.den@canonical.com>
Fri, 6 Dec 2024 01:10:46 +0000 (10:10 +0900)
committerPaolo Abeni <pabeni@redhat.com>
Tue, 10 Dec 2024 10:22:21 +0000 (11:22 +0100)
When virtqueue_reset() has actually recycled all unused buffers,
additional work may be required in some cases. Relying solely on its
return status is fragile, so introduce a new function argument
'recycle_done', which is invoked when it really occurs.

Signed-off-by: Koichiro Den <koichiro.den@canonical.com>
Acked-by: Jason Wang <jasowang@redhat.com>
Reviewed-by: Xuan Zhuo <xuanzhuo@linux.alibaba.com>
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
drivers/net/virtio_net.c
drivers/virtio/virtio_ring.c
include/linux/virtio.h

index 3a0341cc60854654f6ea2ca7f08f49f65c41c8df..5cf4b2b204311e284f3c1bd29afd7f816add99ef 100644 (file)
@@ -5711,7 +5711,7 @@ static int virtnet_rq_bind_xsk_pool(struct virtnet_info *vi, struct receive_queu
 
        virtnet_rx_pause(vi, rq);
 
-       err = virtqueue_reset(rq->vq, virtnet_rq_unmap_free_buf);
+       err = virtqueue_reset(rq->vq, virtnet_rq_unmap_free_buf, NULL);
        if (err) {
                netdev_err(vi->dev, "reset rx fail: rx queue index: %d err: %d\n", qindex, err);
 
@@ -5740,7 +5740,7 @@ static int virtnet_sq_bind_xsk_pool(struct virtnet_info *vi,
 
        virtnet_tx_pause(vi, sq);
 
-       err = virtqueue_reset(sq->vq, virtnet_sq_free_unused_buf);
+       err = virtqueue_reset(sq->vq, virtnet_sq_free_unused_buf, NULL);
        if (err) {
                netdev_err(vi->dev, "reset tx fail: tx queue index: %d err: %d\n", qindex, err);
                pool = NULL;
index 6af8cf6a619e0a9c2c9873fdcac2bcd28737b3cd..fdd2d2b07b5a2aca864bc917306536685afb66a6 100644 (file)
@@ -2827,6 +2827,7 @@ EXPORT_SYMBOL_GPL(virtqueue_resize);
  * virtqueue_reset - detach and recycle all unused buffers
  * @_vq: the struct virtqueue we're talking about.
  * @recycle: callback to recycle unused buffers
+ * @recycle_done: callback to be invoked when recycle for all unused buffers done
  *
  * Caller must ensure we don't call this with other virtqueue operations
  * at the same time (except where noted).
@@ -2838,7 +2839,8 @@ EXPORT_SYMBOL_GPL(virtqueue_resize);
  * -EPERM: Operation not permitted
  */
 int virtqueue_reset(struct virtqueue *_vq,
-                   void (*recycle)(struct virtqueue *vq, void *buf))
+                   void (*recycle)(struct virtqueue *vq, void *buf),
+                   void (*recycle_done)(struct virtqueue *vq))
 {
        struct vring_virtqueue *vq = to_vvq(_vq);
        int err;
@@ -2846,6 +2848,8 @@ int virtqueue_reset(struct virtqueue *_vq,
        err = virtqueue_disable_and_recycle(_vq, recycle);
        if (err)
                return err;
+       if (recycle_done)
+               recycle_done(_vq);
 
        if (vq->packed_ring)
                virtqueue_reinit_packed(vq);
index 0aa7df4ed5ca38939bf614da7bbe460aa8d5a861..dd88682e27e319c0f133af2de8b81c3dc8d45086 100644 (file)
@@ -112,7 +112,8 @@ int virtqueue_resize(struct virtqueue *vq, u32 num,
                     void (*recycle)(struct virtqueue *vq, void *buf),
                     void (*recycle_done)(struct virtqueue *vq));
 int virtqueue_reset(struct virtqueue *vq,
-                   void (*recycle)(struct virtqueue *vq, void *buf));
+                   void (*recycle)(struct virtqueue *vq, void *buf),
+                   void (*recycle_done)(struct virtqueue *vq));
 
 struct virtio_admin_cmd {
        __le16 opcode;