[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <alpine.LFD.1.10.0809021446360.3160@nehalem.linux-foundation.org>
Date: Tue, 2 Sep 2008 15:21:14 -0700 (PDT)
From: Linus Torvalds <torvalds@...ux-foundation.org>
To: Thomas Gleixner <tglx@...utronix.de>
cc: Larry Finger <Larry.Finger@...inger.net>,
LKML <linux-kernel@...r.kernel.org>,
"Rafael J. Wysocki" <rjw@...k.pl>,
Alok Kataria <akataria@...are.com>,
Michael Buesch <mb@...sch.de>
Subject: Re: Regression in 2.6.27 caused by commit bfc0f59
On Tue, 2 Sep 2008, Thomas Gleixner wrote:
>
> On that box, the PIT is probably real hardware or a damned good
> emulation. When you look at the 10 loop values you see that it does
> 50% perfectly fine calibration loops. The others are just SMI
> interruptions caused by random unknown crap in the BIOS.
Ok, so I actually think I know how to resolve the problem once and for
all.
The solution is actually fairly simple: we use the HPET algorithm. The
reason the HPET algorithm is so robust is that
- we can actually read the frequency from the HPET itself
- we also simply just read the counter values from the HPET, and so it
doesn't really matter how much time has passed between the two reads,
it only matters that _some_ time has passed, and that we pick _one_
stable read that we can associate with a TSC value.
But the thing is, the exact same thing is actually true of the old PIT
timer too - except we simply don't take advantage of it. The PIT timer has
a very well known frequency value (PIT_TICK_RATE: 1193180 Hz), and we can
trivially read the counter value too.
But the thing is, that for some forgotten reason, that's not actually what
we do. Instead of reading the counter value, we wait until it counts down
to zero, and read the output value instead. So instead of having a nice
and dependable counter that ticks down (16 bits of precision), we actually
use a _single_ bit of result, and depend on reading the TSC at the same
time.
That's kind of sad.
I'll try to whip up a test-patch to do this in a smarter way.
Linus
--
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