[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <m3k5xzy2w3.fsf@elektro.pacujo.net>
Date: 02 Mar 2007 09:24:44 -0800
From: Marko Rauhamaa <marko@...ujo.net>
To: tglx@...utronix.de
Cc: linux-kernel@...r.kernel.org
Subject: Re: Is the clockevent resolution fine-grained enough?
Thomas Gleixner <tglx@...utronix.de>:
> On Thu, 2007-03-01 at 18:34 -0800, Marko Rauhamaa wrote:
> > It would appear the new clockevent API has a one-nanosecond
> > resolution. It certainly looks sufficiently fine-grained, but I'm
> > afraid it's too coarse for some applications.
>
> That's an academic exercise, or are you talking about some real world
> hardware which runs Linux ?
Real hardware running linux.
> > In our application, we need periodic clock interrupts at about 100
> > kHz.
>
> With a stock kernel ?
Well, with a "clockevent" patch of our own. We'd like to use a stock
kernel, though.
> > If the (programmable) frequency must be rounded to the nearest
> > nanosecond, we have a cumulative error of
> >
> > 100,000 * 0.5 ns/s = 50 µs/s
>
> clockevents is based on the monotonic system clock and depends on the
> accuracy of that and the device which deliveres the interrupts.
> [...]
> There is nothing to nugde. The clockevent subsystem operates on
> absolute time, so there is no cummulative error, except you setup your
> timers relative per event.
I'm afraid you didn't quite understand what I was getting at. Say the
user programs the frequency to be 109,000 Hz. That means a nominal clock
interval of ~9174.3119 ns. Now the clockevent interface forces me to
round it down to 9174 ns. That means the clock interrupts fall behind
with respect to the other parts in the system that implement 109,000 Hz
much more to the letter. The error grows by 34 µs every second so that
after 8 hours, we are lagging by a whole second.
Marko
--
Marko Rauhamaa mailto:marko@...ujo.net http://pacujo.net/marko/
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists