freebsd 10 kqueue timer regression
Ian Lepore
ian at FreeBSD.org
Thu Oct 2 22:15:10 UTC 2014
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
More information about the freebsd-hackers
mailing list