Date: Thu, 02 Oct 2014 16:15:06 -0600 From: Ian Lepore <ian@FreeBSD.org> To: John Baldwin <jhb@freebsd.org> Cc: freebsd-hackers@freebsd.org, Adrian Chadd <adrian@freebsd.org>, Paul Albrecht <palbrecht@glccom.com> Subject: Re: freebsd 10 kqueue timer regression Message-ID: <1412288106.12052.39.camel@revolution.hippie.lan> In-Reply-To: <201410021600.17740.jhb@freebsd.org> References: <8ABC0977-FB8F-45E7-ACCC-BFA92EE22E1C@glccom.com> <CAJ-VmokPNgckHiR0znp6p4u2NRO0aOR_eaOVaBWe7cWDp2_o5g@mail.gmail.com> <1412279608.12052.24.camel@revolution.hippie.lan> <201410021600.17740.jhb@freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, 2014-10-02 at 16:00 -0400, John Baldwin wrote: > On Thursday, October 02, 2014 3:53:28 pm Ian Lepore wrote: > > On Thu, 2014-10-02 at 12:47 -0700, Adrian Chadd wrote: > > > I'm confused; it's doing 50 loops of a 20msec timer, right? So that's > 1000ms. > > > > Yes, so the entire loop should take 1000ms maybe + 1ms. Instead it > > takes 1070. When I run it on an armv6 system running -current it takes > > 1050. When I run it on my 8.4 desktop (pre-eventtimers) it takes 1013. > > > > -- Ian > > What if you set kern.eventtimer.periodic=1? > Some interesting results... HZ 100 500 1000 --------------------------------- periodic=0 1050 1050 1080 periodic=1 1110 1012 1049 The 1080 number was +/- 3ms, all the other numbers were +/- 1ms (except for one outlier of 24363 at 100Hz non-periodic which I'm going to pretend didn't happen). The 1050 numbers are probably each 20ms sleep actually taking 21ms, but the old tvtohz code with -1 adjustments from the old email thread isn't in play anymore. I don't know how to account for the other numbers at all. There's all kinds of stuff I don't understand in the new code involving tick thresholds and such. -- Ian
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?1412288106.12052.39.camel>