Re: [PATCH] correct inconsistent ntp interval/tick_length usage

From: Roman Zippel
Date: Mon Feb 25 2008 - 09:44:17 EST


Hi,

On Thu, 21 Feb 2008, john stultz wrote:

> > Again, what kind of crappy hardware do you expect? Aren't clocks supposed
> > to get better and not worse?
>
> Well, while I've seen much worse, I consider crappy hardware to be 100
> +ppm error. So if the hardware is perfect and the system results in
> 153ppm error, I'd consider that pretty crappy, especially if its not the
> hardware's fault.

Nevertheless this error is real, why are you trying to hide it?
This is isn't an error we can't handle, it's still perfectly within the
limit and except that NTP reports a somewhat larger drift than you'd like
to see, everything works fine.

> > Where do you get this idea that the 500ppm are exclusively for hardware
> > errors? If you have such bad hardware, there is another simple solution:
> > change HZ to 100 and the error is reduced to 15ppm.
>
> True its not exclusively for hardware errors, and if we were talking
> about only 15ppm I wouldn't really worry about it. But when we're saying
> the system is adding 30% of the maximum error, that's just not good.

Another 30% is required for normal to crappy hardware clocks and then
there is still enough room left.

> > I would see the point if this problem had actually any practically
> > relevance, but this error is not a problem for pretty much all existing
> > standard hardware. Why are you insisting on redesigning timekeeping for
> > broken hardware?
>
> Remember my earlier data? Where I was talking about the acpi_pm being a
> multiple of the PIT frequency? By removing CLOCK_TICK_ADJUST we got a
> 127ppm error when HZ=1000. NO_HZ drops that down to where we don't care,
> but this _does_ effect current hardware, so I'd call it relevant.

How exactly does it effect current hardware in a way that it breaks them?
Despite this error everything still works fine, the hardware doesn't care.

> > There's nothing 'injected', that resolution error is very real and the
> > 500ppm limit is more than enough to deal with this. _Nobody_ is hurt by
> > this.
>
> Sure, 500ppm is enough for most people with good hardware. But remember
> the alpha example you brought up earlier? The HZ=1200 case, with the
> CLOCK_TICK_RATE=32768? If we don't take CLOCK_TICK_ADJUST into account,
> we end up with a **11230ppm** error from the granularity issue. NTP just
> won't work on those systems.
>
> Now granted, the three types of alpha systems that actually use that HZ
> value is probably as close to "nobody" as you're going to get, but I
> don't think we can just throw the granularity issue aside.

That's actually a good example, why it's irrelevant. First it's using a
cycle based clock, thus the rounding error is irrelevant. Second in the
common case they already use 1024 as HZ to reduce this error, so something
similiar could be done for the HZ=1200 case and I suspect that it was
already done and only CLOCK_TICK_RATE is just wrong. This mail
http://consortiumlibrary.org/axp-list/archive/2002-11/0101.html suggest
that this is the right thing to do.

There is _no_ reason to artificially optimize this error value, there are
still enough other ways to improve timekeeping. The granularity error is
there no matter what you do and as long as it's within a reasonable limit
there is nothing that needs fixing.

bye, Roman
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/