From: David Vrabel Date: Fri, 12 May 2017 08:46:32 +0000 (+0100) Subject: xen-netback: process guest rx packets in batches X-Git-Tag: v4.1.12-102.0.20170601_1400~213^2~18 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=795b494d32714481b95545f78973e9491be29aa3;p=users%2Fjedix%2Flinux-maple.git xen-netback: process guest rx packets in batches Instead of only placing one skb on the guest rx ring at a time, process a batch of up-to 64. This improves performance by ~10% in some tests. Signed-off-by: David Vrabel [re-based] Signed-off-by: Paul Durrant Signed-off-by: David S. Miller (cherry picked from commit 98f6d57ced73b723551568262019f1d6c8771f20) Signed-off-by: Joao Martins Reviewed-by: Shannon Nelson Acked-by: Konrad Rzeszutek Wilk --- diff --git a/drivers/net/xen-netback/rx.c b/drivers/net/xen-netback/rx.c index 315610ad5aa8f..d1862dbf474ac 100644 --- a/drivers/net/xen-netback/rx.c +++ b/drivers/net/xen-netback/rx.c @@ -372,7 +372,7 @@ static void xenvif_rx_extra_slot(struct xenvif_queue *queue, BUG(); } -void xenvif_rx_action(struct xenvif_queue *queue) +void xenvif_rx_skb(struct xenvif_queue *queue) { struct xenvif_pkt_state pkt; @@ -398,6 +398,19 @@ void xenvif_rx_action(struct xenvif_queue *queue) xenvif_rx_complete(queue, &pkt); } +#define RX_BATCH_SIZE 64 + +void xenvif_rx_action(struct xenvif_queue *queue) +{ + unsigned int work_done = 0; + + while (xenvif_rx_ring_slots_available(queue) && + work_done < RX_BATCH_SIZE) { + xenvif_rx_skb(queue); + work_done++; + } +} + static bool xenvif_rx_queue_stalled(struct xenvif_queue *queue) { RING_IDX prod, cons;