From: Rusty Russell Date: Mon, 19 Nov 2007 16:20:43 +0000 (-0500) Subject: virtio: fix net driver loop case where we fail to restart X-Git-Tag: firefly_0821_release~24270^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=8329d98e480250ef5f5a083f9c3af50510b5e65d;p=firefly-linux-kernel-4.4.55.git virtio: fix net driver loop case where we fail to restart skb is only NULL the first time around: it's more correct to test for being under-budget. Signed-off-by: Rusty Russell --- diff --git a/drivers/net/virtio_net.c b/drivers/net/virtio_net.c index d74e6f4aa248..5413dbf3d4ac 100644 --- a/drivers/net/virtio_net.c +++ b/drivers/net/virtio_net.c @@ -198,8 +198,8 @@ again: if (vi->num < vi->max / 2) try_fill_recv(vi); - /* All done? */ - if (!skb) { + /* Out of packets? */ + if (received < budget) { netif_rx_complete(vi->dev, napi); if (unlikely(!vi->rvq->vq_ops->restart(vi->rvq)) && netif_rx_reschedule(vi->dev, napi))