提交 4d6308aa 编写于 作者: E Eric Dumazet 提交者: David S. Miller

virtio_net: exploit napi_complete_done() return value

Since commit 364b6055 ("net: busy-poll: return busypolling status to
drivers"), napi_complete_done() returns a boolean that can be used
by drivers to conditionally rearm interrupts.

This patch changes virtio_net to use this boolean to avoid a bit of
overhead for busy-poll users.

Jason reports about 1.1% improvement for 1 byte TCP_RR (burst 100).
Signed-off-by: NEric Dumazet <edumazet@google.com>
Acked-by: NJason Wang <jasowang@redhat.com>
Cc: Michael S. Tsirkin <mst@redhat.com>
Cc: Willem de Bruijn <willemb@google.com>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 a076d1bd
...@@ -1012,13 +1012,14 @@ static int virtnet_poll(struct napi_struct *napi, int budget) ...@@ -1012,13 +1012,14 @@ static int virtnet_poll(struct napi_struct *napi, int budget)
/* Out of packets? */ /* Out of packets? */
if (received < budget) { if (received < budget) {
r = virtqueue_enable_cb_prepare(rq->vq); r = virtqueue_enable_cb_prepare(rq->vq);
napi_complete_done(napi, received); if (napi_complete_done(napi, received)) {
if (unlikely(virtqueue_poll(rq->vq, r)) && if (unlikely(virtqueue_poll(rq->vq, r)) &&
napi_schedule_prep(napi)) { napi_schedule_prep(napi)) {
virtqueue_disable_cb(rq->vq); virtqueue_disable_cb(rq->vq);
__napi_schedule(napi); __napi_schedule(napi);
} }
} }
}
return received; return received;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册