diff options
author | Xuan Zhuo <xuanzhuo@linux.alibaba.com> | 2023-05-08 09:14:08 +0300 |
---|---|---|
committer | Jakub Kicinski <kuba@kernel.org> | 2023-05-10 05:44:27 +0300 |
commit | 80f50f918c6e2d3f46aae717e6b04271298ab1c0 (patch) | |
tree | 604b4b522363966fe8b424e370b900657dc00838 /drivers | |
parent | bb2c1e9e75be4a059fa795aac58b805091c9dae7 (diff) | |
download | linux-80f50f918c6e2d3f46aae717e6b04271298ab1c0.tar.xz |
virtio_net: separate the logic of freeing the rest mergeable buf
This patch introduce a new function that frees the rest mergeable buf.
The subsequent patch will reuse this function.
Signed-off-by: Xuan Zhuo <xuanzhuo@linux.alibaba.com>
Acked-by: Jason Wang <jasowang@redhat.com>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/virtio_net.c | 36 |
1 files changed, 24 insertions, 12 deletions
diff --git a/drivers/net/virtio_net.c b/drivers/net/virtio_net.c index c1538ab46795..b26e95c96141 100644 --- a/drivers/net/virtio_net.c +++ b/drivers/net/virtio_net.c @@ -1071,6 +1071,28 @@ err: return NULL; } +static void mergeable_buf_free(struct receive_queue *rq, int num_buf, + struct net_device *dev, + struct virtnet_rq_stats *stats) +{ + struct page *page; + void *buf; + int len; + + while (num_buf-- > 1) { + buf = virtqueue_get_buf(rq->vq, &len); + if (unlikely(!buf)) { + pr_debug("%s: rx error: %d buffers missing\n", + dev->name, num_buf); + dev->stats.rx_length_errors++; + break; + } + stats->bytes += len; + page = virt_to_head_page(buf); + put_page(page); + } +} + /* Why not use xdp_build_skb_from_frame() ? * XDP core assumes that xdp frags are PAGE_SIZE in length, while in * virtio-net there are 2 points that do not match its requirements: @@ -1431,18 +1453,8 @@ err_xdp: stats->xdp_drops++; err_skb: put_page(page); - while (num_buf-- > 1) { - buf = virtqueue_get_buf(rq->vq, &len); - if (unlikely(!buf)) { - pr_debug("%s: rx error: %d buffers missing\n", - dev->name, num_buf); - dev->stats.rx_length_errors++; - break; - } - stats->bytes += len; - page = virt_to_head_page(buf); - put_page(page); - } + mergeable_buf_free(rq, num_buf, dev, stats); + err_buf: stats->drops++; dev_kfree_skb(head_skb); |