Timekeeping oddities on MacMini G4s

Benjamin Herrenschmidt benh at kernel.crashing.org
Wed Feb 1 14:34:48 AEDT 2017


On Wed, 2017-02-01 at 14:10 +1100, Hugh Blemings wrote:
> Hi,
> 
> I've recently been lurking on the ntpsec project mailing list.
> 
> One of the developers (Hal Murray, CCd) has been doing some tests of the 
> codebase using FreeBSD and Debian on a G4 based Mac Mini - this largely 
> motivated by checking all is well on a big-endian system.
> 
> Hal has identified what appears to be a systemic inaccuracy in kernel 
> timekeeping of around 2500ppm on both Linux and FreeBSD and on several 
> different MacMini G4s (1.42GHz and 1.5GHz variants)
> 
> That it appears on both Linux and FreeBSD kernels and some other data 
> points leads us to wonder if the CPU frequency reported by Open Firmware 
> being different to the actual raw clock is the root cause, but I/we 
> speculate at this point.

Right, we just use the value provided by Open Firmware. Any chance you
can try with MacOS X ?

>From the value in the properties you showed me (and the ones I have in
some DT snapshots) it looks like the value isn't fixed but somewhat
calibrated by Open Firmware during boot.

It could be that this calibration sucks. MacOS X seems to do its own
calibration at boot time based on the KeyLargo timer. It would be useful
to see if their stuff is more precise, we could write something similar
for Linux and BSD.

Cheers,
Ben.

 


More information about the Linuxppc-dev mailing list