From: Mark McLoughlin <markmc@redhat.com>
To: Rusty Russell <rusty@rustcorp.com.au>
Cc: Dor Laor <dor.laor@qumranet.com>,
kvm@vger.kernel.org, Herbert Xu <herbert@gondor.apana.org.au>
Subject: Re: [PATCH 3/9] kvm: qemu: Remove virtio_net tx ring-full heuristic
Date: Fri, 25 Jul 2008 18:30:15 +0100 [thread overview]
Message-ID: <1217007015.7098.102.camel@muff> (raw)
In-Reply-To: <200807251030.39301.rusty@rustcorp.com.au>
On Fri, 2008-07-25 at 10:30 +1000, Rusty Russell wrote:
> On Friday 25 July 2008 09:22:53 Dor Laor wrote:
> > Mark McLoughlin wrote:
> > > vq->vring.used->flags &= ~VRING_USED_F_NO_NOTIFY;
> > > qemu_del_timer(n->tx_timer);
> > > n->tx_timer_active = 0;
> >
> > As stated by newer messages, we should handle the first tx notification
> > if the timer wasn't active to shorten latency.
> > Cheers, Dor
>
> Here's what lguest does at the moment. Basically, we cut the timeout a tiny
> bit each time, until we get *fewer* packets than last time. Then we bump it
> up again.
>
> Rough, but seems to work (it should be a per-device var of course, not a
> static).
>
> @@ -921,6 +922,7 @@ static void handle_net_output(int fd, st
> unsigned int head, out, in, num = 0;
> int len;
> struct iovec iov[vq->vring.num];
> + static int last_timeout_num;
>
> if (!timeout)
> net_xmit_notify++;
> @@ -941,6 +943,14 @@ static void handle_net_output(int fd, st
> /* Block further kicks and set up a timer if we saw anything. */
> if (!timeout && num)
> block_vq(vq);
> +
> + if (timeout) {
> + if (num < last_timeout_num)
> + timeout_usec += 10;
> + else if (timeout_usec > 1)
> + timeout_usec--;
> + last_timeout_num = num;
> + }
Yeah, I gave this a try in kvm and in the host->guest case the timeout
just grew and grew. In the guest->host case, it did stabilise at around
50us with high throughput.
Basically, I think in the host->guest case the number of buffers was
very variable so the timeout would get bumped by 10, reduced by a small
amount, bumped by 10, reduced by a small amount, ...
But, I agree the general principal seems about right; just needs some
tweaking.
Cheers,
Mark.
next prev parent reply other threads:[~2008-07-25 17:30 UTC|newest]
Thread overview: 58+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-07-24 11:46 [PATCH 0/9][RFC] KVM virtio_net performance Mark McLoughlin
2008-07-24 11:46 ` [PATCH 1/9] kvm: qemu: Set MIN_TIMER_REARM_US to 150us Mark McLoughlin
2008-07-24 11:46 ` [PATCH 2/9] kvm: qemu: Fix virtio_net tx timer Mark McLoughlin
2008-07-24 11:46 ` [PATCH 3/9] kvm: qemu: Remove virtio_net tx ring-full heuristic Mark McLoughlin
2008-07-24 11:46 ` [PATCH 4/9] kvm: qemu: Add VIRTIO_F_NOTIFY_ON_EMPTY Mark McLoughlin
2008-07-24 11:46 ` [PATCH 5/9] kvm: qemu: Disable recv notifications until avail buffers exhausted Mark McLoughlin
2008-07-24 11:46 ` [PATCH 6/9] kvm: qemu: Add support for partial csums and GSO Mark McLoughlin
2008-07-24 11:46 ` [PATCH 7/9] kvm: qemu: Increase size of virtio_net rings Mark McLoughlin
2008-07-24 11:46 ` [PATCH 8/9] kvm: qemu: Drop the mutex while reading from tapfd Mark McLoughlin
2008-07-24 11:46 ` [PATCH 9/9] kvm: qemu: Eliminate extra virtio_net copy Mark McLoughlin
2008-07-24 23:33 ` [PATCH 8/9] kvm: qemu: Drop the mutex while reading from tapfd Dor Laor
2008-07-25 17:25 ` Mark McLoughlin
2008-07-24 23:22 ` [PATCH 3/9] kvm: qemu: Remove virtio_net tx ring-full heuristic Dor Laor
2008-07-25 0:30 ` Rusty Russell
2008-07-25 17:30 ` Mark McLoughlin [this message]
2008-07-25 17:23 ` Mark McLoughlin
2008-07-24 23:56 ` Dor Laor
2008-07-26 9:48 ` [PATCH 2/9] kvm: qemu: Fix virtio_net tx timer Avi Kivity
2008-07-26 12:08 ` Mark McLoughlin
2008-07-24 11:55 ` [PATCH 0/9][RFC] KVM virtio_net performance Herbert Xu
2008-07-24 16:53 ` Mark McLoughlin
2008-07-24 18:29 ` Anthony Liguori
2008-07-25 16:36 ` Mark McLoughlin
2008-07-24 20:56 ` Anthony Liguori
2008-07-25 17:17 ` Mark McLoughlin
2008-07-25 21:29 ` Dor Laor
2008-07-26 19:09 ` Bill Davidsen
2008-07-27 7:52 ` Avi Kivity
2008-07-27 12:52 ` Bill Davidsen
2008-07-27 13:17 ` Bill Davidsen
2008-07-28 6:42 ` Mark McLoughlin
2008-08-11 7:44 ` Rusty Russell
2008-08-11 9:51 ` Herbert Xu
2008-08-11 13:50 ` csum offload and af_packet Rusty Russell
2008-08-12 0:32 ` Herbert Xu
2008-08-12 0:51 ` David Miller
2008-08-12 0:58 ` Herbert Xu
2008-08-12 16:17 ` Ingo Oeser
2008-08-12 23:37 ` Herbert Xu
2008-08-13 0:55 ` David Miller
2008-08-13 1:09 ` Herbert Xu
2008-08-13 1:17 ` David Miller
2008-08-13 1:21 ` Herbert Xu
2008-08-13 1:25 ` David Miller
2008-08-13 1:37 ` Herbert Xu
2008-08-13 11:26 ` Patrick McHardy
2008-08-17 23:08 ` David Miller
2008-08-18 1:10 ` Herbert Xu
2008-08-18 1:12 ` David Miller
[not found] ` <48A8CCBF.3020408@trash.net>
2008-08-18 1:15 ` David Miller
2008-08-18 2:12 ` David Miller
2008-08-18 11:17 ` Patrick McHardy
2008-08-12 2:27 ` Rusty Russell
2008-07-26 9:45 ` [PATCH 0/9][RFC] KVM virtio_net performance Avi Kivity
2008-07-27 6:48 ` Rusty Russell
2008-07-27 6:48 ` Rusty Russell
2008-08-11 19:56 ` Mark McLoughlin
2008-08-12 13:35 ` Avi Kivity
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1217007015.7098.102.camel@muff \
--to=markmc@redhat.com \
--cc=dor.laor@qumranet.com \
--cc=herbert@gondor.apana.org.au \
--cc=kvm@vger.kernel.org \
--cc=rusty@rustcorp.com.au \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.